#![cfg_attr(
all(msrv, feature = "unstable", nightly),
feature(
c_unwind,
lint_reasons,
must_not_suspend,
non_exhaustive_omitted_patterns_lint,
strict_provenance
)
)]
#![cfg_attr(
msrv,
deny(
absolute_paths_not_starting_with_crate,
anonymous_parameters,
array_into_iter,
asm_sub_register,
bad_asm_style,
bare_trait_objects,
bindings_with_variant_name,
// box_pointers,
break_with_label_and_loop,
clashing_extern_declarations,
coherence_leak_check,
confusable_idents,
const_evaluatable_unchecked,
const_item_mutation,
dead_code,
deprecated,
deprecated_in_future,
deprecated_where_clause_location,
deref_into_dyn_supertrait,
deref_nullptr,
drop_bounds,
duplicate_macro_attributes,
dyn_drop,
elided_lifetimes_in_paths,
ellipsis_inclusive_range_patterns,
explicit_outlives_requirements,
exported_private_dependencies,
forbidden_lint_groups,
function_item_references,
illegal_floating_point_literal_pattern,
improper_ctypes,
improper_ctypes_definitions,
incomplete_features,
indirect_structural_match,
inline_no_sanitize,
invalid_doc_attributes,
invalid_value,
irrefutable_let_patterns,
keyword_idents,
large_assignments,
late_bound_lifetime_arguments,
legacy_derive_helpers,
let_underscore_drop,
macro_use_extern_crate,
meta_variable_misuse,
missing_abi,
missing_copy_implementations,
missing_debug_implementations,
missing_docs,
mixed_script_confusables,
named_arguments_used_positionally,
no_mangle_generic_items,
non_ascii_idents,
non_camel_case_types,
non_fmt_panics,
non_shorthand_field_patterns,
non_snake_case,
non_upper_case_globals,
nontrivial_structural_match,
noop_method_call,
overlapping_range_endpoints,
path_statements,
pointer_structural_match,
private_in_public,
redundant_semicolons,
renamed_and_removed_lints,
repr_transparent_external_private_fields,
rust_2021_incompatible_closure_captures,
rust_2021_incompatible_or_patterns,
rust_2021_prefixes_incompatible_syntax,
rust_2021_prelude_collisions,
semicolon_in_expressions_from_macros,
single_use_lifetimes,
special_module_name,
stable_features,
suspicious_auto_trait_impls,
temporary_cstring_as_ptr,
trivial_bounds,
trivial_casts,
trivial_numeric_casts,
type_alias_bounds,
tyvar_behind_raw_pointer,
uncommon_codepoints,
unconditional_recursion,
unexpected_cfgs,
uninhabited_static,
unknown_lints,
unnameable_test_items,
unreachable_code,
unreachable_patterns,
unreachable_pub,
unsafe_code,
unsafe_op_in_unsafe_fn,
unstable_name_collisions,
unstable_syntax_pre_expansion,
unsupported_calling_conventions,
unused_allocation,
unused_assignments,
unused_attributes,
unused_braces,
unused_comparisons,
unused_crate_dependencies,
unused_doc_comments,
unused_extern_crates,
unused_features,
unused_import_braces,
unused_imports,
unused_labels,
unused_lifetimes,
unused_macro_rules,
unused_macros,
unused_must_use,
unused_mut,
unused_parens,
unused_qualifications,
unused_results,
unused_tuple_struct_fields,
unused_unsafe,
unused_variables,
variant_size_differences,
where_clauses_object_safety,
while_true,
))]
#![cfg_attr(all(msrv, feature = "unstable", nightly), allow(unstable_features))]
#![cfg_attr(
all(msrv, feature = "unstable", nightly),
deny(
ffi_unwind_calls,
fuzzy_provenance_casts,
lossy_provenance_casts,
must_not_suspend,
non_exhaustive_omitted_patterns,
unfulfilled_lint_expectations,
)
)]
#![cfg_attr(all(msrv, not(feature = "unstable"), nightly), deny(unstable_features))]
#![cfg_attr(
all(msrv, any(beta, nightly)),
deny(for_loops_over_fallibles, opaque_hidden_inferred_bound)
)]
#![cfg_attr(msrv, deny(clippy::all, clippy::pedantic))]
#[cfg(test)]
mod drain;
pub use slog::{crit, debug, error, info, trace, warn};
#[macro_export]
macro_rules! try_trace(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::trace!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::trace!(log, $($args)+);
}
};
);
#[macro_export]
macro_rules! try_debug(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::debug!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::debug!(log, $($args)+);
}
};
);
#[macro_export]
macro_rules! try_info(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::info!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::info!(log, $($args)+);
}
};
);
#[macro_export]
macro_rules! try_warn(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::warn!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::warn!(log, $($args)+);
}
};
);
#[macro_export]
macro_rules! try_error(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::error!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::error!(log, $($args)+);
}
};
);
#[macro_export]
macro_rules! try_crit(
($l:expr, #$tag:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::crit!(log, #$tag, $($args)+);
}
};
($l:expr, $($args:tt)+) => {
if let Some(ref log) = $l {
$crate::crit!(log, $($args)+);
}
};
);
#[cfg(test)]
mod tests {
use crate::drain::Buffer;
use slog::{o, Logger};
#[test]
fn trace() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_trace!(opt_logger, "SUCCESS: trace");
try_trace!(opt_logger, #"tag", "SUCCESS: trace with tag");
opt_logger = None;
try_trace!(opt_logger, "FAILED: trace");
try_trace!(opt_logger, #"tag", "FAILED: trace with tag");
assert_eq!(
"SUCCESS: traceSUCCESS: trace with tag",
format!("{}", buffer)
);
}
#[test]
fn debug() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_debug!(opt_logger, "SUCCESS: debug");
try_debug!(opt_logger, #"tag", "SUCCESS: debug with tag");
opt_logger = None;
try_debug!(opt_logger, "FAILED: debug");
try_debug!(opt_logger, #"tag", "FAILED: debug with tag");
assert_eq!(
"SUCCESS: debugSUCCESS: debug with tag",
format!("{}", buffer)
);
}
#[test]
fn info() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_info!(opt_logger, "SUCCESS: info");
try_info!(opt_logger, #"tag", "SUCCESS: info with tag");
opt_logger = None;
try_info!(opt_logger, "FAILED: info");
try_info!(opt_logger, #"tag", "FAILED: info with tag");
assert_eq!("SUCCESS: infoSUCCESS: info with tag", format!("{}", buffer));
}
#[test]
fn warn() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_warn!(opt_logger, "SUCCESS: warn");
try_warn!(opt_logger, #"tag", "SUCCESS: warn with tag");
opt_logger = None;
try_warn!(opt_logger, "FAILED: warn");
try_warn!(opt_logger, #"tag", "FAILED: warn with tag");
assert_eq!("SUCCESS: warnSUCCESS: warn with tag", format!("{}", buffer));
}
#[test]
fn error() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_error!(opt_logger, "SUCCESS: error");
try_error!(opt_logger, #"tag", "SUCCESS: error with tag");
opt_logger = None;
try_error!(opt_logger, "FAILED: error");
try_error!(opt_logger, #"tag", "FAILED: error with tag");
assert_eq!(
"SUCCESS: errorSUCCESS: error with tag",
format!("{}", buffer)
);
}
#[test]
fn crit() {
let buffer = Buffer::default();
let logger = Logger::root(buffer.clone(), o!());
let mut opt_logger: Option<Logger> = Some(logger);
try_crit!(opt_logger, "SUCCESS: crit");
try_crit!(opt_logger, #"tag", "SUCCESS: crit with tag");
opt_logger = None;
try_crit!(opt_logger, "FAILED: crit");
try_crit!(opt_logger, #"tag", "FAILED: crit with tag");
assert_eq!("SUCCESS: critSUCCESS: crit with tag", format!("{}", buffer));
}
}