source: src/Parameters/Validators/RangeValidator.hpp@ aa91de0

Action_Thermostats Add_AtomRandomPerturbation Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph_documentation Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph Fix_ChronosMutex Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids_IntegrationTest JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes
Last change on this file since aa91de0 was 87d6bd, checked in by Frederik Heber <heber@…>, 12 years ago

FIX: Fixing several clang errors such that we may safely use the compiler.

Changes:

  • clang does not like execeptions as pure forward declarations.
  • clang does not like AtomTypes[MaxTypes] with MaxTypes being dynamic.
  • clang does not like cppunit to have no operator<<() for std::sets (it though finds the ones for std::vector?), it cannot use one from toString.hpp as it is declared afterwards (although before instantiation site).
  • clang does not tolerate inheriting from a protected member class TQuery.
  • clang does not tolerate shadowing of a variable inside a for-loop (i.e. declaring variable in loop body with same name as e.g. loop variable).
  • clang compilation ran through after these changes without a single failing test.
  • Property mode set to 100644
File size: 1.1 KB
RevLine 
[a696f9]1/*
2 * RangeValidator.hpp
3 *
4 * Created on: Apr 13, 2012
5 * Author: ankele
6 */
7
8#ifndef RANGEVALIDATOR_HPP_
9#define RANGEVALIDATOR_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
[a9a8f9]17#include "Validator.hpp"
[a696f9]18#include "CodePatterns/Range.hpp"
19
[87d6bd]20#include "Parameters/ParameterExceptions.hpp"
21
[e45c1d]22
[a696f9]23/** A validator with an interval of valid values.
24 *
25 */
26template <class T>
[a9a8f9]27class RangeValidator : public Validator<T>
[a696f9]28{
29public:
[4892c3]30 RangeValidator(const range<T> &_ValidRange) : ValidRange(_ValidRange) {};
[e5d7970]31 RangeValidator(const T&min, const T&max) : ValidRange(min,max) {};
[a696f9]32 virtual ~RangeValidator() {};
33
[3c5ef5]34 bool isValid(const T & _value) const;
35
36 Validator<T>* clone() const;
[a9a8f9]37
[8f130c]38 // comparator
[3c5ef5]39 bool operator==(const Validator<T> &_instance) const;
40
41 // getter/setter for valid ranges
[e45c1d]42 void setValidRange(const range<T> &_range) throw(ParameterValueException);
[3c5ef5]43 const range<T> & getValidRange() const { return ValidRange; };
[8f130c]44
[a696f9]45private:
46 //!> valid range of values
47 range<T> ValidRange;
48};
49
50
[3c5ef5]51#include "RangeValidator_impl.hpp"
52
[a696f9]53
54#endif /* RANGEVALIDATOR_HPP_ */
Note: See TracBrowser for help on using the repository browser.