Skip to content

Commit c8159b3

Browse files
committed
auto merge of #6473 : nikomatsakis/rust/issue-5967-rvalue-immutability, r=pcwalton
Simpler version of PR #5974 based on new borrowck.
2 parents cf8341f + 63d878f commit c8159b3

File tree

4 files changed

+83
-2
lines changed

4 files changed

+83
-2
lines changed

src/librustc/middle/borrowck/gather_loans/lifetime.rs

+14-1
Original file line numberDiff line numberDiff line change
@@ -93,7 +93,7 @@ impl GuaranteeLifetimeContext {
9393
let omit_root = (
9494
ptr_mutbl == m_imm &&
9595
self.bccx.is_subregion_of(self.loan_region, base_scope) &&
96-
base.mutbl.is_immutable() &&
96+
self.is_rvalue_or_immutable(base) &&
9797
!self.is_moved(base)
9898
);
9999

@@ -168,6 +168,19 @@ impl GuaranteeLifetimeContext {
168168
}
169169
}
170170

171+
fn is_rvalue_or_immutable(&self,
172+
cmt: mc::cmt) -> bool {
173+
//! We can omit the root on an `@T` value if the location
174+
//! that holds the box is either (1) an rvalue, in which case
175+
//! it is in a non-user-accessible temporary, or (2) an immutable
176+
//! lvalue.
177+
178+
cmt.mutbl.is_immutable() || match cmt.guarantor().cat {
179+
mc::cat_rvalue => true,
180+
_ => false
181+
}
182+
}
183+
171184
fn check_root(&self,
172185
cmt_deref: mc::cmt,
173186
cmt_base: mc::cmt,

src/librustc/middle/mem_categorization.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -551,7 +551,7 @@ pub impl mem_categorization_ctxt {
551551
id:elt.id(),
552552
span:elt.span(),
553553
cat:cat_rvalue,
554-
mutbl:McImmutable,
554+
mutbl:McDeclared,
555555
ty:expr_ty
556556
}
557557
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// Tests that rvalue lifetimes is limited to the enclosing trans
12+
// cleanup scope. It is unclear that this is the correct lifetime for
13+
// rvalues, but that's what it is right now.
14+
15+
struct Counter {
16+
value: uint
17+
}
18+
19+
impl Counter {
20+
fn new(v: uint) -> Counter {
21+
Counter {value: v}
22+
}
23+
24+
fn inc<'a>(&'a mut self) -> &'a mut Counter {
25+
self.value += 1;
26+
self
27+
}
28+
29+
fn get(&self) -> uint {
30+
self.value
31+
}
32+
}
33+
34+
pub fn main() {
35+
let v = Counter::new(22).inc().inc().get();
36+
//~^ ERROR borrowed value does not live long enough
37+
assert_eq!(v, 24);;
38+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
struct Counter {
12+
value: uint
13+
}
14+
15+
impl Counter {
16+
fn new(v: uint) -> Counter {
17+
Counter {value: v}
18+
}
19+
20+
fn get_and_inc(&mut self) -> uint {
21+
let v = self.value;
22+
self.value += 1;
23+
v
24+
}
25+
}
26+
27+
pub fn main() {
28+
let v = Counter::new(22).get_and_inc();
29+
assert_eq!(v, 22);
30+
}

0 commit comments

Comments
 (0)