pub struct Metadata<'a> { /* private fields */ }Expand description
Metadata describing a span or event.
All spans and events have the following metadata:
- A name, represented as a static string.
- A target, a string that categorizes part of the system where the span
or event occurred. The tracingmacros default to using the module path where the span or event originated as the target, but it may be overridden.
- A verbosity level. This determines how verbose a given span or event
is, and allows enabling or disabling more verbose diagnostics
situationally. See the documentation for the Leveltype for details.
- The names of the fields defined by the span or event.
- Whether the metadata corresponds to a span or event.
In addition, the following optional metadata describing the source code location where the span or event originated may be provided:
- The file name
- The line number
- The module path
Metadata is used by Subscribers when filtering spans and events, and it
may also be used as part of their data payload.
When created by the event! or span! macro, the metadata describing a
particular event or span is constructed statically and exists as a single
static instance. Thus, the overhead of creating the metadata is
significantly lower than that of creating the actual span. Therefore,
filtering is based on metadata, rather than on the constructed span.
§Equality
In well-behaved applications, two Metadata with equal
callsite identifiers will be equal in all other ways (i.e., have the same
name, target, etc.). Consequently, in release builds, Metadata::eq
only checks that its arguments have equal callsites. However, the equality
of Metadata’s other fields is checked in debug builds.
Implementations§
source§impl<'a> Metadata<'a>
 
impl<'a> Metadata<'a>
sourcepub const fn new(
    name: &'static str,
    target: &'a str,
    level: Level,
    file: Option<&'a str>,
    line: Option<u32>,
    module_path: Option<&'a str>,
    fields: FieldSet,
    kind: Kind
) -> Metadata<'a>
 
pub const fn new( name: &'static str, target: &'a str, level: Level, file: Option<&'a str>, line: Option<u32>, module_path: Option<&'a str>, fields: FieldSet, kind: Kind ) -> Metadata<'a>
Construct new metadata for a span or event, with a name, target, level, field names, and optional source code location.
sourcepub fn fields(&self) -> &FieldSet
 
pub fn fields(&self) -> &FieldSet
Returns the names of the fields on the described span or event.
sourcepub fn target(&self) -> &'a str
 
pub fn target(&self) -> &'a str
Returns a string describing the part of the system where the span or event that this metadata describes occurred.
Typically, this is the module path, but alternate targets may be set when spans or events are constructed.
sourcepub fn module_path(&self) -> Option<&'a str>
 
pub fn module_path(&self) -> Option<&'a str>
Returns the path to the Rust module where the span occurred, or
None if the module path is unknown.
sourcepub fn file(&self) -> Option<&'a str>
 
pub fn file(&self) -> Option<&'a str>
Returns the name of the source code file where the span
occurred, or None if the file is unknown
sourcepub fn line(&self) -> Option<u32>
 
pub fn line(&self) -> Option<u32>
Returns the line number in the source code file where the span
occurred, or None if the line number is unknown.
sourcepub fn callsite(&self) -> Identifier
 
pub fn callsite(&self) -> Identifier
Returns an opaque Identifier that uniquely identifies the callsite
this Metadata originated from.
Trait Implementations§
source§impl<'a> PartialEq for Metadata<'a>
 
impl<'a> PartialEq for Metadata<'a>
impl<'a> Eq for Metadata<'a>
Auto Trait Implementations§
impl<'a> Freeze for Metadata<'a>
impl<'a> !RefUnwindSafe for Metadata<'a>
impl<'a> Send for Metadata<'a>
impl<'a> Sync for Metadata<'a>
impl<'a> Unpin for Metadata<'a>
impl<'a> !UnwindSafe for Metadata<'a>
Blanket Implementations§
source§impl<T, U> AsBindGroupShaderType<U> for T
 
impl<T, U> AsBindGroupShaderType<U> for T
source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
 
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T ShaderType for self. When used in AsBindGroup
derives, it is safe to assume that all images in self exist.source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Downcast for Twhere
    T: Any,
 
impl<T> Downcast for Twhere
    T: Any,
source§fn into_any(self: Box<T>) -> Box<dyn Any>
 
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
 
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.source§fn as_any(&self) -> &(dyn Any + 'static)
 
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
 
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.source§impl<T> DowncastSync for T
 
impl<T> DowncastSync for T
source§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.