Skip to content

Commit

Permalink
Accept TyError in patterns to avoid ICE on bad input
Browse files Browse the repository at this point in the history
  • Loading branch information
estebank committed Jun 22, 2018
1 parent 6ec1b62 commit fe5710a
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 1 deletion.
14 changes: 13 additions & 1 deletion src/librustc_mir/hair/pattern/mod.rs
Expand Up @@ -505,7 +505,16 @@ impl<'a, 'tcx> PatternContext<'a, 'tcx> {
let def = self.tables.qpath_def(qpath, pat.hir_id);
let adt_def = match ty.sty {
ty::TyAdt(adt_def, _) => adt_def,
_ => span_bug!(pat.span, "tuple struct pattern not applied to an ADT"),
ty::TyError => { // Avoid ICE (#50585)
return Pattern {
span: pat.span,
ty,
kind: Box::new(PatternKind::Wild),
};
}
_ => span_bug!(pat.span,
"tuple struct pattern not applied to an ADT {:?}",
ty.sty),
};
let variant_def = adt_def.variant_of_def(def);

Expand Down Expand Up @@ -637,6 +646,9 @@ impl<'a, 'tcx> PatternContext<'a, 'tcx> {
let substs = match ty.sty {
ty::TyAdt(_, substs) |
ty::TyFnDef(_, substs) => substs,
ty::TyError => { // Avoid ICE (#50585)
return PatternKind::Wild;
}
_ => bug!("inappropriate type for def: {:?}", ty.sty),
};
PatternKind::Variant {
Expand Down
14 changes: 14 additions & 0 deletions src/test/ui/issue-50585.rs
@@ -0,0 +1,14 @@
// Copyright 2018 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.

fn main() {
|y: Vec<[(); for x in 0..2 {}]>| {};
//~^ ERROR mismatched types
}
14 changes: 14 additions & 0 deletions src/test/ui/issue-50585.stderr
@@ -0,0 +1,14 @@
error[E0308]: mismatched types
--> $DIR/issue-50585.rs:12:18
|
LL | fn main() {
| - expected `()` because of default return type
LL | |y: Vec<[(); for x in 0..2 {}]>| {};
| ^^^^^^^^^^^^^^^^ expected usize, found ()
|
= note: expected type `usize`
found type `()`

error: aborting due to previous error

For more information about this error, try `rustc --explain E0308`.

0 comments on commit fe5710a

Please sign in to comment.