diff options
| author | bors <bors@rust-lang.org> | 2018-08-08 20:16:25 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2018-08-08 20:16:25 +0000 |
| commit | 62e4e08f4c00b8ae7a26d6aa792657f0fd846cec (patch) | |
| tree | bf3738957299bd8eaecc8d6dfcbb294d2418e5d9 /src | |
| parent | 376b60da8b65d7c4392f0a5e2b45c42e84bd01ce (diff) | |
| parent | 8935f99833a3a89604ee7d6e584748ec41cb30ff (diff) | |
| download | rust-62e4e08f4c00b8ae7a26d6aa792657f0fd846cec.tar.gz rust-62e4e08f4c00b8ae7a26d6aa792657f0fd846cec.zip | |
Auto merge of #53163 - oli-obk:const_prop_ice, r=nikomatsakis
Remove an overly pedantic and wrong assertion fixes #53157 fixes #53087
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_mir/transform/const_prop.rs | 5 | ||||
| -rw-r--r-- | src/test/ui/const-eval/issue-53157.rs | 23 |
2 files changed, 23 insertions, 5 deletions
diff --git a/src/librustc_mir/transform/const_prop.rs b/src/librustc_mir/transform/const_prop.rs index 05e51c5430d..5912eee758d 100644 --- a/src/librustc_mir/transform/const_prop.rs +++ b/src/librustc_mir/transform/const_prop.rs @@ -333,11 +333,6 @@ impl<'b, 'a, 'tcx:'b> ConstPropagator<'b, 'a, 'tcx> { ) -> Option<Const<'tcx>> { let span = source_info.span; match *rvalue { - // This branch exists for the sanity type check - Rvalue::Use(Operand::Constant(ref c)) => { - assert_eq!(c.ty, place_layout.ty); - self.eval_constant(c, source_info) - }, Rvalue::Use(ref op) => { self.eval_operand(op, source_info) }, diff --git a/src/test/ui/const-eval/issue-53157.rs b/src/test/ui/const-eval/issue-53157.rs new file mode 100644 index 00000000000..900847767e1 --- /dev/null +++ b/src/test/ui/const-eval/issue-53157.rs @@ -0,0 +1,23 @@ +// 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. + +// compile-pass + +macro_rules! m { + () => {{ + fn f(_: impl Sized) {} + f + }} +} + +fn main() { + fn f() -> impl Sized {}; + m!()(f()); +} |
