BDE 4.14.0 Production release
Loading...
Searching...
No Matches
ball::Category Class Reference

#include <ball_category.h>

Public Member Functions

 BSLMF_NESTED_TRAIT_DECLARATION (Category, bslma::UsesBslmaAllocator)
 
 Category (const char *categoryName, int recordLevel, int passLevel, int triggerLevel, int triggerAllLevel, bslma::Allocator *basicAllocator=0)
 
 ~Category ()=default
 Destroy this object.
 
int setLevels (int recordLevel, int passLevel, int triggerLevel, int triggerAllLevel)
 
const char * categoryName () const
 Return the name of this category.
 
bool isEnabled (int level) const
 
int maxLevel () const
 Return the numerical maximum of the four levels of this category.
 
int recordLevel () const
 Return the record level of this category.
 
int passLevel () const
 Return the pass level of this category.
 
int triggerLevel () const
 Return the trigger level of this category.
 
int triggerAllLevel () const
 Return the trigger-all level of this category.
 
ThresholdAggregate thresholdLevels () const
 Return the aggregate threshold levels of this category.
 
int threshold () const
 
int ruleThreshold () const
 
RuleSet::MaskType relevantRuleMask () const
 

Static Public Member Functions

static bool areValidThresholdLevels (int recordLevel, int passLevel, int triggerLevel, int triggerAllLevel)
 

Friends

class CategoryManagerImpUtil
 

Detailed Description

This class provides a container to hold the name and threshold levels of a category. Instances of Category are created and manipulated by CategoryManager. All threshold levels are integral values in the range [0 .. 255].

Implementation Note: The d_ruleThreshold and d_relevantRuleMask serve as a cache for logging rule evaluation (see ball_attributecontext ). They are not meant to be modified by users of the logging system, and may be modified by const operations of the logging system.

See ball_category

Constructor & Destructor Documentation

◆ Category()

ball::Category::Category ( const char *  categoryName,
int  recordLevel,
int  passLevel,
int  triggerLevel,
int  triggerAllLevel,
bslma::Allocator basicAllocator = 0 
)

Create a category having the specified categoryName and the specified recordLevel, passLevel, triggerLevel, and triggerAllLevel threshold values, respectively. Optionally specify a basicAllocator used to supply memory. If basicAllocator is 0, the currently installed default allocator is used. The behavior is undefined unless each of the specified threshold levels is in the range [0 .. 255], and categoryName is null-terminated.

◆ ~Category()

ball::Category::~Category ( )
default

Member Function Documentation

◆ areValidThresholdLevels()

bool ball::Category::areValidThresholdLevels ( int  recordLevel,
int  passLevel,
int  triggerLevel,
int  triggerAllLevel 
)
inlinestatic

Return true if each of the specified recordLevel, passLevel, triggerLevel and triggerAllLevel threshold values are in the range [0 .. 255], and false otherwise.

◆ BSLMF_NESTED_TRAIT_DECLARATION()

ball::Category::BSLMF_NESTED_TRAIT_DECLARATION ( Category  ,
bslma::UsesBslmaAllocator   
)

◆ categoryName()

const char * ball::Category::categoryName ( ) const
inline

◆ isEnabled()

bool ball::Category::isEnabled ( int  level) const
inline

Return true if logging at the specified level is enabled for this category, and false otherwise. Logging is enabled if level is numerically less than or equal to any of the four threshold levels of this category.

◆ maxLevel()

int ball::Category::maxLevel ( ) const
inline

◆ passLevel()

int ball::Category::passLevel ( ) const
inline

◆ recordLevel()

int ball::Category::recordLevel ( ) const
inline

◆ relevantRuleMask()

RuleSet::MaskType ball::Category::relevantRuleMask ( ) const
inline

Return a reference to the non-modifiable relevant rule mask for this category. The returned RuleSet::MaskType value is a bit-mask, where each bit is a boolean value indicating whether the rule at the corresponding index (in the rule set of the category manager that owns this category) applies at this category. Note that a rule applies to this category if the rule's pattern matches the name returned by categoryName.

◆ ruleThreshold()

int ball::Category::ruleThreshold ( ) const
inline

Return the current maximum threshold (i.e., the lowest severity) for any logging rule associated with this category. Note that the rule having this threshold may not be active given the current thread's logging context (see ball::AttributeContext); this value caches the lowest possible severity where the currently rules need to be evaluated (log records below this threshold do not need any rule evaluation).

◆ setLevels()

int ball::Category::setLevels ( int  recordLevel,
int  passLevel,
int  triggerLevel,
int  triggerAllLevel 
)

Set the threshold levels of this category to the specified recordLevel, passLevel, triggerLevel, and triggerAllLevel values, respectively, if each of the specified values is in the range [0 .. 255]. Return 0 on success, and a non-zero value otherwise (with no effect on the threshold levels of this category).

◆ threshold()

int ball::Category::threshold ( ) const
inline

Return the current maximum threshold (i.e., the lowest severity) between the recordLevel, passLevel, triggerLevel, and triggerAllLevel. Note that this is the threshold at which a log record having this severity will need to be acted upon.

◆ thresholdLevels()

ThresholdAggregate ball::Category::thresholdLevels ( ) const
inline

◆ triggerAllLevel()

int ball::Category::triggerAllLevel ( ) const
inline

◆ triggerLevel()

int ball::Category::triggerLevel ( ) const
inline

Friends And Related Symbol Documentation

◆ CategoryManagerImpUtil

friend class CategoryManagerImpUtil
friend

The documentation for this class was generated from the following file: