Struct symbolic_common::DebugId [−][src]
#[repr(C, packed)]pub struct DebugId { /* fields omitted */ }
Unique identifier for debug information files and their debug information.
This type is analogous to CodeId
, except that it identifies a debug file instead of the actual
library or executable. One some platforms, a DebugId
is an alias for a CodeId
but the exact
rules around this are complex. On Windows, the identifiers are completely different and refer to
separate files.
The string representation must be between 33 and 40 characters long and consist of:
- 36 character hyphenated hex representation of the UUID field
- 1-16 character lowercase hex representation of the u32 appendix
The debug identifier is compatible to Google Breakpad. Use DebugId::breakpad
to get a
breakpad string representation of this debug identifier.
Example
use std::str::FromStr; use debugid::DebugId; let id = DebugId::from_str("dfb8e43a-f242-3d73-a453-aeb6a777ef75-a")?; assert_eq!("dfb8e43a-f242-3d73-a453-aeb6a777ef75-a".to_string(), id.to_string());
Implementations
impl DebugId
[src]
impl DebugId
[src]pub fn nil() -> DebugId
[src]
Constructs an empty debug identifier, containing only zeros.
pub fn from_uuid(uuid: Uuid) -> DebugId
[src]
Constructs a DebugId
from its uuid
.
pub fn from_parts(uuid: Uuid, appendix: u32) -> DebugId
[src]
Constructs a DebugId
from its uuid
and appendix
parts.
pub fn from_guid_age(
guid: &[u8],
age: u32
) -> Result<DebugId, ParseDebugIdError>
[src]
guid: &[u8],
age: u32
) -> Result<DebugId, ParseDebugIdError>
Constructs a DebugId
from a Microsoft little-endian GUID and age.
pub fn from_breakpad(string: &str) -> Result<DebugId, ParseDebugIdError>
[src]
Parses a breakpad identifier from a string.
pub fn uuid(&self) -> Uuid
[src]
Returns the UUID part of the code module’s debug_identifier.
pub fn appendix(&self) -> u32
[src]
Returns the appendix part of the code module’s debug identifier.
On Windows, this is an incrementing counter to identify the build. On all other platforms, this value will always be zero.
pub fn is_nil(&self) -> bool
[src]
Returns whether this identifier is nil, i.e. it consists only of zeros.
pub fn breakpad(&self) -> BreakpadFormat<'_>
[src]
Returns a wrapper which when formatted via fmt::Display
will format a
a breakpad identifier.
Trait Implementations
impl<'de> Deserialize<'de> for DebugId
[src]
impl<'de> Deserialize<'de> for DebugId
[src]pub fn deserialize<D>(
deserializer: D
) -> Result<DebugId, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
[src]
deserializer: D
) -> Result<DebugId, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
impl FromStr for DebugId
[src]
impl FromStr for DebugId
[src]type Err = ParseDebugIdError
The associated error which can be returned from parsing.
pub fn from_str(string: &str) -> Result<DebugId, ParseDebugIdError>
[src]
impl PartialOrd<DebugId> for DebugId
[src]
impl PartialOrd<DebugId> for DebugId
[src]impl Serialize for DebugId
[src]
impl Serialize for DebugId
[src]pub fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
[src]
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
impl StructuralEq for DebugId
[src]
impl StructuralEq for DebugId
[src]impl StructuralPartialEq for DebugId
[src]
impl StructuralPartialEq for DebugId
[src]Auto Trait Implementations
impl RefUnwindSafe for DebugId
impl RefUnwindSafe for DebugId
impl UnwindSafe for DebugId
impl UnwindSafe for DebugId