pub fn setup_logging() {
#[cfg(not(target_arch = "wasm32"))]
fn setup() {
if cfg!(debug_assertions) && std::env::var("RUST_BACKTRACE").is_err() {
std::env::set_var("RUST_BACKTRACE", "1");
}
crate::multi_logger::init().expect("Failed to set logger");
let log_filter = crate::default_log_filter();
if log_filter.contains("trace") {
log::set_max_level(log::LevelFilter::Trace);
} else if log_filter.contains("debug") {
log::set_max_level(log::LevelFilter::Debug);
} else {
log::set_max_level(log::LevelFilter::Info);
}
let mut stderr_logger = env_logger::Builder::new();
stderr_logger.parse_filters(&log_filter);
crate::add_boxed_logger(Box::new(stderr_logger.build())).expect("Failed to install logger");
if env_var_bool("RERUN_PANIC_ON_WARN") == Some(true) {
crate::add_boxed_logger(Box::new(PanicOnWarn {}))
.expect("Failed to enable RERUN_PANIC_ON_WARN");
crate::info!("RERUN_PANIC_ON_WARN: any warning or error will cause Rerun to panic.");
}
}
#[cfg(target_arch = "wasm32")]
fn setup() {
crate::multi_logger::init().expect("Failed to set logger");
log::set_max_level(log::LevelFilter::Debug);
crate::add_boxed_logger(Box::new(crate::web_logger::WebLogger::new(
log::LevelFilter::Debug,
)))
.expect("Failed to install logger");
}
use std::sync::Once;
static START: Once = Once::new();
START.call_once(setup);
}
#[cfg(not(target_arch = "wasm32"))]
fn env_var_bool(name: &str) -> Option<bool> {
std::env::var(name).ok()
.and_then(|s| match s.to_lowercase().as_str() {
"0" | "false" | "off" | "no" => Some(false),
"1" | "true" | "on" | "yes" => Some(true),
_ => {
crate::warn!(
"Invalid value for environment variable {name}={s:?}. Expected 'on' or 'off'. It will be ignored"
);
None
}
})
}
#[cfg(not(target_arch = "wasm32"))]
struct PanicOnWarn {}
#[cfg(not(target_arch = "wasm32"))]
impl log::Log for PanicOnWarn {
fn enabled(&self, metadata: &log::Metadata<'_>) -> bool {
match metadata.level() {
log::Level::Error | log::Level::Warn => true,
log::Level::Info | log::Level::Debug | log::Level::Trace => false,
}
}
fn log(&self, record: &log::Record<'_>) {
let level = match record.level() {
log::Level::Error => "error",
log::Level::Warn => "warning",
log::Level::Info | log::Level::Debug | log::Level::Trace => return,
};
panic!("{level} logged with RERUN_PANIC_ON_WARN: {}", record.args());
}
fn flush(&self) {}
}