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) => {
        /// Logs the line number and filename using `log::$level!`. Additionally, it can accept a
        /// string literal and format arguments like the `format!` macro.
        #[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) => {
        /// Logs the line number and filename using `log::$level!`. Additionally, it can accept a
        /// string literal and format arguments like the `format!` macro.
        #[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}