1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#[cfg(not(all(not(debug_assertions), feature = "off_on_release")))]
macro_rules! make_log_rule {
(($d:tt), $level:ident, $name:ident) => {
#[macro_export]
#[cfg_attr(docsrs, doc(cfg(feature = "log")))]
macro_rules! $name {
() => {
::log::$level!("{}:{:03}", file!(), line!());
};
($msg:literal) => {
::log::$level!("({}:{:03}): {}", file!(), line!(), $msg);
};
($msg:literal, $d($args:expr),+) => {
::log::$level!("({}:{:03}): {}", file!(), line!(), format!($msg, $d($args),+));
}
}
};
($level:ident, $name:ident) => {
make_log_rule!{($), $level, $name}
};
}
#[cfg(all(not(debug_assertions), feature = "off_on_release"))]
macro_rules! make_log_rule {
(($d:tt), $level:ident, $name:ident) => {
#[macro_export]
#[cfg_attr(docsrs, doc(cfg(feature = "log")))]
macro_rules! $name {
() => {};
($msg:literal) => {};
($msg:literal, $d($args:expr),+) => {};
}
};
($level:ident, $name:ident) => {};
}
make_log_rule! {trace, here_trace}
make_log_rule! {debug, here_debug}
make_log_rule! {info, here_info}
make_log_rule! {warn, here_warn}
make_log_rule! {error, here_error}