/* * ContinuousValue_impl.hpp * * Created on: Sep 29, 2011 * Author: heber */ #ifndef CONTINUOUSVALUE_IMPL_HPP_ #define CONTINUOUSVALUE_IMPL_HPP_ // include config.h #ifdef HAVE_CONFIG_H #include #endif #include #include #include "CodePatterns/Assert.hpp" #include "CodePatterns/Log.hpp" #include "Range.hpp" #include "ContinuousValue.hpp" /** Constructor of class DiscreteValue. */ template ContinuousValue::ContinuousValue() : ValueSet(false), ValidRangeSet(range(false, false)) {} /** Constructor of class DiscreteValue with set of valid values. * * @param _ValidValues vector with all valid values */ template ContinuousValue::ContinuousValue(const range &_ValidRange) : ValueSet(false), ValidRangeSet(range(true, true)), ValidRange(_ValidRange) { // LOG(0, "STATUS: Valid range is now " << ValidRange << "."); } /** Destructor of class DiscreteValue. */ template ContinuousValue::~ContinuousValue() {} /** Checks whether \a _value is a valid value. * \param _value value to check for validity. * \return true - \a _value is valid, false - is not */ template bool ContinuousValue::isValid(const T & _value) const { return isValidValue(_value); } /** Compares this continuous value against another \a _instance. * * @param _instance other value to compare to * @return true - if value and valid ranges are the same, false - else */ template bool ContinuousValue::operator==(const ContinuousValue &_instance) const { bool status = true; status = status && (ValidRange == _instance.ValidRange); status = status && (ValueSet == _instance.ValueSet); if (ValueSet && _instance.ValueSet) status = status && (value == _instance.value); return status; } /** Getter of value, returning string. * * @return string value */ template const T & ContinuousValue::get() const { ASSERT(ValueSet, "ContinuousValue::get() - requesting unset value."); return value; } /** Setter of value for string * * @param _value string containing new value */ template void ContinuousValue::set(const T & _value) { setValue(_value); // LOG(0, "STATUS: Value is now set to " << value << "."); } /** Setter for the valid range. * * If value is invalid in new range, we throw AssertFailure and set ValueSet to false. * * @param _range range (pair of values) */ template void ContinuousValue::setValidRange(const range &_range) { ValidRangeSet = range(true, true); ValidRange = _range; if (ValueSet) { //std::cout << "Checking whether " << value << " is in range " << ValidRange << "." << std::endl; if (!((ValidRange.isInRange(value)) || (value == ValidRange.last))) { //std::cout << "ValueSet to false." << std::endl; ValueSet = false; // have full check again in assert such that it appears in output, too ASSERT(ValidRange.isInRange(value) || (value == ValidRange.last), "ContinuousValue::setValidRange() - new range " +toString(_range)+" invalidates current value "+toString(value)+"."); } } // LOG(0, "STATUS: Valid range is now " << ValidRange << "."); } /** Getter for the valid range. * * @return _range range (pair of values) */ template const range & ContinuousValue::getValidRange() const { ASSERT(ValidRangeSet.first && ValidRangeSet.last, "ContinuousValue::getValidRange() called though no valid range set so far."); return ValidRange; } /** Checks whether \a _value is a valid value. * \param _value value to check for validity. * \return true - \a _value is valid, false - is not */ template bool ContinuousValue::isValidValue(const T &_value) const { bool isBefore = true; bool isBeyond = true; // check left boundary isBefore = !((!ValidRangeSet.first) || (!ValidRange.isBefore(_value))); // if (isBefore) // LOG(0, "INFO: " << _value << " is before " << ValidRange.first << "."); // check right boundary isBeyond = !((!ValidRangeSet.last) || (!ValidRange.isBeyond(_value)) || (_value == ValidRange.last)); // if (isBeyond) // LOG(0, "INFO: " << _value << " is beyond " << ValidRange.last << "."); return (!isBefore) && (!isBeyond); } /** Sets the value. * * We check for its validity, otherwise we throw an Assert::AssertionFailure. * * @param _value const reference of value to set */ template void ContinuousValue::setValue(const T &_value) { ASSERT(isValidValue(_value), "ContinuousValue::setValue() - trying to set invalid value "+toString(_value)+"."); if (!ValueSet) ValueSet = true; value = _value; } /** Getter for the set value. * * We check whether it has been set, otherwise we throw an Assert::AssertionFailure. * * @return set value */ template const T &ContinuousValue::getValue() const { ASSERT(ValueSet, "ContinuousValue::get() - value has never been set."); return value; } #endif /* CONTINUOUSVALUE_IMPL_HPP_ */