Changeset 2f429e
- Timestamp:
- Oct 11, 2015, 7:11:38 AM (9 years ago)
- Branches:
- Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
- Children:
- d26fb7
- Parents:
- 3b1c36
- git-author:
- Frederik Heber <heber@…> (09/22/15 18:02:47)
- git-committer:
- Frederik Heber <heber@…> (10/11/15 07:11:38)
- Location:
- src
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Parameters/Specifics/Value_element.cpp
r3b1c36 r2f429e 35 35 #include "CodePatterns/MemDebug.hpp" 36 36 37 #include <boost/lexical_cast.hpp> 38 37 39 #include "Value_element.hpp" 38 40 … … 45 47 static const element * FindElementByString(const std::string &_value) 46 48 { 47 static ConvertTo<atomicNumber_t> converter; 48 const element * _element = 49 World::getInstance().getPeriode()->FindElement(converter(_value)); 50 return _element; 49 const element * elem = NULL; 50 try { 51 const int tempvalue = boost::lexical_cast<atomicNumber_t>(_value); 52 elem = World::getInstance().getPeriode()->FindElement(tempvalue); 53 } catch( boost::bad_lexical_cast &e) { 54 elem = World::getInstance().getPeriode()->FindElement(_value); 55 } 56 return elem; 51 57 } 52 58 -
src/Parameters/Specifics/Value_elements.cpp
r3b1c36 r2f429e 57 57 for(tokenizer::iterator beg=tok.begin(); 58 58 beg != tok.end();++beg) { 59 const int tempvalue = boost::lexical_cast<atomicNumber_t>(*beg); 60 const element * _element = 61 World::getInstance().getPeriode()->FindElement(tempvalue); 62 ASSERT( _element != NULL, 59 const element * elem = NULL; 60 try { 61 const int tempvalue = boost::lexical_cast<atomicNumber_t>(*beg); 62 elem = World::getInstance().getPeriode()->FindElement(tempvalue); 63 } catch( boost::bad_lexical_cast &e) { 64 elem = World::getInstance().getPeriode()->FindElement(*beg); 65 } 66 ASSERT( elem != NULL, 63 67 "FindElementsByString() - cannnot find element " 64 +toString( tempvalue)+" in periodentafel.");65 elements.push_back( _element);68 +toString(*beg)+" in periodentafel."); 69 elements.push_back(elem); 66 70 } 67 71 return elements; -
src/UIElements/CommandLineUI/CommandLineParser.cpp
r3b1c36 r2f429e 390 390 // currentOption->hasDefaultValue() ? 391 391 // po::value < const element * >()->default_value(boost::lexical_cast<const element *>(currentOption->getDefaultValue().c_str())) : 392 po::value < int>(),392 po::value < std::string >(), 393 393 currentOption->getDescription().c_str()) 394 394 ; … … 399 399 // currentOption->hasDefaultValue() ? 400 400 // po::value < std::vector<const element *> >()->default_value(boost::lexical_cast< std::vector<const element *> >(currentOption->getDefaultValue().c_str())) : 401 po::value < std::vector< int> >()->multitoken(),401 po::value < std::vector<std::string> >()->multitoken(), 402 402 currentOption->getDescription().c_str()) 403 403 ; -
src/UIElements/CommandLineUI/Query/ElementCommandLineQuery.cpp
r3b1c36 r2f429e 36 36 #include "CodePatterns/MemDebug.hpp" 37 37 38 #include <string> 39 38 40 #include "CommandLineUI/Query/CommandLineQuery.hpp" 39 41 #include "CommandLineUI/CommandLineParser.hpp" … … 54 56 // TODO: vector of ints and removing first is not correctly implemented yet. How to remove from a vector? 55 57 periodentafel *periode = World::getInstance().getPeriode(); 56 int Z = -1;57 58 if (CommandLineParser::getInstance().vm.count(getTitle())) { 59 std::string argument("none"); 58 60 try { 59 Z = CommandLineParser::getInstance().vm[getTitle()].as< int >(); 61 argument = CommandLineParser::getInstance().vm[getTitle()].as< std::string >(); 62 try { 63 int Z = -1; 64 Z = boost::lexical_cast<int>(argument); 65 temp = periode->FindElement(Z); 66 } catch(boost::bad_lexical_cast &e) { 67 temp = periode->FindElement(argument); 68 } 60 69 } catch(boost::bad_any_cast &e) { 61 Z = -1;62 70 return false; 63 71 } 64 temp = periode->FindElement(Z);65 72 ASSERT(temp != NULL, "Invalid element specified in ElementCommandLineQuery"); 66 73 return true; -
src/UIElements/CommandLineUI/Query/ElementsCommandLineQuery.cpp
r3b1c36 r2f429e 36 36 #include "CodePatterns/MemDebug.hpp" 37 37 38 #include <string> 39 38 40 #include "CommandLineUI/Query/CommandLineQuery.hpp" 39 41 #include "CommandLineUI/CommandLineParser.hpp" … … 51 53 {} 52 54 55 template <typename T> 56 std::vector<const element *> getElementsFromInput(const std::vector<std::string> &_input) 57 { 58 periodentafel *periode = World::getInstance().getPeriode(); 59 std::vector<const element *> result; 60 const element *temp_element; 61 for (typename std::vector<std::string>::const_iterator ZRunner = _input.begin(); ZRunner != _input.end(); ++ZRunner) { 62 const T argument = boost::lexical_cast<T>(*ZRunner); 63 temp_element = periode->FindElement(argument); 64 ASSERT(temp_element != NULL, "Invalid element specified in ElementCommandLineQuery"); 65 result.push_back(temp_element); 66 } 67 return result; 68 } 69 53 70 bool CommandLineDialog::ElementsCommandLineQuery::handle() { 54 71 // TODO: vector of ints and removing first is not correctly implemented yet. How to remove from a vector? 55 periodentafel *periode = World::getInstance().getPeriode();56 std::vector<int> AllElements;57 72 if (CommandLineParser::getInstance().vm.count(getTitle())) { 58 73 try { 59 AllElements = CommandLineParser::getInstance().vm[getTitle()].as< vector<int> >(); 74 std::vector<std::string> AllArguments; 75 AllArguments = CommandLineParser::getInstance().vm[getTitle()].as< vector<std::string> >(); 76 try { 77 temp = getElementsFromInput<int>(AllArguments); 78 } catch(boost::bad_lexical_cast &e) { 79 try { 80 temp = getElementsFromInput<std::string>(AllArguments); 81 } catch(boost::bad_lexical_cast &e) { 82 return false; 83 } 84 } 60 85 } catch(boost::bad_any_cast &e) { 61 AllElements.clear();62 86 return false; 63 87 } 64 const element *temp_element; 65 for (vector<int>::iterator ZRunner = AllElements.begin(); ZRunner != AllElements.end(); ++ZRunner) { 66 temp_element = periode->FindElement(*ZRunner); 67 ASSERT(temp_element != NULL, "Invalid element specified in ElementCommandLineQuery"); 68 temp.push_back(temp_element); 69 } 70 return true; 88 if (temp.empty()) 89 return false; 90 else 91 return true; 71 92 } 72 93 return false;
Note:
See TracChangeset
for help on using the changeset viewer.