Ignore:
Timestamp:
Jun 13, 2012, 5:39:12 PM (13 years ago)
Author:
Frederik Heber <heber@…>
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:
8453b3
Parents:
301723
git-author:
Frederik Heber <heber@…> (05/09/12 16:17:57)
git-committer:
Frederik Heber <heber@…> (06/13/12 17:39:12)
Message:

All Actions' .def files now have a paramvalids that is used to for validators of their Parameters.

  • the structure ActionParameters contains Parameter<> instances per required parameter of the Action.
  • these Parameter<> contain a validation functionality if given a Validator.
  • right now via boost::preprocessor magic (new defines valid_print and validcopy_print) we create the cstor of the derived ActionParameters class and create a DummyValidator of the correct type for each parameter.
  • TODO: We have to go through each .def file and replace DummyValidator by the correct Validator.
  • added src/Actions/test.sh which is the shell script to make these changes.
Location:
src/Actions/MoleculeAction
Files:
15 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/MoleculeAction/BondFileAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)(unsigned int)(unsigned int)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())(DummyValidator< unsigned int >())(DummyValidator< unsigned int >())
    1518#define paramtokens ("bond-file")("skiplines")("offset")
    1619#define paramdescriptions ("name of the bond file")("number of header lines to skip")("offset to add to each id")
  • src/Actions/MoleculeAction/ChangeNameAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (std::string)
     17#define paramvalids (DummyValidator< std::string >())
    1518#define paramtokens ("change-molname")
    1619#define paramdescriptions ("new name of molecule")
  • src/Actions/MoleculeAction/CopyAction.def

    r301723 r649aaa  
    99#include <vector>
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (Vector)
     17#define paramvalids (DummyValidator< Vector >())
    1518#define paramtokens ("position")
    1619#define paramdescriptions ("position in R^3 space")
  • src/Actions/MoleculeAction/FillVoidWithMoleculeAction.def

    r301723 r649aaa  
    1010class MoleculeListClass;
    1111
     12#include "Parameters/Validators/DummyValidator.hpp"
     13
    1214// i.e. there is an integer with variable name Z that can be found in
    1315// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1416// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1517#define paramtypes (boost::filesystem::path)(Vector)(double)(double)(double)(double)(bool)
     18#define paramvalids (DummyValidator< boost::filesystem::path >())(DummyValidator< Vector >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< bool >())
    1619#define paramtokens ("fill-void")("distances")("distance-to-molecule")("random-atom-displacement")("random-molecule-displacement")("distance-to-boundary")("DoRotate")
    1720#define paramdescriptions ("name of xyz file of filler molecule")("list of three of distances in space, one for each axis direction")("minimum distance to present molecules")("magnitude of random atom displacement")("magnitude of random molecule displacement")("minimum distance to boundary")("whether to rotate or not")
  • src/Actions/MoleculeAction/FillWithMoleculeAction.def

    r301723 r649aaa  
    1111class MoleculeListClass;
    1212
     13#include "Parameters/Validators/DummyValidator.hpp"
     14
    1315// i.e. there is an integer with variable name Z that can be found in
    1416// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1517// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1618#define paramtypes (boost::filesystem::path)(Vector)(double)(double)(double)(double)(bool)
     19#define paramvalids (DummyValidator< boost::filesystem::path >())(DummyValidator< Vector >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< double >())(DummyValidator< bool >())
    1720#define paramtokens ("fill-molecule")("distances")("distance-to-molecule")("random-atom-displacement")("random-molecule-displacement")("MaxDistance")("DoRotate")
    1821#define paramdescriptions ("name of xyz file of filler molecule")("list of three of distances in space, one for each axis direction")("minimum distance to present molecules")("magnitude of random atom displacement")("magnitude of random molecule displacement")("maximum spatial distance")("whether to rotate or not")
  • src/Actions/MoleculeAction/LinearInterpolationofTrajectoriesAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (unsigned int)(unsigned int)(unsigned int)(bool)
     17#define paramvalids (DummyValidator< unsigned int >())(DummyValidator< unsigned int >())(DummyValidator< unsigned int >())(DummyValidator< bool >())
    1518#define paramtokens ("start-step")("interpolation-steps")("end-step")("id-mapping")
    1619#define paramdescriptions ("first or start step")("number of steps to interpolate in between start and end step")("last or end step")("whether the identity shall be used in mapping atoms onto atoms or not")
  • src/Actions/MoleculeAction/LoadAction.def

    r301723 r649aaa  
    1111#include <boost/shared_ptr.hpp>
    1212
     13#include "Parameters/Validators/DummyValidator.hpp"
     14
    1315// i.e. there is an integer with variable name Z that can be found in
    1416// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1517// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1618#define paramtypes (boost::filesystem::path)
     19#define paramvalids (DummyValidator< boost::filesystem::path >())
    1720#define paramtokens ("load")
    1821#define paramdescriptions ("name of molecule file")
  • src/Actions/MoleculeAction/RotateAroundSelfByAngleAction.def

    r301723 r649aaa  
    1010class Vector;
    1111
     12#include "Parameters/Validators/DummyValidator.hpp"
     13
    1214// i.e. there is an integer with variable name Z that can be found in
    1315// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1416// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1517#define paramtypes (double)(Vector)
     18#define paramvalids (DummyValidator< double >())(DummyValidator< Vector >())
    1619#define paramtokens ("rotate-around-self")("axis")
    1720#define paramdescriptions ("rotation angle in degrees")("direction rotation of rotation axis relative to molecule's center of gravity")
  • src/Actions/MoleculeAction/RotateToPrincipalAxisSystemAction.def

    r301723 r649aaa  
    1212class MoleculeListClass;
    1313
     14#include "Parameters/Validators/DummyValidator.hpp"
     15
    1416// i.e. there is an integer with variable name Z that can be found in
    1517// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1618// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1719#define paramtypes (Vector)
     20#define paramvalids (DummyValidator< Vector >())
    1821#define paramtokens ("rotate-to-principal-axis-system")
    1922#define paramdescriptions ("vector to which to align the biggest eigenvector with")
  • src/Actions/MoleculeAction/SaveAdjacencyAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())
    1518#define paramtokens ("save-adjacency")
    1619#define paramdescriptions ("name of the adjacency file to write to")
  • src/Actions/MoleculeAction/SaveBondsAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())
    1518#define paramtokens ("save-bonds")
    1619#define paramdescriptions ("name of the bonds file to write to")
  • src/Actions/MoleculeAction/SaveSelectedMoleculesAction.def

    r301723 r649aaa  
    99
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())
    1518#define paramtokens ("save-selected-molecules")
    1619#define paramdescriptions ("file name of file")
  • src/Actions/MoleculeAction/SaveTemperatureAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())
    1518#define paramtokens ("save-temperature")
    1619#define paramdescriptions ("name of the temperature file to write to")
  • src/Actions/MoleculeAction/SuspendInWaterAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (double)
     17#define paramvalids (DummyValidator< double >())
    1518#define paramtokens ("suspend-in-water")
    1619#define paramdescriptions ("desired final density")
  • src/Actions/MoleculeAction/VerletIntegrationAction.def

    r301723 r649aaa  
    99class MoleculeListClass;
    1010
     11#include "Parameters/Validators/DummyValidator.hpp"
     12
    1113// i.e. there is an integer with variable name Z that can be found in
    1214// ValueStorage by the token "Z" -> first column: int, Z, "Z"
    1315// "undefine" if no parameters are required, use (NODEFAULT) for each (undefined) default value
    1416#define paramtypes (boost::filesystem::path)(double)(unsigned int)(bool)
     17#define paramvalids (DummyValidator< boost::filesystem::path >())(DummyValidator< double >())(DummyValidator< unsigned int >())(DummyValidator< bool >())
    1518#define paramtokens ("verlet-integration")("deltat")("MDSteps")("keep-fixed-CenterOfMass")
    1619#define paramdescriptions ("perform verlet integration of a given force file")("time step width")("number of MDSteps to integrate")("whether forces and velocities shall be corrected such that center of mass remains at rest")
Note: See TracChangeset for help on using the changeset viewer.