about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2013-10-25 12:56:20 -0700
committerbors <bors@rust-lang.org>2013-10-25 12:56:20 -0700
commitdcdcd309fb9baf06f835831c83b94a5ad1cdd568 (patch)
tree3469e4abfaf89f07d9319239abbabb7880c38c5f /src
parent953e56052fb6d82bfc2d38bd93049a62d427a703 (diff)
parentf04886b6bfae431ad9cdbed67caa8fd599af0289 (diff)
downloadrust-dcdcd309fb9baf06f835831c83b94a5ad1cdd568.tar.gz
rust-dcdcd309fb9baf06f835831c83b94a5ad1cdd568.zip
auto merge of #10067 : sanxiyn/rust/addr-of-bot, r=thestinger
Fix #5500.
Diffstat (limited to 'src')
-rw-r--r--src/librustc/middle/borrowck/gather_loans/mod.rs15
-rw-r--r--src/test/run-fail/addr-of-bot.rs15
2 files changed, 24 insertions, 6 deletions
diff --git a/src/librustc/middle/borrowck/gather_loans/mod.rs b/src/librustc/middle/borrowck/gather_loans/mod.rs
index 6c927794dc8..b5523c2ca5d 100644
--- a/src/librustc/middle/borrowck/gather_loans/mod.rs
+++ b/src/librustc/middle/borrowck/gather_loans/mod.rs
@@ -230,12 +230,15 @@ fn gather_loans_in_expr(this: &mut GatherLoanCtxt,
 
         // make sure that the thing we are pointing out stays valid
         // for the lifetime `scope_r` of the resulting ptr:
-        let scope_r = ty_region(tcx, ex.span, ty::expr_ty(tcx, ex));
-        this.guarantee_valid(ex.id,
-                             ex.span,
-                             base_cmt,
-                             LoanMutability::from_ast_mutability(mutbl),
-                             scope_r);
+        let expr_ty = ty::expr_ty(tcx, ex);
+        if !ty::type_is_bot(expr_ty) {
+            let scope_r = ty_region(tcx, ex.span, expr_ty);
+            this.guarantee_valid(ex.id,
+                                 ex.span,
+                                 base_cmt,
+                                 LoanMutability::from_ast_mutability(mutbl),
+                                 scope_r);
+        }
         visit::walk_expr(this, ex, ());
       }
 
diff --git a/src/test/run-fail/addr-of-bot.rs b/src/test/run-fail/addr-of-bot.rs
new file mode 100644
index 00000000000..45dbe11c76e
--- /dev/null
+++ b/src/test/run-fail/addr-of-bot.rs
@@ -0,0 +1,15 @@
+// Copyright 2013 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.
+
+// error-pattern:explicit failure
+
+fn main() {
+    &fail!()
+}