logo

Struct std::panic::PanicInfo

1.10.0 · source ·
pub struct PanicInfo<'a> { /* private fields */ }
Expand description

A struct providing information about a panic.

PanicInfo structure is passed to a panic hook set by the set_hook function.

Examples

i
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");
Run

Implementations

source

impl<'a> PanicInfo<'a>

source

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
i
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");
Run
source

pub fn message(&self) -> Option<&Arguments<'_>>

🔬 This is a nightly-only experimental API. (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

source

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
i
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");
Run
source

pub fn can_unwind(&self) -> bool

🔬 This is a nightly-only experimental API. (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 true, however this will simply cause the panic handler to be called again.

Trait Implementations

source

impl<'a> Debug for PanicInfo<'a>

source

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

1.26.0 · source

impl Display for PanicInfo<'_>

source

fn fmt(&self, formatter: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more

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

source

impl<T> Any for T where
T: 'static + ?Sized,

source

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more

source

impl<T> Borrow<T> for T where
T: ?Sized,

const: unstable · source

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more

source

impl<T> BorrowMut<T> for T where
T: ?Sized,

const: unstable · source

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more

source

impl<T> From<T> for T

const: unstable · source

fn from(t: T) -> T

Returns the argument unchanged.

source

impl<T, U> Into<U> for T where
U: From<T>,

const: unstable · source

fn into(self) -> U

Calls U::from(self).

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

source

impl<T> ToString for T where
T: Display + ?Sized,

source

default fn to_string(&self) -> String

Converts the given value to a String. Read more

source

impl<T, U> TryFrom<U> for T where
U: Into<T>,

type Error = Infallible

The type returned in the event of a conversion error.

const: unstable · source

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.

source

impl<T, U> TryInto<U> for T where
U: TryFrom<T>,

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

const: unstable · source

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

AltStyle によって変換されたページ (->オリジナル) /