Compare the value of a number element to a target. More...
#include <indiCompRules.hpp>


| Public Types | |
| typedef std::variant< bool, std::string > | boolorerr_t | 
| In-band error reporting type. | |
| Public Member Functions | |
| numValRule () | |
| Default c'tor. | |
| void | target (const double &tgt) | 
| Set the target for the comparison. | |
| const double & | target () | 
| Get the target. | |
| void | tol (const double &t) | 
| Set the tolerance. | |
| const double & | tol () | 
| Get the tolerance. | |
| virtual bool | value () | 
| Get the value of this rule. | |
| void | property (pcf::IndiProperty *property) | 
| Set the property pointer. | |
| const pcf::IndiProperty * | property () | 
| Get the property pointer. | |
| void | element (const std::string &el) | 
| Set the element name. | |
| const std::string & | element () | 
| Get the element name. | |
| virtual boolorerr_t | valid () | 
| Check if this rule is valid. | |
| bool | isError (boolorerr_t rv) | 
| Check if returned value indicates an error. | |
| void | priority (const rulePriority &p) | 
| Set priority of this rule. | |
| const rulePriority & | priority () | 
| Get the rule priority. | |
| void | message (const std::string &m) | 
| Set the message. | |
| const std::string & | message () | 
| Get the message. | |
| void | comparison (const ruleComparison &c) | 
| Set the comparison for this rule. | |
| const ruleComparison & | comparison () | 
| Get the rule comparison. | |
| boolorerr_t | compTxt (const std::string &str1, const std::string &str2) | 
| Compare two strings. | |
| boolorerr_t | compSw (const pcf::IndiElement::SwitchStateType &sw1, const pcf::IndiElement::SwitchStateType &sw2) | 
| Compare two switches. | |
| boolorerr_t | compNum (const double &num1, const double &num2, const double &tol) | 
| Compare two numbers. | |
| boolorerr_t | compBool (const bool &b1, const bool &b2) | 
| Compare two booleans. | |
| Static Public Attributes | |
| static constexpr char | name [] = "numVal" | 
| Name of this rule, used by config system. | |
| Protected Attributes | |
| double | m_target {0} | 
| The target value for comparison. | |
| double | m_tol {1e-6} | 
| The tolerance for the comparison. | |
| int | m_type | 
| The property type, from pcf::IndiProperty::Type. | |
| pcf::IndiProperty * | m_property {nullptr} | 
| Pointer to the property. | |
| std::string | m_element | 
| The element name within the property. | |
| rulePriority | m_priority {rulePriority::none} | 
| The reporting priority for this rule. | |
| std::string | m_message | 
| The message used for notifications. | |
| ruleComparison | m_comparison {ruleComparison::Eq} | 
| The comparison for this rule. | |
Compare the value of a number element to a target.
Definition at line 614 of file indiCompRules.hpp.
| 
 | inherited | 
In-band error reporting type.
Definition at line 142 of file indiCompRules.hpp.
| 
 | inline | 
Default c'tor.
Definition at line 630 of file indiCompRules.hpp.
| 
 | inlineinherited | 
Get the rule comparison.
Definition at line 208 of file indiCompRules.hpp.
References indiCompRule::m_comparison.
Referenced by ruleCompRule::ruleCompRule().
| 
 | inlineinherited | 
Set the comparison for this rule.
| [in] | c | the new comparison | 
Definition at line 198 of file indiCompRules.hpp.
References indiCompRule::m_comparison.
Referenced by loadRuleConfig(), SCENARIO(), SCENARIO(), SCENARIO(), and SCENARIO().
| 
 | inlineinherited | 
Compare two booleans.
| [in] | b1 | the first bool to compare | 
| [in] | b2 | the second bool to compare | 
Definition at line 331 of file indiCompRules.hpp.
References And, Eq, indiCompRule::m_comparison, Nand, Neq, Nor, and Or.
Referenced by ruleCompRule::value().
| 
 | inlineinherited | 
Compare two numbers.
The comparison is (num1 comp num2), e.g. (num1 < num2). A tolerance is included for floating point equality.
| [in] | num1 | the first number to compare | 
| [in] | num2 | the second number to compare | 
| [in] | tol | the tolerance for the comparison | 
Definition at line 289 of file indiCompRules.hpp.
References Eq, Gt, GtEq, Lt, LtEq, indiCompRule::m_comparison, and Neq.
Referenced by value(), and elCompNumRule::value().
| 
 | inlineinherited | 
Compare two switches.
Switch comparison can only be Eq or Neq.
| [in] | sw1 | the first switch to compare | 
| [in] | sw2 | the first switch to compare | 
Definition at line 260 of file indiCompRules.hpp.
References Eq, indiCompRule::m_comparison, and Neq.
Referenced by swValRule::value(), and elCompSwRule::value().
| 
 | inlineinherited | 
Compare two strings.
String comparison can only be Eq or Neq.
| [in] | str1 | the first string to compare | 
| [in] | str2 | the second string to compare | 
Definition at line 232 of file indiCompRules.hpp.
References Eq, indiCompRule::m_comparison, and Neq.
Referenced by txtValRule::value(), and elCompTxtRule::value().
| 
 | inlineinherited | 
Get the element name.
Definition at line 425 of file indiCompRules.hpp.
References onePropRule::m_element.
| 
 | inlineinherited | 
