Logging to the console

Previous: Managing the lifecycle of components

The simplest way to learn about the logging system in BSW based projects is to look at a working example.

Search the code for occurrences of these macros…

  • DECLARE_LOGGER_COMPONENT

  • DEFINE_LOGGER_COMPONENT

  • LOGGER_COMPONENT_MAPPING_INFO

You will find that DECLARE_LOGGER_COMPONENT is used in header files to declare a logging component (providing an extern reference to it) and these header files are included in any code with log messages that use that logging component. You will find that DEFINE_LOGGER_COMPONENT is defined once per logging component in a .cpp file to instantiate the logging component.

eg. libs/bsw/cpp2can/include/can/CanLogger.h contains…

#include "util/logger/Logger.h"

DECLARE_LOGGER_COMPONENT(CAN)

and libs/bsw/cpp2can/src/can/CanLogger.cpp contains…

#include "can/CanLogger.h"

DEFINE_LOGGER_COMPONENT(CAN)

With these in place, log messages can use the CAN logging component at different output levels. For example, platforms/posix/main/src/systems/CanSystem.cpp contains…

using ::util::logger::CAN;
using ::util::logger::Logger;

void CanSystem::canFrameSent(::can::CANFrame const& frame)
{
    Logger::info(
        CAN,
        "[CanSystem] CAN frame sent, id=0x%X, length=%d",
        (int)frame.getId(),
        (int)frame.getPayloadLength());
}

The macro LOGGER_COMPONENT_MAPPING_INFO is used to set up a table containing info such as the default levels for each logging component. In this project, executables/referenceApp/application/src/logger/logger.cpp contains…

START_LOGGER_COMPONENT_MAPPING_INFO_TABLE(loggerComponentInfoTable)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, BSP, ::util::format::Color::DEFAULT_COLOR)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, COMMON, ::util::format::Color::DEFAULT_COLOR)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, DEMO, ::util::format::Color::DEFAULT_COLOR)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, GLOBAL, ::util::format::Color::DEFAULT_COLOR)
/* start: adding logger components */
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, LIFECYCLE, ::util::format::Color::DARK_GRAY)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, CONSOLE, ::util::format::Color::DEFAULT_COLOR)
#ifdef PLATFORM_SUPPORT_CAN
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, CAN, ::util::format::Color::LIGHT_BLUE)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, DOCAN, ::util::format::Color::LIGHT_GRAY)
#endif // PLATFORM_SUPPORT_CAN
#ifdef PLATFORM_SUPPORT_UDS
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, UDS, ::util::format::Color::LIGHT_YELLOW)
LOGGER_COMPONENT_MAPPING_INFO(_DEBUG, TPROUTER, ::util::format::Color::LIGHT_YELLOW)
#endif // PLATFORM_SUPPORT_UDS
/* end: adding logger components */
END_LOGGER_COMPONENT_MAPPING_INFO_TABLE();

To learn more, you can try changing the default logging levels for components to see how this effects logging output, or you could add your own logging component. See util::logger for more information.

Next: Adding commands to the console