Skip to content

Commit 441b994

Browse files
author
Oliver Schneider
committed
simplify processing of ConstVal objects when not all variants are legal
1 parent 67256df commit 441b994

File tree

3 files changed

+51
-54
lines changed

3 files changed

+51
-54
lines changed

src/librustc/middle/const_eval.rs

Lines changed: 22 additions & 30 deletions
Original file line numberDiff line numberDiff line change
@@ -273,6 +273,22 @@ pub enum ConstVal {
273273
Tuple(ast::NodeId),
274274
}
275275

276+
impl ConstVal {
277+
pub fn description(&self) -> &'static str {
278+
match *self {
279+
Float(_) => "float",
280+
Int(i) if i < 0 => "negative integer",
281+
Int(_) => "positive integer",
282+
Uint(_) => "unsigned integer",
283+
Str(_) => "string literal",
284+
Binary(_) => "binary array",
285+
Bool(_) => "boolean",
286+
Struct(_) => "struct",
287+
Tuple(_) => "tuple",
288+
}
289+
}
290+
}
291+
276292
pub fn const_expr_to_pat(tcx: &ty::ctxt, expr: &Expr, span: Span) -> P<ast::Pat> {
277293
let pat = match expr.node {
278294
ast::ExprTup(ref exprs) =>
@@ -352,16 +368,8 @@ pub enum ErrKind {
352368
InvalidOpForFloats(ast::BinOp_),
353369
InvalidOpForIntUint(ast::BinOp_),
354370
InvalidOpForUintInt(ast::BinOp_),
355-
NegateOnString,
356-
NegateOnBoolean,
357-
NegateOnBinary,
358-
NegateOnStruct,
359-
NegateOnTuple,
360-
NotOnFloat,
361-
NotOnString,
362-
NotOnBinary,
363-
NotOnStruct,
364-
NotOnTuple,
371+
NegateOn(ConstVal),
372+
NotOn(ConstVal),
365373

366374
NegateWithOverflow(i64),
367375
AddiWithOverflow(i64, i64),
@@ -397,16 +405,8 @@ impl ConstEvalErr {
397405
InvalidOpForFloats(_) => "can't do this op on floats".into_cow(),
398406
InvalidOpForIntUint(..) => "can't do this op on an isize and usize".into_cow(),
399407
InvalidOpForUintInt(..) => "can't do this op on a usize and isize".into_cow(),
400-
NegateOnString => "negate on string".into_cow(),
401-
NegateOnBoolean => "negate on boolean".into_cow(),
402-
NegateOnBinary => "negate on binary literal".into_cow(),
403-
NegateOnStruct => "negate on struct".into_cow(),
404-
NegateOnTuple => "negate on tuple".into_cow(),
405-
NotOnFloat => "not on float or string".into_cow(),
406-
NotOnString => "not on float or string".into_cow(),
407-
NotOnBinary => "not on binary literal".into_cow(),
408-
NotOnStruct => "not on struct".into_cow(),
409-
NotOnTuple => "not on tuple".into_cow(),
408+
NegateOn(ref const_val) => format!("negate on {}", const_val.description()).into_cow(),
409+
NotOn(ref const_val) => format!("not on {}", const_val.description()).into_cow(),
410410

411411
NegateWithOverflow(..) => "attempted to negate with overflow".into_cow(),
412412
AddiWithOverflow(..) => "attempted to add with overflow".into_cow(),
@@ -754,23 +754,15 @@ pub fn eval_const_expr_with_substs<'tcx, S>(tcx: &ty::ctxt<'tcx>,
754754
}
755755
try!(const_uint_checked_neg(i, e, expr_uint_type))
756756
}
757-
Str(_) => signal!(e, NegateOnString),
758-
Bool(_) => signal!(e, NegateOnBoolean),
759-
Binary(_) => signal!(e, NegateOnBinary),
760-
Tuple(_) => signal!(e, NegateOnTuple),
761-
Struct(..) => signal!(e, NegateOnStruct),
757+
const_val => signal!(e, NegateOn(const_val)),
762758
}
763759
}
764760
ast::ExprUnary(ast::UnNot, ref inner) => {
765761
match try!(eval_const_expr_partial(tcx, &**inner, ety)) {
766762
Int(i) => Int(!i),
767763
Uint(i) => const_uint_not(i, expr_uint_type),
768764
Bool(b) => Bool(!b),
769-
Str(_) => signal!(e, NotOnString),
770-
Float(_) => signal!(e, NotOnFloat),
771-
Binary(_) => signal!(e, NotOnBinary),
772-
Tuple(_) => signal!(e, NotOnTuple),
773-
Struct(..) => signal!(e, NotOnStruct),
765+
const_val => signal!(e, NotOn(const_val)),
774766
}
775767
}
776768
ast::ExprBinary(op, ref a, ref b) => {

src/librustc/middle/ty.rs

Lines changed: 1 addition & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -6100,13 +6100,7 @@ impl<'tcx> ctxt<'tcx> {
61006100
let found = match val {
61016101
ConstVal::Uint(count) => return count as usize,
61026102
ConstVal::Int(count) if count >= 0 => return count as usize,
6103-
ConstVal::Int(_) => "negative integer",
6104-
ConstVal::Float(_) => "float",
6105-
ConstVal::Str(_) => "string",
6106-
ConstVal::Bool(_) => "boolean",
6107-
ConstVal::Binary(_) => "binary array",
6108-
ConstVal::Struct(..) => "struct",
6109-
ConstVal::Tuple(_) => "tuple"
6103+
const_val => const_val.description(),
61106104
};
61116105
span_err!(self.sess, count_expr.span, E0306,
61126106
"expected positive integer for repeat count, found {}",

src/test/compile-fail/repeat_count.rs

Lines changed: 28 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -12,47 +12,58 @@
1212

1313
fn main() {
1414
let n = 1;
15-
let a = [0; n]; //~ ERROR expected constant integer for repeat count, found variable
15+
let a = [0; n];
16+
//~^ ERROR expected constant integer for repeat count, found variable [E0307]
1617
let b = [0; ()];
17-
//~^ ERROR mismatched types
18-
//~| expected `usize`
19-
//~| found `()`
20-
//~| expected usize
21-
//~| found ()
22-
//~| ERROR expected positive integer for repeat count, found tuple
18+
//~^ ERROR mismatched types
19+
//~| expected `usize`
20+
//~| found `()`
21+
//~| expected usize
22+
//~| found ()) [E0308]
23+
//~| ERROR expected positive integer for repeat count, found tuple [E0306]
2324
let c = [0; true];
2425
//~^ ERROR mismatched types
2526
//~| expected `usize`
2627
//~| found `bool`
2728
//~| expected usize
28-
//~| found bool
29-
//~| ERROR expected positive integer for repeat count, found boolean
29+
//~| found bool) [E0308]
30+
//~| ERROR expected positive integer for repeat count, found boolean [E0306]
3031
let d = [0; 0.5];
3132
//~^ ERROR mismatched types
3233
//~| expected `usize`
3334
//~| found `_`
3435
//~| expected usize
35-
//~| found floating-point variable
36-
//~| ERROR expected positive integer for repeat count, found float
36+
//~| found floating-point variable) [E0308]
37+
//~| ERROR expected positive integer for repeat count, found float [E0306]
3738
let e = [0; "foo"];
3839
//~^ ERROR mismatched types
3940
//~| expected `usize`
4041
//~| found `&'static str`
4142
//~| expected usize
42-
//~| found &-ptr
43-
//~| ERROR expected positive integer for repeat count, found string
43+
//~| found &-ptr) [E0308]
44+
//~| ERROR expected positive integer for repeat count, found string literal [E0306]
4445
let f = [0; -4_isize];
4546
//~^ ERROR mismatched types
4647
//~| expected `usize`
4748
//~| found `isize`
4849
//~| expected usize
49-
//~| found isize
50-
//~| ERROR expected positive integer for repeat count, found negative integer
50+
//~| found isize) [E0308]
51+
//~| ERROR expected positive integer for repeat count, found negative integer [E0306]
5152
let f = [0_usize; -1_isize];
5253
//~^ ERROR mismatched types
5354
//~| expected `usize`
5455
//~| found `isize`
5556
//~| expected usize
56-
//~| found isize
57-
//~| ERROR expected positive integer for repeat count, found negative integer
57+
//~| found isize) [E0308]
58+
//~| ERROR expected positive integer for repeat count, found negative integer [E0306]
59+
struct G {
60+
g: (),
61+
}
62+
let g = [0; G { g: () }];
63+
//~^ ERROR mismatched types
64+
//~| expected `usize`
65+
//~| found `main::G`
66+
//~| expected usize
67+
//~| found struct `main::G`) [E0308]
68+
//~| ERROR expected positive integer for repeat count, found struct [E0306]
5869
}

0 commit comments

Comments
 (0)