On this page
Struct std::panic::PanicInfo
pub struct PanicInfo<'a> { /* private fields */ }
A struct providing information about a panic.
PanicInfo
structure is passed to a panic hook set by the set_hook
function.
Examples
use std::panic;
panic::set_hook(Box::new(|panic_info| {
println!("panic occurred: {panic_info}");
}));
panic!("critical system failure");
Implementations
impl<'a> PanicInfo<'a>
pub fn payload(&self) -> &(dyn Any + Send + 'static)
Returns the payload associated with the panic.
This will commonly, but not always, be a &'static str
or String
.
Examples
use std::panic;
panic::set_hook(Box::new(|panic_info| {
if let Some(s) = panic_info.payload().downcast_ref::<&str>() {
println!("panic occurred: {s:?}");
} else {
println!("panic occurred");
}
}));
panic!("Normal panic");
pub fn message(&self) -> Option<&Arguments<'_>>
panic_info_message
#66745)
If the panic!
macro from the core
crate (not from std
) was used with a formatting string and some additional arguments, returns that message ready to be used for example with fmt::write
pub fn location(&self) -> Option<&Location<'_>>
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");
pub fn can_unwind(&self) -> bool
panic_can_unwind
#92988)
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
impl<'a> Debug for PanicInfo<'a>
fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>
impl Display for PanicInfo<'_>
Auto Trait Implementations
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
impl<T> Any for T
where
T: 'static + ?Sized,
impl<T> Borrow<T> for T
where
T: ?Sized,
impl<T> BorrowMut<T> for T
where
T: ?Sized,
impl<T> From<T> for T
fn from(t: T) -> T
Returns the argument unchanged.
impl<T, U> Into<U> for T
where
U: From<T>,
fn into(self) -> U
Calls U::from(self)
.
That is, this conversion is whatever the implementation of From<T> for U
chooses to do.
impl<T> ToString for T
where
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T
where
U: Into<T>,
type Error = Infallible
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto<U> for T
where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/panic/struct.PanicInfo.html