#include <balm_metricdescription.h>
This class provides a mechanism for describing a metric. A MetricDescription holds the category to which the metric belongs, and a null-terminated string containing the name of the metric.
See balm_metricdescription
◆ UserDataKey
A key used to refer to a data value associated with a metric. Note that a UserDataKey can be used by clients of balm to associate additional information with a metric. See balm_metricregistry for information on obtaining a unique key.
◆ MetricDescription()
| balm::MetricDescription::MetricDescription |
( |
const Category * |
category, |
|
|
const char * |
name, |
|
|
bslma::Allocator * |
basicAllocator = 0 |
|
) |
| |
|
inline |
Create a metric description for the specified category and the specified name. Optionally specify a basicAllocator used to supply memory. If basicAllocator is 0, the currently installed default allocator is used. The initial value for preferredPublicationType is e_UNSPECIFIED, and the initial value for format is 0. The behavior is undefined unless name and category remain valid, and the contents of name remain unmodified, for the lifetime of this object.
◆ ~MetricDescription()
| balm::MetricDescription::~MetricDescription |
( |
| ) |
|
|
default |
◆ category()
| const Category * balm::MetricDescription::category |
( |
| ) |
const |
|
inline |
Return the address of the non-modifiable category object indicating the category of the metric described by this object.
◆ format()
Return a shared pointer to the non-modifiable format for this metric description. Note that the returned shared pointer may be null if a format has not been provided for the described metric.
◆ name()
| const char * balm::MetricDescription::name |
( |
| ) |
const |
|
inline |
Return the address of the non-modifiable, null-terminated string containing the name of the described metric.
◆ preferredPublicationType()
Return the preferred publication type of this metric. The preferred publication type of this metric indicates the preferred aggregate to publish for this metric, or PublicationType::UNSPECIFIED if there is no preference. Note that there is no uniform definition for how publishers will interpret this value; an UNSPECIFIED value generally indicates that the all the collected aggregates (total, count, minimum, and maximum value) should be published.
◆ print()
| bsl::ostream & balm::MetricDescription::print |
( |
bsl::ostream & |
stream | ) |
const |
Print the category and name of this metric description to the specified output stream in some single-line human-readable form, and return a reference to the modifiable stream.
◆ printDescription()
| bsl::ostream & balm::MetricDescription::printDescription |
( |
bsl::ostream & |
stream | ) |
const |
Print the properties of this metric description to the specified output stream in some single-line human-readable form, and return a reference to the modifiable stream.
◆ setCategory()
| void balm::MetricDescription::setCategory |
( |
const Category * |
category | ) |
|
|
inline |
Set the category of this metric description to the object at the specified category address. The behavior is undefined unless category remains valid for the lifetime of this object.
◆ setFormat()
Set the format for this metric description to the specified format.
◆ setName()
| void balm::MetricDescription::setName |
( |
const char * |
name | ) |
|
|
inline |
Set the name of this metric description to the specified name. The behavior is undefined unless the contents of name remains valid and unmodified for the lifetime of this object.
◆ setPreferredPublicationType()
Set the preferred publication type of this metric to the specified type. The preferred publication type of this metric indicates the preferred aggregate to publish for this metric, or PublicationType::UNSPECIFIED if there is no preference. Note that there is no uniform definition for how publishers will interpret this value; an UNSPECIFIED value generally indicates that all the collected aggregates (total, count, minimum, and maximum value) should be published.
◆ setUserData()
| void balm::MetricDescription::setUserData |
( |
UserDataKey |
key, |
|
|
const void * |
value |
|
) |
| |
|
inline |
Associate the specified value with the specified data key. The behavior is undefined unless key >= 0. Note that this method allows clients of balm to associate (opaque) application-specific information with a metric.
◆ userData()
| const void * balm::MetricDescription::userData |
( |
UserDataKey |
key | ) |
const |
|
inline |
Return the non-modifiable value associated with the specified user-data key. If the data for key has not been set, a value of 0 is returned, which is indistinguishable from a valid key with a 0 value. The behavior is undefined unless key >= 0. Note that this method allows clients of balm to access the (opaque) application-specific information that they have previously associated with a metric (via setUserData).
The documentation for this class was generated from the following file: