Enum miri::interpret::InvalidProgramInfo
source · pub enum InvalidProgramInfo<'tcx> {
TooGeneric,
AlreadyReported(ReportedErrorInfo),
Layout(LayoutError<'tcx>),
FnAbiAdjustForForeignAbi(AdjustForForeignAbiError),
ConstPropNonsense,
}
Expand description
Error information for when the program we executed turned out not to actually be a valid program. This cannot happen in stand-alone Miri, but it can happen during CTFE/ConstProp where we work on generic code or execution does not have all information available.
Variants§
TooGeneric
Resolution can fail if we are in a too generic context.
AlreadyReported(ReportedErrorInfo)
Abort in case errors are already reported.
Layout(LayoutError<'tcx>)
An error occurred during layout computation.
FnAbiAdjustForForeignAbi(AdjustForForeignAbiError)
An error occurred during FnAbi computation: the passed –target lacks FFI support
(which unfortunately typeck does not reject).
Not using FnAbiError
as that contains a nested LayoutError
.
ConstPropNonsense
We are runnning into a nonsense situation due to ConstProp violating our invariants.
Auto Trait Implementations§
impl<'tcx> !RefUnwindSafe for InvalidProgramInfo<'tcx>
impl<'tcx> Send for InvalidProgramInfo<'tcx>
impl<'tcx> Sync for InvalidProgramInfo<'tcx>
impl<'tcx> Unpin for InvalidProgramInfo<'tcx>
impl<'tcx> !UnwindSafe for InvalidProgramInfo<'tcx>
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
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: 24 bytes
Size for each variant:
TooGeneric
: 0 bytesAlreadyReported
: 9 bytesLayout
: 24 bytesFnAbiAdjustForForeignAbi
: 16 bytesConstPropNonsense
: 0 bytes