Skip to content

Commit 6a62ad3

Browse files
committed
auto merge of #18862 : murarth/rust/issue-18566-test, r=alexcrichton
2 parents 5745e41 + 67a6944 commit 6a62ad3

File tree

1 file changed

+33
-0
lines changed

1 file changed

+33
-0
lines changed

src/test/compile-fail/issue-18566.rs

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
// Copyright 2014 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+
#![feature(tuple_indexing)]
12+
13+
struct MyPtr<'a>(&'a mut uint);
14+
impl<'a> Deref<uint> for MyPtr<'a> {
15+
fn deref<'b>(&'b self) -> &'b uint { self.0 }
16+
}
17+
18+
trait Tr {
19+
fn poke(&self, s: &mut uint);
20+
}
21+
22+
impl Tr for uint {
23+
fn poke(&self, s: &mut uint) {
24+
*s = 2;
25+
}
26+
}
27+
28+
fn main() {
29+
let s = &mut 1u;
30+
31+
MyPtr(s).poke(s);
32+
//~^ ERROR cannot borrow `*s` as mutable more than once at a time
33+
}

0 commit comments

Comments
 (0)