emit_traceparent

Struct Traceparent

Source
pub struct Traceparent { /* private fields */ }
Expand description

A W3C traceparent.

This type contains emit’s TraceId and SpanId, along with TraceFlags that determine sampling.

Traceparents exist at the edges of your application. On incoming requests, it may carry a traceparent header that can be parsed into a Traceparent and pushed onto the active trace context with Traceparent::push. On outgoing requests, the active trace context is pulled by Traceparent::current and formatted into a traceparent header.

Implementations§

Source§

impl Traceparent

Source

pub const fn new( trace_id: Option<TraceId>, span_id: Option<SpanId>, trace_flags: TraceFlags, ) -> Self

Create a new traceparent with the given trace id, span id, and trace flags.

Source

pub fn try_from_str(traceparent: &str) -> Result<Self, Error>

Parse a traceparent from its text format, as defined in the W3C standard.

Source

pub fn trace_id(&self) -> Option<&TraceId>

Get the trace id.

Source

pub fn span_id(&self) -> Option<&SpanId>

Get the span id (also called the parent id).

Source

pub fn trace_flags(&self) -> &TraceFlags

Get the trace flags.

These flags can be used to tell whether the traceparent is for a sampled trace or not.

Source

pub fn current() -> Self

Get the current trace context.

If no context has been set, this method will return a new traceparent with no trace id or span id, but with TraceFlags::SAMPLED.

Source

pub fn push(&self) -> Frame<TraceparentCtxt>

Get a Frame that can set the current trace context in a scope.

While the frame is active, Traceparent::current will return this traceparent.

Source

pub fn is_valid(&self) -> bool

Whether the traceparent carries a non-empty trace id and span id.

An invalid traceparent can still be used for propagation, but will likely be ignored by downstream services.

Trait Implementations§

Source§

impl Clone for Traceparent

Source§

fn clone(&self) -> Traceparent

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Traceparent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for Traceparent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FromStr for Traceparent

Source§

type Err = Error

The associated error which can be returned from parsing.
Source§

fn from_str(header: &str) -> Result<Self, Error>

Parses a string s to return a value of this type. Read more
Source§

impl PartialEq for Traceparent

Source§

fn eq(&self, other: &Traceparent) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for Traceparent

Source§

impl Eq for Traceparent

Source§

impl StructuralPartialEq for Traceparent

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V