pub struct TraceState(/* private fields */);
Expand description
TraceState carries system-specific configuration data, represented as a list of key-value pairs. TraceState allows multiple tracing systems to participate in the same trace.
Please review the W3C specification for details on this field.
Implementations§
Source§impl TraceState
impl TraceState
Sourcepub const NONE: TraceState = _
pub const NONE: TraceState = _
The default TraceState
, as a constant
Sourcepub fn from_key_value<T, K, V>(trace_state: T) -> TraceResult<Self>
pub fn from_key_value<T, K, V>(trace_state: T) -> TraceResult<Self>
Creates a new TraceState
from the given key-value collection.
§Examples
use opentelemetry::trace::TraceState;
let kvs = vec![("foo", "bar"), ("apple", "banana")];
let trace_state = TraceState::from_key_value(kvs);
assert!(trace_state.is_ok());
assert_eq!(trace_state.unwrap().header(), String::from("foo=bar,apple=banana"))
Sourcepub fn get(&self, key: &str) -> Option<&str>
pub fn get(&self, key: &str) -> Option<&str>
Retrieves a value for a given key from the TraceState
if it exists.
Sourcepub fn insert<K, V>(&self, key: K, value: V) -> TraceResult<TraceState>
pub fn insert<K, V>(&self, key: K, value: V) -> TraceResult<TraceState>
Inserts the given key-value pair into the TraceState
. If a value already exists for the
given key, this updates the value and updates the value’s position. If the key or value are
invalid per the W3 Spec an Err
is returned, else a new TraceState
with the
updated key/value is returned.
Sourcepub fn delete<K: Into<String>>(&self, key: K) -> TraceResult<TraceState>
pub fn delete<K: Into<String>>(&self, key: K) -> TraceResult<TraceState>
Removes the given key-value pair from the TraceState
. If the key is invalid per the
W3 Spec an Err
is returned. Else, a new TraceState
with the removed entry is returned.
If the key is not in TraceState
. The original TraceState
will be cloned and returned.
Sourcepub fn header(&self) -> String
pub fn header(&self) -> String
Creates a new TraceState
header string, delimiting each key and value with a =
and each
entry with a ,
.
Sourcepub fn header_delimited(
&self,
entry_delimiter: &str,
list_delimiter: &str,
) -> String
pub fn header_delimited( &self, entry_delimiter: &str, list_delimiter: &str, ) -> String
Creates a new TraceState
header string, with the given key/value delimiter and entry delimiter.
Trait Implementations§
Source§impl Clone for TraceState
impl Clone for TraceState
Source§fn clone(&self) -> TraceState
fn clone(&self) -> TraceState
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more