#[macro_export]
#[clippy::format_args]
macro_rules! log {
(logger: $logger:expr, target: $target:expr, $lvl:expr, $($arg:tt)+) => ({
$crate::__log!(
logger: $crate::__log_logger!($logger),
target: $target,
$lvl,
$($arg)+
)
});
(logger: $logger:expr, $lvl:expr, $($arg:tt)+) => ({
$crate::__log!(
logger: $crate::__log_logger!($logger),
target: $crate::__private_api::module_path!(),
$lvl,
$($arg)+
)
});
(target: $target:expr, $lvl:expr, $($arg:tt)+) => ({
$crate::__log!(
logger: $crate::__log_logger!(__log_global_logger),
target: $target,
$lvl,
$($arg)+
)
});
($lvl:expr, $($arg:tt)+) => ({
$crate::__log!(
logger: $crate::__log_logger!(__log_global_logger),
target: $crate::__private_api::module_path!(),
$lvl,
$($arg)+
)
});
}
#[doc(hidden)]
#[macro_export]
macro_rules! __log {
(logger: $logger:expr, target: $target:expr, $lvl:expr, $($key:tt $(:$capture:tt)? $(= $value:expr)?),+; $($arg:tt)+) => ({
let lvl = $lvl;
if lvl <= $crate::STATIC_MAX_LEVEL && lvl <= $crate::max_level() {
$crate::__private_api::log(
$logger,
$crate::__private_api::format_args!($($arg)+),
lvl,
&($target, $crate::__private_api::module_path!(), $crate::__private_api::loc()),
&[$(($crate::__log_key!($key), $crate::__log_value!($key $(:$capture)* = $($value)*))),+] as &[_],
);
}
});
(logger: $logger:expr, target: $target:expr, $lvl:expr, $($arg:tt)+) => ({
let lvl = $lvl;
if lvl <= $crate::STATIC_MAX_LEVEL && lvl <= $crate::max_level() {
$crate::__private_api::log(
$logger,
$crate::__private_api::format_args!($($arg)+),
lvl,
&($target, $crate::__private_api::module_path!(), $crate::__private_api::loc()),
(),
);
}
});
}
#[macro_export]
#[clippy::format_args]
macro_rules! error {
(logger: $logger:expr, target: $target:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), target: $target, $crate::Level::Error, $($arg)+)
});
(logger: $logger:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), $crate::Level::Error, $($arg)+)
});
(target: $target:expr, $($arg:tt)+) => ({
$crate::log!(target: $target, $crate::Level::Error, $($arg)+)
});
($($arg:tt)+) => ($crate::log!($crate::Level::Error, $($arg)+))
}
#[macro_export]
#[clippy::format_args]
macro_rules! warn {
(logger: $logger:expr, target: $target:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), target: $target, $crate::Level::Warn, $($arg)+)
});
(logger: $logger:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), $crate::Level::Warn, $($arg)+)
});
(target: $target:expr, $($arg:tt)+) => ({
$crate::log!(target: $target, $crate::Level::Warn, $($arg)+)
});
($($arg:tt)+) => ($crate::log!($crate::Level::Warn, $($arg)+))
}
#[macro_export]
#[clippy::format_args]
macro_rules! info {
(logger: $logger:expr, target: $target:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), target: $target, $crate::Level::Info, $($arg)+)
});
(logger: $logger:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), $crate::Level::Info, $($arg)+)
});
(target: $target:expr, $($arg:tt)+) => ({
$crate::log!(target: $target, $crate::Level::Info, $($arg)+)
});
($($arg:tt)+) => ($crate::log!($crate::Level::Info, $($arg)+))
}
#[macro_export]
#[clippy::format_args]
macro_rules! debug {
(logger: $logger:expr, target: $target:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), target: $target, $crate::Level::Debug, $($arg)+)
});
(logger: $logger:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), $crate::Level::Debug, $($arg)+)
});
(target: $target:expr, $($arg:tt)+) => ({
$crate::log!(target: $target, $crate::Level::Debug, $($arg)+)
});
($($arg:tt)+) => ($crate::log!($crate::Level::Debug, $($arg)+))
}
#[macro_export]
#[clippy::format_args]
macro_rules! trace {
(logger: $logger:expr, target: $target:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), target: $target, $crate::Level::Trace, $($arg)+)
});
(logger: $logger:expr, $($arg:tt)+) => ({
$crate::log!(logger: $crate::__log_logger!($logger), $crate::Level::Trace, $($arg)+)
});
(target: $target:expr, $($arg:tt)+) => ({
$crate::log!(target: $target, $crate::Level::Trace, $($arg)+)
});
($($arg:tt)+) => ($crate::log!($crate::Level::Trace, $($arg)+))
}
#[macro_export]
macro_rules! log_enabled {
(logger: $logger:expr, target: $target:expr, $lvl:expr) => ({
$crate::__log_enabled!(logger: $crate::__log_logger!($logger), target: $target, $lvl)
});
(logger: $logger:expr, $lvl:expr) => ({
$crate::__log_enabled!(logger: $crate::__log_logger!($logger), target: $crate::__private_api::module_path!(), $lvl)
});
(target: $target:expr, $lvl:expr) => ({
$crate::__log_enabled!(logger: $crate::__log_logger!(__log_global_logger), target: $target, $lvl)
});
($lvl:expr) => ({
$crate::__log_enabled!(logger: $crate::__log_logger!(__log_global_logger), target: $crate::__private_api::module_path!(), $lvl)
});
}
#[doc(hidden)]
#[macro_export]
macro_rules! __log_enabled {
(logger: $logger:expr, target: $target:expr, $lvl:expr) => {{
let lvl = $lvl;
lvl <= $crate::STATIC_MAX_LEVEL
&& lvl <= $crate::max_level()
&& $crate::__private_api::enabled($logger, lvl, $target)
}};
}
#[doc(hidden)]
#[macro_export]
macro_rules! __log_logger {
(__log_global_logger) => {{
$crate::__private_api::GlobalLogger
}};
($logger:expr) => {{
&($logger)
}};
}
#[doc(hidden)]
#[macro_export]
#[cfg(feature = "kv")]
macro_rules! __log_key {
($($args:ident)*) => {
$crate::__private_api::stringify!($($args)*)
};
($($args:expr)*) => {
$($args)*
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(not(feature = "kv"))]
macro_rules! __log_key {
($($args:tt)*) => {
compile_error!("key value support requires the `kv` feature of `log`")
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(feature = "kv")]
macro_rules! __log_value {
($key:tt = $args:expr) => {
$crate::__log_value!(($args):value)
};
($key:tt :$capture:tt = $args:expr) => {
$crate::__log_value!(($args):$capture)
};
($key:ident =) => {
$crate::__log_value!(($key):value)
};
($key:ident :$capture:tt =) => {
$crate::__log_value!(($key):$capture)
};
(($args:expr):value) => {
$crate::__private_api::capture_to_value(&&$args)
};
(($args:expr):?) => {
$crate::__private_api::capture_debug(&&$args)
};
(($args:expr):debug) => {
$crate::__private_api::capture_debug(&&$args)
};
(($args:expr):%) => {
$crate::__private_api::capture_display(&&$args)
};
(($args:expr):display) => {
$crate::__private_api::capture_display(&&$args)
};
(($args:expr):err) => {
$crate::__log_value_error!($args)
};
(($args:expr):sval) => {
$crate::__log_value_sval!($args)
};
(($args:expr):serde) => {
$crate::__log_value_serde!($args)
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(not(feature = "kv"))]
macro_rules! __log_value {
($($args:tt)*) => {
compile_error!("key value support requires the `kv` feature of `log`")
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(feature = "kv_sval")]
macro_rules! __log_value_sval {
($args:expr) => {
$crate::__private_api::capture_sval(&&$args)
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(not(feature = "kv_sval"))]
macro_rules! __log_value_sval {
($args:expr) => {
compile_error!("capturing values as `sval::Value` requites the `kv_sval` feature of `log`")
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(feature = "kv_serde")]
macro_rules! __log_value_serde {
($args:expr) => {
$crate::__private_api::capture_serde(&&$args)
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(not(feature = "kv_serde"))]
macro_rules! __log_value_serde {
($args:expr) => {
compile_error!(
"capturing values as `serde::Serialize` requites the `kv_serde` feature of `log`"
)
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(feature = "kv_std")]
macro_rules! __log_value_error {
($args:expr) => {
$crate::__private_api::capture_error(&$args)
};
}
#[doc(hidden)]
#[macro_export]
#[cfg(not(feature = "kv_std"))]
macro_rules! __log_value_error {
($args:expr) => {
compile_error!(
"capturing values as `std::error::Error` requites the `kv_std` feature of `log`"
)
};
}