Struct sentry_core::protocol::Frame

source ·
pub struct Frame {
Show 17 fields pub function: Option<String>, pub symbol: Option<String>, pub module: Option<String>, pub package: Option<String>, pub filename: Option<String>, pub abs_path: Option<String>, pub lineno: Option<u64>, pub colno: Option<u64>, pub pre_context: Vec<String, Global>, pub context_line: Option<String>, pub post_context: Vec<String, Global>, pub in_app: Option<bool>, pub vars: BTreeMap<String, Value, Global>, pub image_addr: Option<Addr>, pub instruction_addr: Option<Addr>, pub symbol_addr: Option<Addr>, pub addr_mode: Option<String>,
}
Expand description

Represents a frame.

Fields

function: Option<String>

The name of the function is known.

Note that this might include the name of a class as well if that makes sense for the language.

symbol: Option<String>

The potentially mangled name of the symbol as it appears in an executable.

This is different from a function name by generally being the mangled name that appears natively in the binary. This is relevant for languages like Swift, C++ or Rust.

module: Option<String>

The name of the module the frame is contained in.

Note that this might also include a class name if that is something the language natively considers to be part of the stack (for instance in Java).

package: Option<String>

The name of the package that contains the frame.

For instance this can be a dylib for native languages, the name of the jar or .NET assembly.

filename: Option<String>

The filename (basename only).

abs_path: Option<String>

If known the absolute path.

lineno: Option<u64>

The line number if known.

colno: Option<u64>

The column number if known.

pre_context: Vec<String, Global>

The sources of the lines leading up to the current line.

context_line: Option<String>

The current line as source.

post_context: Vec<String, Global>

The sources of the lines after the current line.

in_app: Option<bool>

In-app indicator.

vars: BTreeMap<String, Value, Global>

Optional local variables.

image_addr: Option<Addr>

If known the location of the image.

instruction_addr: Option<Addr>

If known the location of the instruction.

symbol_addr: Option<Addr>

If known the location of symbol.

addr_mode: Option<String>

Optionally changes the addressing mode. The default value is the same as "abs" which means absolute referencing. This can also be set to "rel:DEBUG_ID" or "rel:IMAGE_INDEX" to make addresses relative to an object referenced by debug id or index. This for instance is necessary for WASM processing as WASM does not use a unified address space.

Trait Implementations

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Returns the “default value” for a type. Read more
Deserialize this value from the given Serde deserializer. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

Should always be Self
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.