sentry_core

Struct Span

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

A running Performance Monitoring Span.

The span needs to be explicitly finished via Span::finish, otherwise it will not be sent to Sentry.

Implementations§

Source§

impl Span

Source

pub fn set_data(&self, key: &str, value: Value)

Set some extra information to be sent with this Transaction.

Source

pub fn set_tag<V: ToString>(&self, key: &str, value: V)

Sets a tag to a specific value.

Source

pub fn data(&self) -> Data<'_>

Returns a smart pointer to the span’s data field.

Since Data implements Deref and DerefMut, this can be used to read and mutate the span data.

§Concurrency

In order to obtain any kind of reference to the data field, a Mutex needs to be locked. The returned Data holds on to this lock for as long as it lives. Therefore you must take care not to keep the returned Data around too long or it will never relinquish the lock and you may run into a deadlock.

Source

pub fn get_trace_context(&self) -> TraceContext

Get the TransactionContext of the Span.

Note that this clones the underlying value.

Source

pub fn get_span_id(&self) -> SpanId

Get the current span ID.

Source

pub fn get_status(&self) -> Option<SpanStatus>

Get the status of the Span.

Source

pub fn set_status(&self, status: SpanStatus)

Set the status of the Span.

Source

pub fn set_request(&self, request: Request)

Set the HTTP request information for this Span.

Source

pub fn iter_headers(&self) -> TraceHeadersIter

Returns the headers needed for distributed tracing.

Source

pub fn is_sampled(&self) -> bool

Get the sampling decision for this Span.

Source

pub fn finish(self)

Finishes the Span.

This will record the end timestamp and add the span to the transaction in which it was started.

Source

pub fn start_child(&self, op: &str, description: &str) -> Span

Starts a new child Span with the given op and description.

The span must be explicitly finished via Span::finish.

Trait Implementations§

Source§

impl Clone for Span

Source§

fn clone(&self) -> Span

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 Span

Source§

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

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

impl From<Span> for TransactionOrSpan

Source§

fn from(span: Span) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl Freeze for Span

§

impl RefUnwindSafe for Span

§

impl Send for Span

§

impl Sync for Span

§

impl Unpin for Span

§

impl UnwindSafe for Span

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, 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

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T