#include <ball_ruleset.h>
This class manages a set of unique rule values. Rules may be added to or removed from the set; however, rules having duplicate values will not be added. For the definition of two rules having the same value, please refer to the function-level documentation associated with the Rule::operator==
function.
See ball_ruleset
◆ MaskType
MaskType
is an alias for the fundamental integral type used to indicate rule subsets compactly.
◆ anonymous enum
Enumerator |
---|
e_MAX_NUM_RULES | |
BAEL_MAX_NUM_RULES | |
MAX_NUM_RULES | |
◆ RuleSet() [1/2]
Create an empty rule set. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is 0, the currently installed default allocator will be used.
◆ RuleSet() [2/2]
Create a RuleSet
object having the same value as that of the specified original
object. Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is 0, the currently installed default allocator will be used.
◆ ~RuleSet()
ball::RuleSet::~RuleSet |
( |
| ) |
|
|
default |
◆ addRule()
int ball::RuleSet::addRule |
( |
const Rule & |
value | ) |
|
Create a new Rule
object having the specified value
. Return the non-negative id of this non-modifiable object on success, and a negative value otherwise. A return value of -1 indicates that another rule having this value already exists. A return value of -2 indicates that the maximum number of rules for this rule set has been reached.
◆ addRules()
int ball::RuleSet::addRules |
( |
const RuleSet & |
rules | ) |
|
Add each rule in the specified rules
to this rule set. Return the number of rules added. Note that a rule in rules
will be ignored if there is an existing rule having the same value or if the number of rules in the set has reached the upper limit. Also note that if not all valid rules will fit, the (possibly empty) subset of unique values that will be added is implementation dependent.
◆ BSLMF_NESTED_TRAIT_DECLARATION()
◆ getRuleById()
const Rule * ball::RuleSet::getRuleById |
( |
int |
id | ) |
const |
|
inline |
Return the address of the rule having the specified id
if such a rule exists, and 0 otherwise. The behavior is undefined unless 0 <= id < maxNumRules()
. Note that rules may be assigned non-sequential identifiers, and that there may be a valid rule whose identifier is greater than numRules()
(i.e., valid rules may appear anywhere in the range 0 <= id < maxNumRules()
).
◆ maxNumRules()
int ball::RuleSet::maxNumRules |
( |
| ) |
|
|
inlinestatic |
Return the maximum number of rules that can be simultaneously maintained by this object.
◆ numPredicates()
int ball::RuleSet::numPredicates |
( |
| ) |
const |
|
inline |
Return the total number of predicates in all rules maintained by this object.
◆ numRules()
int ball::RuleSet::numRules |
( |
| ) |
const |
|
inline |
Return the number of unique rules maintained in this RuleSet
object. Note that this value is not the maximum identifier for the rules currently in this container.
◆ operator=()
◆ print()
bsl::ostream & ball::RuleSet::print |
( |
bsl::ostream & |
stream, |
|
|
int |
level = 0 , |
|
|
int |
spacesPerLevel = 4 |
|
) |
| const |
Format this object to the specified output stream
at the (absolute value of) the optionally specified indentation level
and return a reference to stream
. If level
is specified, optionally specify spacesPerLevel
, the number of spaces per indentation level for this and all of its nested objects. If level
is negative, suppress indentation of the first line. If spacesPerLevel
is negative, format the entire output on one line, suppressing all but the initial indentation (as governed by level
). If stream
is not valid on entry, this operation has no effect.
◆ printMask()
static void ball::RuleSet::printMask |
( |
bsl::ostream & |
stream, |
|
|
MaskType |
mask, |
|
|
int |
level = 0 , |
|
|
int |
spacesPerLevel = 0 |
|
) |
| |
|
static |
Format the specified mask
to the specified output stream
at the optionally specified indentation level
and return a reference to the modifiable stream
. If level
is specified, optionally specify spacesPerLevel
, the number of spaces per indentation level for this and all of its nested objects. Each line is indented by the absolute value of level * spacesPerLevel
. If level
is negative, suppress indentation of the first line. If spacesPerLevel
is negative, suppress line breaks and format the entire output on one line. If stream
is initially invalid, this operation has no effect.
◆ removeAllRules()
void ball::RuleSet::removeAllRules |
( |
| ) |
|
◆ removeRule()
int ball::RuleSet::removeRule |
( |
const Rule & |
value | ) |
|
Remove the rule having the specified value
from this rule set. Return the number of rules removed (i.e., 1 on success and 0 if there is no such a rule).
◆ removeRuleById()
int ball::RuleSet::removeRuleById |
( |
int |
id | ) |
|
Remove from this rule set the rule having the specified id
. Return the number of rules removed (i.e., 1 on success and 0 if there is no rule whose id is id
). The behavior is undefined unless 0 <= id < e_MAX_NUM_RULES
.
◆ removeRules()
int ball::RuleSet::removeRules |
( |
const RuleSet & |
rules | ) |
|
Remove each rule in the specified rules
from this rule set. Return the number of rules removed.
◆ ruleId()
int ball::RuleSet::ruleId |
( |
const Rule & |
value | ) |
const |
Return the id of the rule having the specified value
if such a rule exists, and a negative value otherwise. Note that if there are multiple rules having value
, the id of the first one found will be returned and the order in which rules are searched is implementation dependent.
◆ operator!=
Return true
if the specified lhs
and rhs
rule sets do not have the same value, and false
otherwise. Two rule sets do not have the same value if there is at least one rule that exists in one rule but does not exist in the other.
◆ operator<<
bsl::ostream & operator<< |
( |
bsl::ostream & |
, |
|
|
const RuleSet & |
|
|
) |
| |
|
friend |
Write the value of the specified rules
to the specified output
stream. Return the specified output
stream
◆ operator==
Return true
if the specified lhs
and rhs
rule sets have the same value, and false
otherwise. Two rule sets have the same value if every rule that exists in one rule set also exists in the other.
The documentation for this class was generated from the following file: