Enum rustc_middle::mir::interpret::error::InterpError
source · [−]pub enum InterpError<'tcx> {
UndefinedBehavior(UndefinedBehaviorInfo),
Unsupported(UnsupportedOpInfo),
InvalidProgram(InvalidProgramInfo<'tcx>),
ResourceExhaustion(ResourceExhaustionInfo),
MachineStop(Box<dyn MachineStopType>),
}
Variants
UndefinedBehavior(UndefinedBehaviorInfo)
The program caused undefined behavior.
Unsupported(UnsupportedOpInfo)
The program did something the interpreter does not support (some of these might be UB but the interpreter is not sure).
InvalidProgram(InvalidProgramInfo<'tcx>)
The program was invalid (ill-typed, bad MIR, not sufficiently monomorphized, …).
ResourceExhaustion(ResourceExhaustionInfo)
The program exhausted the interpreter’s resources (stack/heap too big, execution takes too long, …).
MachineStop(Box<dyn MachineStopType>)
Stop execution for a machine-controlled reason. This is never raised by the core engine itself.
Implementations
sourceimpl InterpError<'_>
impl InterpError<'_>
sourcepub fn formatted_string(&self) -> bool
pub fn formatted_string(&self) -> bool
Some errors do string formatting even if the error is never printed.
To avoid performance issues, there are places where we want to be sure to never raise these formatting errors,
so this method lets us detect them and bug!
on unexpected errors.
sourcepub fn is_hard_err(&self) -> bool
pub fn is_hard_err(&self) -> bool
Should this error be reported as a hard error, preventing compilation, or a soft error, causing a deny-by-default lint?
Trait Implementations
sourceimpl Debug for InterpError<'_>
impl Debug for InterpError<'_>
sourceimpl Display for InterpError<'_>
impl Display for InterpError<'_>
sourceimpl<'tcx> From<InterpError<'tcx>> for InterpErrorInfo<'tcx>
impl<'tcx> From<InterpError<'tcx>> for InterpErrorInfo<'tcx>
sourcefn from(kind: InterpError<'tcx>) -> Self
fn from(kind: InterpError<'tcx>) -> Self
Auto Trait Implementations
impl<'tcx> !RefUnwindSafe for InterpError<'tcx>
impl<'tcx> Send for InterpError<'tcx>
impl<'tcx> !Sync for InterpError<'tcx>
impl<'tcx> Unpin for InterpError<'tcx>
impl<'tcx> !UnwindSafe for InterpError<'tcx>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
sourceimpl<T, R> InternIteratorElement<T, R> for T
impl<T, R> InternIteratorElement<T, R> for T
type Output = R
fn intern_with<I, F>(iter: I, f: F) -> <T as InternIteratorElement<T, R>>::Outputwhere
I: Iterator<Item = T>,
F: FnOnce(&[T]) -> R,
sourceimpl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
sourceimpl<CTX, T> Value<CTX> for Twhere
CTX: DepContext,
impl<CTX, T> Value<CTX> for Twhere
CTX: DepContext,
default fn from_cycle_error(tcx: CTX) -> T
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
Layout
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference’s “Type Layout” chapter for details on type layout guarantees.
Size: 64 bytes
Size for each variant:
UndefinedBehavior
: 63 bytesUnsupported
: 39 bytesInvalidProgram
: 63 bytesResourceExhaustion
: 1 byteMachineStop
: 23 bytes