blob: 312c909f0ffe7cfa1b31d8612fca2916880e7075 (
plain)
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
#[cfg(feature = "logging")]
pub fn init_logger(
min_level: log::LevelFilter, debug_file_name: &std::ffi::OsStr,
) -> Result<(), fern::InitError> {
fern::Dispatch::new()
.format(|out, message, record| {
// Note we aren't using local time since it only works on single-threaded processes.
// If that ever does get patched in again, enable the "local-offset" feature.
let offset = time::OffsetDateTime::now_utc();
out.finish(format_args!(
"{}[{}][{}] {}",
offset
.format(&time::macros::format_description!(
// The weird "[[[" is because we need to escape a bracket ("[[") to show one "[".
// See https://time-rs.github.io/book/api/format-description.html
"[[[year]-[month]-[day]][[[hour]:[minute]:[second][subsecond digits:9]]"
))
.unwrap(),
record.target(),
record.level(),
message
))
})
.level(min_level)
.chain(fern::log_file(debug_file_name)?)
.apply()?;
Ok(())
}
#[macro_export]
macro_rules! c_debug {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::debug!($($x)*)
}
};
}
#[macro_export]
macro_rules! c_error {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::error!($($x)*)
}
};
}
#[macro_export]
macro_rules! c_info {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::info!($($x)*)
}
};
}
#[macro_export]
macro_rules! c_log {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::log!($($x)*)
}
};
}
#[macro_export]
macro_rules! c_trace {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::trace!($($x)*)
}
};
}
#[macro_export]
macro_rules! c_warn {
($($x:tt)*) => {
#[cfg(feature = "logging")]
{
log::warn!($($x)*)
}
};
}
|