- Timestamp:
- Jun 1, 2012, 3:31:25 PM (13 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:
- 118f1e
- Parents:
- 7dc60a
- git-author:
- Michael Ankele <ankele@…> (04/18/12 14:02:14)
- git-committer:
- Michael Ankele <ankele@…> (06/01/12 15:31:25)
- Location:
- src/Parameters
- Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Parameters/Parameter_impl.hpp
r7dc60a r6c05d8 143 143 { 144 144 Parameter<T> *instance = new Parameter<T>(ParameterInterface<T>::getName(), Value<T>::getValidator()); 145 instance->set(Value<T>::get()); 145 if (Value<T>::ValueSet) 146 instance->set(Value<T>::get()); 146 147 return instance; 147 148 } -
src/Parameters/Value.hpp
r7dc60a r6c05d8 27 27 28 28 class ValueTest; 29 template <class T> 30 class Parameter; 29 31 30 32 /** This class represents a general value. … … 37 39 friend class ValueTest; 38 40 friend class ContinuousValueTest; 41 friend class Parameter<T>; 39 42 public: 40 43 Value(); -
src/Parameters/Value_impl.hpp
r7dc60a r6c05d8 22 22 #include "CodePatterns/Log.hpp" 23 23 24 #include "Validators/DummyValidator.hpp" 24 25 #include "Validators/DiscreteValidator.hpp" 25 26 #include "Validators/RangeValidator.hpp" … … 33 34 Value<T>::Value() : 34 35 ValueSet(false), 35 validator( NULL)36 validator(new DummyValidator<T>) 36 37 {} 37 38 … … 75 76 Value<T>::~Value() 76 77 { 77 if (validator) 78 delete(validator); 78 ASSERT(validator, 79 "Value<T>::~Value() - validator missing."); 80 delete(validator); 79 81 } 80 82 … … 86 88 bool Value<T>::isValid(const T & _value) const 87 89 { 88 if (validator)89 return (*validator)(_value);90 return true;90 ASSERT(validator, 91 "Value<T>::isValid() - validator missing."); 92 return (*validator)(_value); 91 93 } 92 94 … … 99 101 bool Value<T>::operator==(const Value<T> &_instance) const 100 102 { 103 ASSERT(validator, 104 "Value<T>::operator==() - validator missing."); 105 ASSERT(_instance.validator, 106 "Value<T>::operator==() - instance.validator missing."); 101 107 bool status = true; 102 108 status = status && (*validator == *_instance.validator); … … 148 154 } 149 155 156 template <> 157 inline bool Value<std::string>::isValidAsString(const std::string _value) const 158 { 159 return isValid(_value); 160 } 161 150 162 /** Getter of value, returning string. 151 163 * … … 173 185 } 174 186 187 template <> 188 inline void Value<std::string>::setAsString(const std::string _value) 189 { 190 set(_value); 191 // LOG(0, "STATUS: Value is now set to " << value << "."); 192 } 193 175 194 /** Returns the validator as a const reference. 176 195 * … … 180 199 const Validator<T> &Value<T>::getValidator() const 181 200 { 201 ASSERT(validator, 202 "Value<T>::getValidator() const - validator missing."); 182 203 return *validator; 183 204 } … … 190 211 Validator<T> &Value<T>::getValidator() 191 212 { 213 ASSERT(validator, 214 "Value<T>::getValidator() - validator missing."); 192 215 return *validator; 193 216 } -
src/Parameters/unittests/ContinuousParameterTest.cpp
r7dc60a r6c05d8 84 84 Parameter<int> test("intParam", *ValidIntRange); 85 85 86 // check that we throw because of unset parameter87 #ifndef NDEBUG88 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;89 CPPUNIT_ASSERT_THROW(test.clone(), Assert::AssertionFailure);90 #endif91 92 86 // set parameter 93 87 test.set(2); -
src/Parameters/unittests/ContinuousValueTest.cpp
r7dc60a r6c05d8 60 60 61 61 // checking valid values 62 /*for (int i=1; i<=4;++i)62 for (int i=1; i<=4;++i) 63 63 CPPUNIT_ASSERT_EQUAL(true, test.isValidAsString(toString(i))); 64 64 … … 67 67 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); 68 68 for (int i=5; i<=0;++i) 69 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); */69 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); 70 70 } 71 71 … … 144 144 145 145 // setting invalid, throws 146 /*#ifndef NDEBUG146 #ifndef NDEBUG 147 147 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl; 148 148 CPPUNIT_ASSERT_THROW(test.setAsString(toString(5)), Assert::AssertionFailure); … … 159 159 CPPUNIT_ASSERT_EQUAL(true, test.ValueSet); 160 160 CPPUNIT_ASSERT_EQUAL(toString(i), test.getAsString()); 161 } */161 } 162 162 } 163 163 -
src/Parameters/unittests/DiscreteParameterTest.cpp
r7dc60a r6c05d8 84 84 Parameter<int> test("intParam", ValidValues); 85 85 86 // check that we throw because of unset parameter87 #ifndef NDEBUG88 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;89 CPPUNIT_ASSERT_THROW(test.clone(), Assert::AssertionFailure);90 #endif91 92 86 // set parameter 93 87 test.set(2); -
src/Parameters/unittests/DiscreteValueTest.cpp
r7dc60a r6c05d8 82 82 83 83 // checking valid values 84 /*for (int i=1; i<=3;++i)84 for (int i=1; i<=3;++i) 85 85 CPPUNIT_ASSERT_EQUAL(true, test.isValidAsString(toString(i))); 86 86 … … 89 89 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); 90 90 for (int i=4; i<=0;++i) 91 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); */91 CPPUNIT_ASSERT_EQUAL(false, test.isValidAsString(toString(i))); 92 92 } 93 93 … … 195 195 196 196 // setting invalid, throws 197 /*#ifndef NDEBUG197 #ifndef NDEBUG 198 198 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl; 199 199 CPPUNIT_ASSERT_THROW(test.setAsString(toString(4)), Assert::AssertionFailure); … … 208 208 test.setAsString(toString(i)); 209 209 CPPUNIT_ASSERT_EQUAL(toString(i), test.getAsString()); 210 } */210 } 211 211 } 212 212
Note:
See TracChangeset
for help on using the changeset viewer.