text_logging.h File Reference

Detailed Description

This is the entry point for all text logging within Drake.

Once you've included this file, the suggested ways you should write log messages include:

  drake::log()->trace("Some trace message: {} {}", something, some_other);

Similarly, it provides:


If you want to log objects that are expensive to serialize, these macros will not be compiled if debugging is turned off (-DNDEBUG is set):

  DRAKE_LOGGER_TRACE("message: {}", something_conditionally_compiled);
  DRAKE_LOGGER_DEBUG("message: {}", something_conditionally_compiled);

The format string syntax is fmtlib; see https://fmt.dev/latest/syntax.html. In particular, any class that overloads operator<< for ostream can be printed without any special handling. (Note that the documentation link provides syntax for the latest version of fmtlib; the version of fmtlib used by Drake might be older.)

#include <string>
#include "drake/common/drake_copyable.h"
Include dependency graph for text_logging.h:
This graph shows which files directly or indirectly include this file:


struct  Warn
 When constructed, logs a message (at "warn" severity); the destructor is guaranteed to be trivial. More...




using logger = spdlog::logger
 The drake::logging::logger class provides text logging methods. More...


logging::logger * log ()
 Retrieve an instance of a logger to use for logging; for example: More...
sink * get_dist_sink ()
 (Advanced) Retrieves the default sink for all Drake logs. More...
std::string set_log_level (const std::string &level)
 Invokes drake::log()->set_level(level). More...


constexpr bool kHaveSpdlog = true
 True only if spdlog is enabled in this build. More...
const char *const kSetLogLevelUnchanged
 The "unchanged" string to pass to set_log_level() so as to achieve a no-op. More...
const char *const kSetLogLevelHelpMessage
 An end-user help string suitable to describe the effects of set_log_level(). More...