Unregress error spans in constant errors

This commit is contained in:
Oliver Schneider 2018-02-06 14:04:35 +01:00
parent 421622d8f7
commit 5b698a1040
No known key found for this signature in database
GPG key ID: A69F8D225B3AD7D9
9 changed files with 26 additions and 20 deletions

View file

@ -155,7 +155,7 @@ impl<'a, 'gcx, 'tcx> ConstEvalErr<'tcx> {
ConstEvalErrDescription::Backtrace(miri, frames) => {
diag.span_label(self.span, format!("{}", miri));
for frame in frames {
diag.span_label(frame.span, format!("inside call to {}", frame.location));
diag.span_label(frame.span, format!("inside call to `{}`", frame.location));
}
}
}

View file

@ -789,7 +789,7 @@ impl<'a, 'tcx> PatternContext<'a, 'tcx> {
let field = Field::new(i);
let val = match cv.val {
ConstVal::Value(miri) => const_val_field(
self.tcx, self.param_env, instance, span,
self.tcx, self.param_env, instance,
variant_opt, field, miri, cv.ty,
).unwrap(),
_ => bug!("{:#?} is not a valid adt", cv),

View file

@ -61,7 +61,7 @@ pub fn eval_body_with_mir<'a, 'mir, 'tcx>(
mir: &'mir mir::Mir<'tcx>,
param_env: ty::ParamEnv<'tcx>,
) -> Option<(Value, Pointer, Ty<'tcx>)> {
let (res, ecx, _) = eval_body_and_ecx(tcx, cid, Some(mir), param_env);
let (res, ecx) = eval_body_and_ecx(tcx, cid, Some(mir), param_env);
match res {
Ok(val) => Some(val),
Err(mut err) => {
@ -76,7 +76,7 @@ pub fn eval_body<'a, 'tcx>(
cid: GlobalId<'tcx>,
param_env: ty::ParamEnv<'tcx>,
) -> Option<(Value, Pointer, Ty<'tcx>)> {
let (res, ecx, _) = eval_body_and_ecx(tcx, cid, None, param_env);
let (res, ecx) = eval_body_and_ecx(tcx, cid, None, param_env);
match res {
Ok(val) => Some(val),
Err(mut err) => {
@ -91,7 +91,7 @@ fn eval_body_and_ecx<'a, 'mir, 'tcx>(
cid: GlobalId<'tcx>,
mir: Option<&'mir mir::Mir<'tcx>>,
param_env: ty::ParamEnv<'tcx>,
) -> (EvalResult<'tcx, (Value, Pointer, Ty<'tcx>)>, EvalContext<'a, 'mir, 'tcx, CompileTimeEvaluator>, Span) {
) -> (EvalResult<'tcx, (Value, Pointer, Ty<'tcx>)>, EvalContext<'a, 'mir, 'tcx, CompileTimeEvaluator>) {
debug!("eval_body: {:?}, {:?}", cid, param_env);
let mut ecx = EvalContext::new(tcx, param_env, CompileTimeEvaluator, ());
// we start out with the best span we have
@ -155,7 +155,7 @@ fn eval_body_and_ecx<'a, 'mir, 'tcx>(
};
Ok((value, ptr, layout.ty))
})();
(res, ecx, span)
(res, ecx)
}
pub struct CompileTimeEvaluator;
@ -367,7 +367,6 @@ pub fn const_val_field<'a, 'tcx>(
tcx: TyCtxt<'a, 'tcx, 'tcx>,
param_env: ty::ParamEnv<'tcx>,
instance: ty::Instance<'tcx>,
span: Span,
variant: Option<usize>,
field: mir::Field,
value: Value,
@ -403,7 +402,7 @@ pub fn const_val_field<'a, 'tcx>(
ty,
})),
Err(err) => {
let trace = ecx.generate_stacktrace(None);
let (trace, span) = ecx.generate_stacktrace(None);
let err = ErrKind::Miri(err, trace);
Err(ConstEvalErr {
kind: err.into(),
@ -490,7 +489,7 @@ pub fn const_eval_provider<'a, 'tcx>(
}
};
let (res, ecx, span) = eval_body_and_ecx(tcx, cid, None, key.param_env);
let (res, ecx) = eval_body_and_ecx(tcx, cid, None, key.param_env);
res.map(|(miri_value, _, miri_ty)| {
tcx.mk_const(ty::Const {
val: ConstVal::Value(miri_value),
@ -500,7 +499,7 @@ pub fn const_eval_provider<'a, 'tcx>(
if tcx.is_static(def_id).is_some() {
ecx.report(&mut err, true, None);
}
let trace = ecx.generate_stacktrace(None);
let (trace, span) = ecx.generate_stacktrace(None);
let err = ErrKind::Miri(err, trace);
ConstEvalErr {
kind: err.into(),

View file

@ -1570,7 +1570,7 @@ impl<'a, 'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> EvalContext<'a, 'mir, 'tcx, M
Ok(())
}
pub fn generate_stacktrace(&self, explicit_span: Option<Span>) -> Vec<FrameInfo> {
pub fn generate_stacktrace(&self, explicit_span: Option<Span>) -> (Vec<FrameInfo>, Span) {
let mut last_span = None;
let mut frames = Vec::new();
// skip 1 because the last frame is just the environment of the constant
@ -1594,7 +1594,15 @@ impl<'a, 'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> EvalContext<'a, 'mir, 'tcx, M
};
frames.push(FrameInfo { span, location });
}
frames
let frame = self.frame();
let bb = &frame.mir.basic_blocks()[frame.block];
let span = if let Some(stmt) = bb.statements.get(frame.stmt) {
stmt.source_info.span
} else {
bb.terminator().source_info.span
};
trace!("generate stacktrace: {:#?}, {:?}", frames, explicit_span);
(frames, span)
}
pub fn report(&self, e: &mut EvalError, as_err: bool, explicit_span: Option<Span>) {
@ -1658,9 +1666,10 @@ impl<'a, 'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> EvalContext<'a, 'mir, 'tcx, M
"constant evaluation error",
)
};
let (frames, span) = self.generate_stacktrace(explicit_span);
err.span_label(span, e.to_string());
for FrameInfo { span, location } in self.generate_stacktrace(explicit_span) {
err.span_note(span, &format!("inside call to {}", location));
for FrameInfo { span, location } in frames {
err.span_note(span, &format!("inside call to `{}`", location));
}
err.emit();
} else {

View file

@ -80,7 +80,7 @@ impl<'b, 'a, 'tcx:'b> ConstPropagator<'b, 'a, 'tcx> {
let value = match self.tcx.const_eval(self.param_env.and(cid)) {
Ok(val) => val,
Err(err) => {
err.report(self.tcx, span, "constant propagated");
err.report(self.tcx, err.span, "constant propagated");
return None;
},
};

View file

@ -203,7 +203,6 @@ impl<'a, 'tcx> FunctionCx<'a, 'tcx> {
bx.tcx(),
ty::ParamEnv::empty(traits::Reveal::All),
self.instance,
constant.span,
None,
mir::Field::new(field as usize),
c,

View file

@ -10,6 +10,5 @@
static FOO: i32 = [][0];
//~^ ERROR E0080
//~| ERROR E0080
fn main() {}

View file

@ -18,6 +18,7 @@ const fn f(x: usize) -> usize {
for i in 0..x {
//~^ ERROR E0015
//~| ERROR E0019
//~| ERROR E0080
sum += i;
}
sum
@ -26,5 +27,4 @@ const fn f(x: usize) -> usize {
#[allow(unused_variables)]
fn main() {
let a : [i32; f(X)];
//~^ ERROR E0080
}

View file

@ -12,7 +12,7 @@
#![feature(const_fn)]
const fn a() -> usize { b() }
const fn b() -> usize { a() }
const ARR: [i32; a()] = [5; 6]; //~ ERROR constant evaluation error
const fn b() -> usize { a() } //~ ERROR constant evaluation error
const ARR: [i32; a()] = [5; 6];
fn main(){}