mirror of
https://github.com/rust-windowing/winit.git
synced 2026-06-27 07:03:15 -04:00
Tracing is a modern replacement for the log crate that allows for annotating log messages with the function that they come from. Signed-off-by: John Nunley <dev@notgull.net> Closes: #3482
41 lines
919 B
Rust
41 lines
919 B
Rust
use icrate::Foundation::{NSNotFound, NSRange, NSUInteger};
|
|
use tracing::trace;
|
|
|
|
pub const EMPTY_RANGE: NSRange = NSRange {
|
|
location: NSNotFound as NSUInteger,
|
|
length: 0,
|
|
};
|
|
|
|
macro_rules! trace_scope {
|
|
($s:literal) => {
|
|
let _crate = $crate::platform_impl::platform::util::TraceGuard::new(module_path!(), $s);
|
|
};
|
|
}
|
|
|
|
pub(crate) struct TraceGuard {
|
|
module_path: &'static str,
|
|
called_from_fn: &'static str,
|
|
}
|
|
|
|
impl TraceGuard {
|
|
#[inline]
|
|
pub(crate) fn new(module_path: &'static str, called_from_fn: &'static str) -> Self {
|
|
trace!(target = module_path, "Triggered `{}`", called_from_fn);
|
|
Self {
|
|
module_path,
|
|
called_from_fn,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Drop for TraceGuard {
|
|
#[inline]
|
|
fn drop(&mut self) {
|
|
trace!(
|
|
target = self.module_path,
|
|
"Completed `{}`",
|
|
self.called_from_fn
|
|
);
|
|
}
|
|
}
|