pub struct PanicInfo<'a> { /* private fields */ }
Expand description
A struct providing information about a panic.
A PanicInfo
structure is passed to the panic handler defined by #[panic_handler]
.
For the type used by the panic hook mechanism in std
, see std::panic::PanicHookInfo
.
Implementations§
Source§impl<'a> PanicInfo<'a>
impl<'a> PanicInfo<'a>
1.81.0 · Sourcepub fn message(&self) -> PanicMessage<'_>
Available on non-crate feature ferrocene_certified
only.
pub fn message(&self) -> PanicMessage<'_>
ferrocene_certified
only.The message that was given to the panic!
macro.
§Example
The type returned by this method implements Display
, so it can
be passed directly to write!()
and similar macros.
#[panic_handler]
fn panic_handler(panic_info: &PanicInfo<'_>) -> ! {
write!(DEBUG_OUTPUT, "panicked: {}", panic_info.message());
loop {}
}
1.10.0 · Sourcepub fn location(&self) -> Option<&Location<'_>>
Available on non-crate feature ferrocene_certified
only.
pub fn location(&self) -> Option<&Location<'_>>
ferrocene_certified
only.Returns information about the location from which the panic originated, if available.
This method will currently always return Some
, but this may change
in future versions.
§Examples
use std::panic;
panic::set_hook(Box::new(|panic_info| {
if let Some(location) = panic_info.location() {
println!("panic occurred in file '{}' at line {}",
location.file(),
location.line(),
);
} else {
println!("panic occurred but can't get location information...");
}
}));
panic!("Normal panic");
1.10.0 · Sourcepub fn payload(&self) -> &(dyn Any + Send)
👎Deprecated since 1.81.0: this never returns anything usefulAvailable on non-crate feature ferrocene_certified
only.
pub fn payload(&self) -> &(dyn Any + Send)
ferrocene_certified
only.Returns the payload associated with the panic.
On this type, core::panic::PanicInfo
, this method never returns anything useful.
It only exists because of compatibility with std::panic::PanicHookInfo
,
which used to be the same type.
Sourcepub fn can_unwind(&self) -> bool
🔬This is a nightly-only experimental API. (panic_can_unwind
#92988)Available on non-crate feature ferrocene_certified
only.
pub fn can_unwind(&self) -> bool
panic_can_unwind
#92988)ferrocene_certified
only.Returns whether the panic handler is allowed to unwind the stack from the point where the panic occurred.
This is true for most kinds of panics with the exception of panics
caused by trying to unwind out of a Drop
implementation or a function
whose ABI does not support unwinding.
It is safe for a panic handler to unwind even when this function returns false, however this will simply cause the panic handler to be called again.
Trait Implementations§
Auto Trait Implementations§
impl<'a> Freeze for PanicInfo<'a>
impl<'a> RefUnwindSafe for PanicInfo<'a>
impl<'a> !Send for PanicInfo<'a>
impl<'a> !Sync for PanicInfo<'a>
impl<'a> Unpin for PanicInfo<'a>
impl<'a> UnwindSafe for PanicInfo<'a>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
ferrocene_certified
only.