ESPHome 2026.1.0-dev
Loading...
Searching...
No Matches
logger_host.cpp
Go to the documentation of this file.
1#if defined(USE_HOST)
2#include "logger.h"
3
4namespace esphome::logger {
5
6void HOT Logger::write_msg_(const char *msg, size_t len) {
7 static constexpr size_t TIMESTAMP_LEN = 10; // "[HH:MM:SS]"
8 // tx_buffer_size_ defaults to 512, so 768 covers default + headroom
9 char buffer[TIMESTAMP_LEN + 768];
10
11 time_t rawtime;
12 time(&rawtime);
13 struct tm *timeinfo = localtime(&rawtime);
14 size_t pos = strftime(buffer, TIMESTAMP_LEN + 1, "[%H:%M:%S]", timeinfo);
15
16 // Copy message (with newline already included by caller)
17 size_t copy_len = std::min(len, sizeof(buffer) - pos);
18 memcpy(buffer + pos, msg, copy_len);
19 pos += copy_len;
20
21 // Single write for everything
22 fwrite(buffer, 1, pos, stdout);
23}
24
25void Logger::pre_setup() { global_logger = this; }
26
27} // namespace esphome::logger
28
29#endif
void pre_setup()
Set up this component.
void write_msg_(const char *msg, size_t len)
Logger * global_logger
Definition logger.cpp:297
std::string size_t len
Definition helpers.h:533