esp-println 0.17.0

Provides `print!` and `println!` implementations for various Espressif devices
Documentation
use log_04 as log;

use super::println;

#[cfg(not(host_is_windows))]
include!(concat!(env!("OUT_DIR"), "/log_filter.rs"));

#[cfg(host_is_windows)]
include!(concat!(env!("OUT_DIR"), "\\log_filter.rs"));

/// Initialize the logger with the given maximum log level.
pub fn init_logger(level: log::LevelFilter) {
    unsafe {
        log::set_logger_racy(&EspLogger).unwrap();
        log::set_max_level_racy(level);
    }
}

/// Initialize the logger from the `ESP_LOG` environment variable.
pub fn init_logger_from_env() {
    unsafe {
        log::set_logger_racy(&EspEnvLogger).unwrap();
        log::set_max_level_racy(FILTER_MAX);
    }
}

struct EspLogger;

impl log::Log for EspLogger {
    #[allow(unused)]
    fn enabled(&self, _: &log::Metadata) -> bool {
        // Filtered by `log` already
        true
    }

    #[allow(unused)]
    fn log(&self, record: &log::Record) {
        print_log_record(record);
    }

    fn flush(&self) {}
}

struct EspEnvLogger;

impl log::Log for EspEnvLogger {
    fn enabled(&self, metadata: &log::Metadata) -> bool {
        let level = metadata.level();
        let target = metadata.target();
        is_enabled(level, target)
    }

    #[allow(unused)]
    fn log(&self, record: &log::Record) {
        if self.enabled(record.metadata()) {
            print_log_record(record);
        }
    }

    fn flush(&self) {}
}

fn print_log_record(record: &log::Record) {
    let (color, reset) = if cfg!(feature = "colors") {
        const RESET: &str = "\u{001B}[0m";
        const RED: &str = "\u{001B}[31m";
        const GREEN: &str = "\u{001B}[32m";
        const YELLOW: &str = "\u{001B}[33m";
        const BLUE: &str = "\u{001B}[34m";
        const CYAN: &str = "\u{001B}[35m";

        let color = match record.level() {
            log::Level::Error => RED,
            log::Level::Warn => YELLOW,
            log::Level::Info => GREEN,
            log::Level::Debug => BLUE,
            log::Level::Trace => CYAN,
        };
        let reset = RESET;
        (color, reset)
    } else {
        ("", "")
    };

    #[cfg(feature = "timestamp")]
    println!(
        "{}{} ({}) - {}{}",
        color,
        record.level(),
        unsafe { _esp_println_timestamp() },
        record.args(),
        reset
    );
    #[cfg(not(feature = "timestamp"))]
    println!("{}{} - {}{}", color, record.level(), record.args(), reset);
}

#[cfg(feature = "timestamp")]
unsafe extern "Rust" {
    fn _esp_println_timestamp() -> u64;
}