about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2018-08-08 20:16:25 +0000
committerbors <bors@rust-lang.org>2018-08-08 20:16:25 +0000
commit62e4e08f4c00b8ae7a26d6aa792657f0fd846cec (patch)
treebf3738957299bd8eaecc8d6dfcbb294d2418e5d9 /src
parent376b60da8b65d7c4392f0a5e2b45c42e84bd01ce (diff)
parent8935f99833a3a89604ee7d6e584748ec41cb30ff (diff)
downloadrust-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.rs5
-rw-r--r--src/test/ui/const-eval/issue-53157.rs23
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());
+}