Crates.io | l0g-macros |
lib.rs | l0g-macros |
version | 1.0.0 |
source | src |
created_at | 2024-03-21 17:40:05.793504 |
updated_at | 2024-03-21 17:40:05.793504 |
description | proc-macros for l0g crate |
homepage | |
repository | https://github.com/glaeqen/l0g |
max_upload_size | |
id | 1181901 |
size | 5,187 |
Opinionated l0gging facade meant for the no_std
libraries that are also sometimes used in a std
context.
Logging facilities differ depending on the environment, especially between no_std
and std
. This facade allows to delegate the decision which l0gging implementation shall be used to the top-level application.
Any call to l0g::{error,warn,info,debug,trace}
turns into a
log::{error,warn,info,debug,trace}
from the log crate when log
feature is setdefmt::{error,warn,info,debug,trace}
from the defmt crate when defmt
feature is setMoreover, proc-macro is provided to generalize over which formatting implementation should be used
#[l0g::format]
struct MyStruct {
value: u8
}
turns into
#[derive(core::fmt::Debug)]
struct MyStruct {
value: u8
}
if log
feature is used or
#[derive(defmt::Format)]
struct MyStruct {
value: u8
}
if defmt
feature is used.
This allows a {:?}
formatting to work, regardless of which logging implementation is chosen.
In the Cargo.toml
of your libraries just say
l0g = "1"
In the no_std
top-level application specify the dependency with the defmt
feature. For how to make defmt
work, take a look into its respective documentation.
l0g = { version = "1", features = ["defmt"] }
In the std top-level application specify the dependency with the log
feature. For how to make log
work, take a look into its respective documentation.
l0g = { version = "1", features = ["log"] }