diff --git a/src/librustc/mir/interpret/error.rs b/src/librustc/mir/interpret/error.rs index b9c4d312adb7b..cfc91a98e44f5 100644 --- a/src/librustc/mir/interpret/error.rs +++ b/src/librustc/mir/interpret/error.rs @@ -229,6 +229,10 @@ pub enum InterpError<'tcx, O> { /// match an existing variant. MachineError(String), + /// Not actually an interprer error -- used to signal that execution has exited + /// with the given status code. + Exit(i32), + FunctionAbiMismatch(Abi, Abi), FunctionArgMismatch(Ty<'tcx>, Ty<'tcx>), FunctionRetMismatch(Ty<'tcx>, Ty<'tcx>), @@ -317,6 +321,8 @@ impl<'tcx, O> InterpError<'tcx, O> { use self::InterpError::*; match *self { MachineError(ref inner) => inner, + Exit(..) => + "exited", FunctionAbiMismatch(..) | FunctionArgMismatch(..) | FunctionRetMismatch(..) | FunctionArgCountMismatch => "tried to call a function through a function pointer of incompatible type", @@ -515,6 +521,8 @@ impl<'tcx, O: fmt::Debug> fmt::Debug for InterpError<'tcx, O> { write!(f, "the evaluated program panicked at '{}', {}:{}:{}", msg, file, line, col), InvalidDiscriminant(val) => write!(f, "encountered invalid enum discriminant {}", val), + Exit(code) => + write!(f, "exited with status code {}", code), _ => write!(f, "{}", self.description()), } } diff --git a/src/librustc_mir/transform/const_prop.rs b/src/librustc_mir/transform/const_prop.rs index e0ff71cbe52f8..b5bdc9e1c8c6e 100644 --- a/src/librustc_mir/transform/const_prop.rs +++ b/src/librustc_mir/transform/const_prop.rs @@ -148,6 +148,7 @@ impl<'a, 'mir, 'tcx> ConstPropagator<'a, 'mir, 'tcx> { match diagnostic.error { // don't report these, they make no sense in a const prop context | MachineError(_) + | Exit(_) // at runtime these transformations might make sense // FIXME: figure out the rules and start linting | FunctionAbiMismatch(..)