mirror of
https://github.com/rust-lang/rust.git
synced 2024-10-31 14:31:55 +00:00
Fix freezing of @mut Objects when passing as argument
This commit is contained in:
parent
0d817ee869
commit
afb20775d1
@ -121,9 +121,9 @@ impl Coerce {
|
||||
};
|
||||
}
|
||||
|
||||
ty::ty_trait(_, _, ty::RegionTraitStore(*), _, _) => {
|
||||
ty::ty_trait(_, _, ty::RegionTraitStore(*), m, _) => {
|
||||
return do self.unpack_actual_value(a) |sty_a| {
|
||||
self.coerce_borrowed_object(a, sty_a, b)
|
||||
self.coerce_borrowed_object(a, sty_a, b, m)
|
||||
};
|
||||
}
|
||||
|
||||
@ -274,7 +274,8 @@ impl Coerce {
|
||||
fn coerce_borrowed_object(&self,
|
||||
a: ty::t,
|
||||
sty_a: &ty::sty,
|
||||
b: ty::t) -> CoerceResult
|
||||
b: ty::t,
|
||||
b_mutbl: ast::mutability) -> CoerceResult
|
||||
{
|
||||
debug!("coerce_borrowed_object(a=%s, sty_a=%?, b=%s)",
|
||||
a.inf_str(self.infcx), sty_a,
|
||||
@ -282,16 +283,14 @@ impl Coerce {
|
||||
|
||||
let tcx = self.infcx.tcx;
|
||||
let r_a = self.infcx.next_region_var(Coercion(self.trace));
|
||||
let trt_mut;
|
||||
|
||||
let a_borrowed = match *sty_a {
|
||||
ty::ty_trait(_, _, ty::RegionTraitStore(_), _, _) => {
|
||||
return self.subtype(a, b);
|
||||
}
|
||||
ty::ty_trait(did, ref substs, _, m, b) => {
|
||||
trt_mut = m;
|
||||
ty::ty_trait(did, ref substs, _, _, b) => {
|
||||
ty::mk_trait(tcx, did, substs.clone(),
|
||||
ty::RegionTraitStore(r_a), m, b)
|
||||
ty::RegionTraitStore(r_a), b_mutbl, b)
|
||||
}
|
||||
_ => {
|
||||
return self.subtype(a, b);
|
||||
@ -301,7 +300,7 @@ impl Coerce {
|
||||
if_ok!(self.tys(a_borrowed, b));
|
||||
Ok(Some(@AutoDerefRef(AutoDerefRef {
|
||||
autoderefs: 0,
|
||||
autoref: Some(AutoBorrowObj(r_a, trt_mut))
|
||||
autoref: Some(AutoBorrowObj(r_a, b_mutbl))
|
||||
})))
|
||||
}
|
||||
|
||||
|
22
src/test/run-fail/borrowck-wg-fail-object-arg.rs
Normal file
22
src/test/run-fail/borrowck-wg-fail-object-arg.rs
Normal file
@ -0,0 +1,22 @@
|
||||
// error-pattern:borrowed
|
||||
|
||||
trait Foo {
|
||||
fn foo(&self, @mut int);
|
||||
}
|
||||
|
||||
impl Foo for int {
|
||||
fn foo(&self, x: @mut int) {
|
||||
*x += *self;
|
||||
}
|
||||
}
|
||||
|
||||
fn it_takes_two(f: &Foo, g: &mut Foo) {
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let x = @mut 3_i;
|
||||
let y = x as @mut Foo;
|
||||
let z = y;
|
||||
|
||||
it_takes_two(y, z);
|
||||
}
|
44
src/test/run-pass/objects-coerce-from-managed-to-borrowed.rs
Normal file
44
src/test/run-pass/objects-coerce-from-managed-to-borrowed.rs
Normal file
@ -0,0 +1,44 @@
|
||||
// Copyright 2012 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.
|
||||
|
||||
// Test that we can coerce an `@Object` to an `&Object`
|
||||
|
||||
trait Foo {
|
||||
fn foo(&self) -> uint;
|
||||
fn bar(&mut self) -> uint;
|
||||
}
|
||||
|
||||
impl Foo for uint {
|
||||
fn foo(&self) -> uint {
|
||||
*self
|
||||
}
|
||||
|
||||
fn bar(&mut self) -> uint {
|
||||
*self += 1;
|
||||
*self
|
||||
}
|
||||
}
|
||||
|
||||
fn do_it_mut(obj: &mut Foo) {
|
||||
let x = obj.bar();
|
||||
let y = obj.foo();
|
||||
assert_eq!(x, y);
|
||||
}
|
||||
|
||||
fn do_it_imm(obj: &Foo, v: uint) {
|
||||
let y = obj.foo();
|
||||
assert_eq!(v, y);
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let x = @mut 22u as @mut Foo;
|
||||
do_it_mut(x);
|
||||
do_it_imm(x, 23u);
|
||||
}
|
Loading…
Reference in New Issue
Block a user