Ignore:
Timestamp:
Nov 19, 2012, 10:27:51 AM (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, Candidate_v1.7.0, 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:
d5307b
Parents:
286a967 (diff), 315351 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'michi-list-query-validator' into stable

Location:
src/Parameters/Validators
Files:
6 added
9 edited

Legend:

Unmodified
Added
Removed
  • src/Parameters/Validators/DiscreteValidator.hpp

    r286a967 rd61161  
    4242
    4343  void appendValidValue(const T &_value) throw(ParameterValidatorException);
    44   const std::vector<T> &getValidValues() const;
     44  virtual const std::vector<T> &getValidValues() const;
    4545
    4646private:
  • src/Parameters/Validators/Ops_Validator_impl.hpp

    r286a967 rd61161  
    4949    return false;
    5050  }
     51
     52  Validator<T> *getA(){ return a; }
     53  Validator<T> *getB(){ return b; }
    5154
    5255private:
  • src/Parameters/Validators/STLVectorValidator.hpp

    r286a967 rd61161  
    122122  }
    123123
     124  Validator<value_type> *getElementwiseValidator(){ return ElementwiseValidator;  }
     125  Validator<size_t> *getNumberOfElementsValidator(){  return NumberOfElementsValidator; }
     126
    124127private:
    125128  /** Constructor for class STLVectorValidator, number of elements given by \ref RangeValidator.
  • src/Parameters/Validators/Specific/BoundaryConditionValidator.cpp

    r286a967 rd61161  
    4141#include "Box_BoundaryConditions.hpp"
    4242
     43BoundaryConditionValidator::BoundaryConditionValidator() :
     44  DiscreteValidator<std::string>(std::vector<std::string>())
     45{}
     46
    4347bool BoundaryConditionValidator::isValid(const std::string & _value) const
    4448{
    4549  BoundaryConditions::BCContainer bc;
    4650  return (bc.ReConverterBiMap.find(_value) != bc.ReConverterBiMap.end());
     51}
     52
     53const std::vector<std::string> &BoundaryConditionValidator::getValidValues() const
     54{
     55  BoundaryConditions::BCContainer bc;
     56  currentList.clear();
     57  for (BoundaryConditions::BCContainer::StringToEnumMap::iterator iter = bc.ReConverterBiMap.begin();
     58    iter != bc.ReConverterBiMap.end();
     59    iter ++)
     60    currentList.push_back(iter->first);
     61  return currentList;
    4762}
    4863
  • src/Parameters/Validators/Specific/BoundaryConditionValidator.hpp

    r286a967 rd61161  
    1717#include <string>
    1818
    19 #include "Parameters/Validators/Validator.hpp"
     19#include "Parameters/Validators/DiscreteValidator.hpp"
    2020
    2121/** This validator checks whether the given string is one keyword of a box
    2222 * condition.
    2323 */
    24 class BoundaryConditionValidator : public Validator<std::string>
     24class BoundaryConditionValidator : public DiscreteValidator<std::string>
    2525{
     26public:
     27  BoundaryConditionValidator();
    2628  bool isValid(const std::string & _value) const;
     29  const std::vector<std::string> &getValidValues() const;
    2730  bool operator==(const Validator<std::string> &_instance) const;
    2831  Validator< std::string >* clone() const;
     32private:
     33  mutable std::vector<std::string> currentList;
    2934};
    3035
  • src/Parameters/Validators/Specific/ParserTypeValidator.cpp

    r286a967 rd61161  
    3939
    4040#include "Parser/FormatParserStorage.hpp"
     41#include "Parser/ParserTypes.hpp"
    4142
    42 bool ParserTypeValidator::isValid(const std::string & _value) const
     43ParserTypeValidator::ParserTypeValidator() :
     44DiscreteValidator<std::string>(std::vector<std::string>())
    4345{
    44   return (FormatParserStorage::getInstance().getTypeFromName(_value) != ParserTypes_end);
    45 }
    46 
    47 bool ParserTypeValidator::operator==(const Validator<std::string> &_instance) const
    48 {
    49   const ParserTypeValidator *inst =
    50       dynamic_cast<const ParserTypeValidator *>(&_instance);
    51   if (inst)
    52     return true;
    53   else
    54     return false;
    55 }
    56 
    57 Validator< std::string >* ParserTypeValidator::clone() const
    58 {
    59   Validator< std::string > *inst =
    60       new ParserTypeValidator();
    61   return inst;
     46  for (ParserTypes t = ParserTypes_begin; t != ParserTypes_end; ++ t)
     47    appendValidValue(FormatParserStorage::getInstance().getNameFromType(t));
    6248}
    6349
  • src/Parameters/Validators/Specific/ParserTypeValidator.hpp

    r286a967 rd61161  
    1717#include <string>
    1818
    19 #include "Parameters/Validators/Validator.hpp"
     19#include "Parameters/Validators/DiscreteValidator.hpp"
    2020
    2121/** This validator checks whether the given string refers to a valid
    2222 * \ref FormatParser type.
    2323 */
    24 class ParserTypeValidator : public Validator<std::string>
     24class ParserTypeValidator : public DiscreteValidator<std::string>
    2525{
    26   bool isValid(const std::string & _value) const;
    27   bool operator==(const Validator<std::string> &_instance) const;
    28   Validator< std::string >* clone() const;
     26public:
     27  ParserTypeValidator();
    2928};
    3029
  • src/Parameters/Validators/Specific/RandomNumberValidators.cpp

    r286a967 rd61161  
    4141#include "RandomNumbers/RandomNumberEngineFactory.hpp"
    4242
     43RandomNumberDistributionNameValidator::RandomNumberDistributionNameValidator() :
     44  DiscreteValidator<std::string>(std::vector<std::string>())
     45{}
     46
    4347bool RandomNumberDistributionNameValidator::isValid(const std::string & _value) const
    4448{
     
    5256  }
    5357  return false;
     58}
     59
     60const std::vector<std::string> &RandomNumberDistributionNameValidator::getValidValues() const
     61{
     62  currentList.clear();
     63  RandomNumberDistributionFactory::getInstance();
     64  for (RandomNumberDistributionFactory::NameMap::const_iterator
     65      iter = RandomNumberDistributionFactory::getInstance().names.begin();
     66      iter != RandomNumberDistributionFactory::getInstance().names.end();
     67      ++iter)
     68    currentList.push_back(iter->second);
     69  return currentList;
    5470}
    5571
     
    7995
    8096
     97RandomNumberEngineNameValidator::RandomNumberEngineNameValidator() :
     98  DiscreteValidator<std::string>(std::vector<std::string>())
     99{}
     100
    81101bool RandomNumberEngineNameValidator::isValid(const std::string & _value) const
    82102{
     
    90110  }
    91111  return false;
     112}
     113
     114const std::vector<std::string> &RandomNumberEngineNameValidator::getValidValues() const
     115{
     116  currentList.clear();
     117  RandomNumberEngineFactory::getInstance();
     118  for (RandomNumberEngineFactory::NameMap::const_iterator
     119      iter = RandomNumberEngineFactory::getInstance().names.begin();
     120      iter != RandomNumberEngineFactory::getInstance().names.end();
     121      ++iter)
     122    currentList.push_back(iter->second);
     123  return currentList;
    92124}
    93125
  • src/Parameters/Validators/Specific/RandomNumberValidators.hpp

    r286a967 rd61161  
    1717#include <string>
    1818
    19 #include "Parameters/Validators/Validator.hpp"
     19#include "Parameters/Validators/DiscreteValidator.hpp"
    2020
    2121/** This validator checks whether the given string contains the name of a
    2222 * present \ref RandomNumberDistribution.
    2323 */
    24 class RandomNumberDistributionNameValidator : public Validator<std::string>
     24class RandomNumberDistributionNameValidator : public DiscreteValidator<std::string>
    2525{
     26public:
     27  RandomNumberDistributionNameValidator();
    2628  bool isValid(const std::string & _value) const;
     29  const std::vector<std::string> &getValidValues() const;
    2730  bool operator==(const Validator<std::string> &_instance) const;
    2831  Validator< std::string >* clone() const;
     32private:
     33  mutable std::vector<std::string> currentList;
    2934};
    3035
     
    3237 * present \ref RandomNumberEngine.
    3338 */
    34 class RandomNumberEngineNameValidator : public Validator<std::string>
     39class RandomNumberEngineNameValidator : public DiscreteValidator<std::string>
    3540{
     41public:
     42  RandomNumberEngineNameValidator();
    3643  bool isValid(const std::string & _value) const;
     44  const std::vector<std::string> &getValidValues() const;
    3745  bool operator==(const Validator<std::string> &_instance) const;
    3846  Validator< std::string >* clone() const;
     47private:
     48  mutable std::vector<std::string> currentList;
    3949};
    4050
Note: See TracChangeset for help on using the changeset viewer.