diff options
| author | bors <bors@rust-lang.org> | 2013-10-25 12:56:20 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2013-10-25 12:56:20 -0700 |
| commit | dcdcd309fb9baf06f835831c83b94a5ad1cdd568 (patch) | |
| tree | 3469e4abfaf89f07d9319239abbabb7880c38c5f /src | |
| parent | 953e56052fb6d82bfc2d38bd93049a62d427a703 (diff) | |
| parent | f04886b6bfae431ad9cdbed67caa8fd599af0289 (diff) | |
| download | rust-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.rs | 15 | ||||
| -rw-r--r-- | src/test/run-fail/addr-of-bot.rs | 15 |
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!() +} |
