pub struct Formatter { /* private fields */ }
Expand description
A formatter to write logs into.
Formatter
implements the standard Write
trait for writing log records.
It also supports terminal styling using ANSI escape codes.
§Examples
Use the writeln
macro to format a log record.
An instance of a Formatter
is passed to an env_logger
format as buf
:
use std::io::Write;
let mut builder = env_logger::Builder::new();
builder.format(|buf, record| writeln!(buf, "{}: {}", record.level(), record.args()));
Implementations§
Source§impl Formatter
impl Formatter
Sourcepub fn timestamp(&self) -> Timestamp
Available on crate feature humantime
only.
pub fn timestamp(&self) -> Timestamp
humantime
only.Get a Timestamp
for the current date and time in UTC.
§Examples
Include the current timestamp with the log record:
use std::io::Write;
let mut builder = env_logger::Builder::new();
builder.format(|buf, record| {
let ts = buf.timestamp();
writeln!(buf, "{}: {}: {}", ts, record.level(), record.args())
});
Examples found in repository?
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
fn init_logger() {
let env = Env::default()
.filter("MY_LOG_LEVEL")
.write_style("MY_LOG_STYLE");
Builder::from_env(env)
.format(|buf, record| {
// We are reusing `anstyle` but there are `anstyle-*` crates to adapt it to your
// preferred styling crate.
let warn_style = buf.default_level_style(log::Level::Warn);
let timestamp = buf.timestamp();
writeln!(
buf,
"My formatted log ({timestamp}): {warn_style}{}{warn_style:#}",
record.args()
)
})
.init();
}
Sourcepub fn timestamp_seconds(&self) -> Timestamp
Available on crate feature humantime
only.
pub fn timestamp_seconds(&self) -> Timestamp
humantime
only.Get a Timestamp
for the current date and time in UTC with full
second precision.
Sourcepub fn timestamp_millis(&self) -> Timestamp
Available on crate feature humantime
only.
pub fn timestamp_millis(&self) -> Timestamp
humantime
only.Get a Timestamp
for the current date and time in UTC with
millisecond precision.
Sourcepub fn timestamp_micros(&self) -> Timestamp
Available on crate feature humantime
only.
pub fn timestamp_micros(&self) -> Timestamp
humantime
only.Get a Timestamp
for the current date and time in UTC with
microsecond precision.
Sourcepub fn timestamp_nanos(&self) -> Timestamp
Available on crate feature humantime
only.
pub fn timestamp_nanos(&self) -> Timestamp
humantime
only.Get a Timestamp
for the current date and time in UTC with
nanosecond precision.
Source§impl Formatter
impl Formatter
Sourcepub fn default_level_style(&self, level: Level) -> Style
Available on crate feature color
only.
pub fn default_level_style(&self, level: Level) -> Style
color
only.Get the default style::Style
for the given level.
The style can be used to print other values besides the level.
See style
for how to adapt it to the styling crate of your choice
Examples found in repository?
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
fn init_logger() {
let env = Env::default()
.filter("MY_LOG_LEVEL")
.write_style("MY_LOG_STYLE");
Builder::from_env(env)
.format(|buf, record| {
// We are reusing `anstyle` but there are `anstyle-*` crates to adapt it to your
// preferred styling crate.
let warn_style = buf.default_level_style(log::Level::Warn);
let timestamp = buf.timestamp();
writeln!(
buf,
"My formatted log ({timestamp}): {warn_style}{}{warn_style:#}",
record.args()
)
})
.init();
}
Trait Implementations§
Source§impl Write for Formatter
impl Write for Formatter
Source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
can_vector
)1.0.0 · Source§fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
Source§fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
write_all_vectored
)