source: src/UIElements/TextUI/Query/VectorsTextQuery.cpp@ adbeca

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since adbeca was cb5231, checked in by Frederik Heber <frederik.heber@…>, 8 years ago

Vector(s) are now stored as strings in Querys intermediately.

  • they get evaluated first after being stored in a Parameter/Value on request via get().
  • Needed to change all Vector(s)..Query's of all UIs and also the general base classes inside Dialog.
  • QtQueryList need to be specialized in order to allow a QtQueryList<Vector> to actually store a vector of strings.
  • we may use setAsString() in order to set the Parameter thankfully.
  • TESTS: All regression tests on Geometry Actions are now working.
  • Property mode set to 100644
File size: 2.5 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
21 */
22
23/*
24 * VectorsTextQuery.cpp
25 *
26 * Created on: Oct 25, 2010
27 * Author: heber
28 */
29
30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
34
35//#include "CodePatterns/MemDebug.hpp"
36
37#include <iostream>
38
39#include "TextUI/Query/TextQuery.hpp"
40
41#include "CodePatterns/Log.hpp"
42#include "CodePatterns/Verbose.hpp"
43#include "Geometry/GeometryRegistry.hpp"
44#include "LinearAlgebra/Vector.hpp"
45#include "LinearAlgebra/RealSpaceMatrix.hpp"
46#include "World.hpp"
47
48
49TextDialog::VectorsTextQuery::VectorsTextQuery(Parameter<std::vector<Vector> > &_param, const std::string &_title, const std::string &_description) :
50 Dialog::TQuery<std::vector<Vector> >(_param, _title,_description)
51{}
52
53TextDialog::VectorsTextQuery::~VectorsTextQuery()
54{}
55
56bool TextDialog::VectorsTextQuery::handle() {
57 std::stringstream output;
58 std::cout << getDescription() << std::endl;
59 char coords[3] = {'x', 'y', 'z'};
60 const RealSpaceMatrix &M = World::getInstance().getDomain().getM();
61 std::cout << "Enter three comma-separated coordinates, vector name, ? for list or empty for end." << std::endl;
62 while (true) {
63 for (int i=0;i<3;i++)
64 std::cout << coords[i] << "[0.." << M.at(i,i) << ( (i!=2) ? "], " : "]: ");
65
66 std::string line;
67 getline(std::cin,line);
68
69 if (line == "?") {
70 GeometryRegistry &reg = GeometryRegistry::getInstance();
71
72 GeometryRegistry::const_iterator iter;
73 for (iter = reg.getBeginIter(); iter != reg.getEndIter(); iter ++){
74 GeometryObject *v = iter->second;
75 std::cout << "\t" << *v << std::endl;
76 }
77 } else if (line.empty()) {
78 break;
79 } else {
80 // simply append with white-space delimiter
81 temp.push_back(line);
82 }
83 }
84
85 return true;
86}
87
Note: See TracBrowser for help on using the repository browser.