Set the element name.
| [in] | el | the new element name | 
Definition at line 416 of file indiCompRules.hpp.
References onePropRule::m_element.
Referenced by loadRuleConfig(), SCENARIO(), SCENARIO(), and SCENARIO().
| 
 | inlineinherited | 
Check if returned value indicates an error.
| [in] | rv | the return value to check | 
Definition at line 145 of file indiCompRules.hpp.
Referenced by ruleCompRule::valid(), value(), txtValRule::value(), swValRule::value(), elCompNumRule::value(), elCompTxtRule::value(), elCompSwRule::value(), and ruleCompRule::value().
| 
 | inlineinherited | 
Get the message.
Definition at line 192 of file indiCompRules.hpp.
References indiCompRule::m_message.
| 
 | inlineinherited | 
Set the message.
| [in] | m | the new message | 
Definition at line 183 of file indiCompRules.hpp.
References indiCompRule::m_message.
Referenced by loadRuleConfig().
| 
 | inlineinherited | 
Get the rule priority.
Definition at line 177 of file indiCompRules.hpp.
References indiCompRule::m_priority.
| 
 | inlineinherited | 
Set priority of this rule.
| [in] | p | the new priority | 
Definition at line 168 of file indiCompRules.hpp.
References indiCompRule::m_priority.
Referenced by loadRuleConfig().
| 
 | inlineinherited | 
Get the property pointer.
Definition at line 410 of file indiCompRules.hpp.
References onePropRule::m_property.
Referenced by onePropRule::property().
| 
 | inlineinherited | 
Set the property pointer.
| mx::err::invalidarg | if propertyis nullptr | 
| mx::err::invalidconfig | if the supplied property has the wrong type | 
| [in] | property | the new property pointer | 
Definition at line 391 of file indiCompRules.hpp.
References onePropRule::m_property, onePropRule::m_type, and onePropRule::property().
Referenced by loadRuleConfig(), SCENARIO(), SCENARIO(), and SCENARIO().
| 
 | inline | 
Get the target.
Definition at line 643 of file indiCompRules.hpp.
References m_target.
| 
 | inline | 
Set the target for the comparison.
| [in] | tgt | The new target | 
Definition at line 634 of file indiCompRules.hpp.
References m_target.
Referenced by loadRuleConfig(), and SCENARIO().
| 
 | inline | 
Get the tolerance.
Definition at line 668 of file indiCompRules.hpp.
References m_tol.
| 
 | inline | 
Set the tolerance.
This is used for equality comparison to allow for floating point precision and text conversions in INDI. Set to 0 for strict comparison.
| mx::err:invalidarg | if the new value is negative | 
| [in] | t | the new tolerance | 
Definition at line 654 of file indiCompRules.hpp.
References m_tol.
Referenced by loadRuleConfig(), and SCENARIO().
| 
 | inlinevirtualinherited | 
Check if this rule is valid.
The rule is valid if the property pointer is not null, and the element is contained within the property.
If not valid, the return value is a std::string with the reason. If valid, the return value is a bool set to true.
Implements indiCompRule.
Definition at line 437 of file indiCompRules.hpp.
References onePropRule::m_element, and onePropRule::m_property.
Referenced by value(), txtValRule::value(), and swValRule::value().
| 
 | inlinevirtual | 
Get the value of this rule.
First checks if the rule is currently valid. The performs the comparison and returns the result.
| mx::err::invalidconfig | if the rule is not currently valid | 
| mx::err::invalidconfig | on an error from the comparison | 
Implements indiCompRule.
Definition at line 682 of file indiCompRules.hpp.
References indiCompRule::compNum(), indiCompRule::isError(), onePropRule::m_element, m_target, m_tol, and onePropRule::valid().
Referenced by audibleAlerts.personality.Operation::__str__(), audibleAlerts.personality.Transition::compare(), and SCENARIO().
| 
 | protectedinherited | 
The comparison for this rule.
Definition at line 159 of file indiCompRules.hpp.
Referenced by indiCompRule::comparison(), indiCompRule::comparison(), indiCompRule::compBool(), indiCompRule::compNum(), indiCompRule::compSw(), and indiCompRule::compTxt().
| 
 | protectedinherited | 
The element name within the property.
Definition at line 375 of file indiCompRules.hpp.
Referenced by onePropRule::element(), onePropRule::element(), onePropRule::valid(), value(), txtValRule::value(), and swValRule::value().
| 
 | protectedinherited | 
The message used for notifications.
Definition at line 156 of file indiCompRules.hpp.
Referenced by indiCompRule::message(), and indiCompRule::message().
| 
 | protectedinherited | 
The reporting priority for this rule.
Definition at line 153 of file indiCompRules.hpp.
Referenced by indiCompRule::priority(), and indiCompRule::priority().
| 
 | protectedinherited | 
Pointer to the property.
Definition at line 373 of file indiCompRules.hpp.
Referenced by onePropRule::property(), onePropRule::property(), onePropRule::valid(), txtValRule::value(), and swValRule::value().
| 
 | protected | 
The target value for comparison.
Definition at line 624 of file indiCompRules.hpp.
| 
 | protected | 
The tolerance for the comparison.
Definition at line 625 of file indiCompRules.hpp.
| 
 | protectedinherited | 
The property type, from pcf::IndiProperty::Type.
Definition at line 371 of file indiCompRules.hpp.
Referenced by onePropRule::property().
| 
 | staticconstexpr | 
Name of this rule, used by config system.
Definition at line 620 of file indiCompRules.hpp.
Referenced by loadRuleConfig().