docs.rs failed to build sgx_backtrace-1.1.1
Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
A library for acquiring a backtrace at runtime
This library is meant to supplement the `RUST_BACKTRACE=1` support of the
standard library by allowing an acquisition of a backtrace at runtime
programmatically. The backtraces generated by this library do not need to be
parsed, for example, and expose the functionality of multiple backend
implementations.
# Implementation
This library makes use of a number of strategies for actually acquiring a
backtrace. For example unix uses libgcc's libunwind bindings by default to
acquire a backtrace, but coresymbolication or dladdr is used on OSX to
acquire symbol names while linux uses gcc's libbacktrace.
When using the default feature set of this library the "most reasonable" set
of defaults is chosen for the current platform, but the features activated
can also be controlled at a finer granularity.
# API Principles
This library attempts to be as flexible as possible to accommodate different
backend implementations of acquiring a backtrace. Consequently the currently
exported functions are closure-based as opposed to the likely expected
iterator-based versions. This is done due to limitations of the underlying
APIs used from the system.
# Usage
First, add this to your Cargo.toml
```toml
[dependencies]
sgx_backtrace = "1.0.8"
```
Next:
```
extern crate sgx_backtrace;
fn main() {
# // Unsafe here so test passes on no_std.
# #[cfg(feature = "std")] {
sgx_backtrace::set_enclave_path("enclave.signed.so");
sgx_backtrace::trace(|frame| {
let ip = frame.ip();
let symbol_address = frame.symbol_address();
// Resolve this instruction pointer to a symbol name
sgx_backtrace::resolve_frame(frame, |symbol| {
if let Some(name) = symbol.name() {
// ...
}
if let Some(filename) = symbol.filename() {
// ...
}
});
true // keep going to the next frame
});
}
# }
```
Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.