LogMessage#
Fully qualified name: carb::logging::LogMessage
Defined in carb/logging/Logger.h
- 
struct LogMessage#
- A structure defining a log message as passed to Logger2::handleMessage(). - See also - Public Members - 
size_t sizeOf = {sizeof(LogMessage)}#
- The size of the - LogMessagestructure, used as a version.- To verify if a desired field is included, do this check: - msg.sizeOf >= (offsetof(LogMessage, <field>) + sizeof(LogMessage::<field>))- Warning - Only access fields that fit fully within the - sizeOf! Fields up to and including- messageare always valid.
 - 
const char *source#
- The source of the log message in UTF-8 encoding. Commonly this is the plugin name that generated the message, or the channel name. Will not be NULL. 
 - 
const char *fileName#
- The source code file name that generated the log message. May be NULL if not available. 
 - 
int lineNumber#
- The line number in - fileNamewhere the log message was generated from. Will be 0 if not available.
 - 
int32_t level#
- The log severity level of the message. - See also 
 - 
const char *moduleName#
- The name of the module which generated the log message. May be NULL if not available. 
 - 
const char *functionName#
- The name of the function which generated the log message. May be NULL if not available. 
 - 
const char *traceParentId#
- The current traceparent ID for the thread that generated the message, or an empty string if no trace is active on the calling thread or OmniTrace is not enabled. Will not be NULL. 
 - 
std::chrono::nanoseconds timestampNs#
- The log timestamp in nanoseconds based on std::chrono::steady_clock. This value will not be relative to any specific epoch and should only be used for relative time deltas or comparisons. This timestamp will generally be relative to system boot time, but even that is not guaranteed. Note that this value is not subject to periodic system time updates and will be a monotonically increasing timer. 
 - 
const char *message#
- The log message in UTF-8 encoding. Will not be NULL. 
 - 
const char *globalExtraFields#
- A string containing the current global extra fields for this log message. This may be an empty string if no extra fields have been specified. - Warning - This field must be checked if it is safe to access in the passed version of a log message struct using a call to - CARB_INCLUDES_MEMBER(msg.sizeOf, carb::logging::LogMessage::globalExtraFields)before attempting to access this member.
 - 
const char *threadExtraFields#
- A string containing the current thread extra fields for this log message. This may be an empty string if no thread specific extra fields have been specified. - Warning - This field must be checked if it is safe to access in the passed version of a log message struct using a call to - CARB_INCLUDES_MEMBER(msg.sizeOf, carb::logging::LogMessage::threadExtraFields)before attempting to access this member.
 - 
std::chrono::nanoseconds timestampNsSinceUnixEpoch#
- The number of nanoseconds since the Unix epoch (midnight January 1, 1970). This value will be the system wall clock time since that epoch and will therefore be subject to periodic system wall clock time updates. This may result in timestamps either jumping forward or backward in time, usually by small amounts, from time to time. This timestamp will always be given in UTC and will need to be converted to a local time if needed for display or processing. - This value in combination with timestampNs can also be used to calculate a monotonic absolute timestamp with the two parameter version fo the carb::time::getMonotonicNanosecondsSinceUnixEpoch() helper function (include “carb/time/Util.h”). This calculated value will be an approximate absolute timestamp in nanoseconds since the Unix epoch (midnight January 1, 1970). It is the log consumer’s responsibility to calculate this value if needed. 
 
- 
size_t sizeOf = {sizeof(LogMessage)}#