File tree 4 files changed +83
-2
lines changed
4 files changed +83
-2
lines changed Original file line number Diff line number Diff line change @@ -93,7 +93,7 @@ impl GuaranteeLifetimeContext {
93
93
let omit_root = (
94
94
ptr_mutbl == m_imm &&
95
95
self . bccx . is_subregion_of ( self . loan_region , base_scope) &&
96
- base . mutbl . is_immutable ( ) &&
96
+ self . is_rvalue_or_immutable ( base ) &&
97
97
!self . is_moved ( base)
98
98
) ;
99
99
@@ -168,6 +168,19 @@ impl GuaranteeLifetimeContext {
168
168
}
169
169
}
170
170
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
+
171
184
fn check_root ( & self ,
172
185
cmt_deref : mc:: cmt ,
173
186
cmt_base : mc:: cmt ,
Original file line number Diff line number Diff line change @@ -551,7 +551,7 @@ pub impl mem_categorization_ctxt {
551
551
id : elt. id ( ) ,
552
552
span : elt. span ( ) ,
553
553
cat : cat_rvalue,
554
- mutbl : McImmutable ,
554
+ mutbl : McDeclared ,
555
555
ty : expr_ty
556
556
}
557
557
}
Original file line number Diff line number Diff line change
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 number Diff line number Diff line change
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
+ }
You can’t perform that action at this time.
0 commit comments