summaryrefslogtreecommitdiffstats
path: root/src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs')
-rw-r--r--src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs87
1 files changed, 87 insertions, 0 deletions
diff --git a/src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs b/src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs
new file mode 100644
index 000000000..a8225f2fa
--- /dev/null
+++ b/src/test/ui/borrowck/borrowck-closures-mut-and-imm.rs
@@ -0,0 +1,87 @@
+// Tests that two closures cannot simultaneously have mutable
+// and immutable access to the variable. Issue #6801.
+
+fn get(x: &isize) -> isize {
+ *x
+}
+
+fn set(x: &mut isize) {
+ *x = 4;
+}
+
+
+
+fn a() {
+ let mut x = 3;
+ let c1 = || x = 4;
+ let c2 = || x * 5;
+ //~^ ERROR cannot borrow `x` as immutable because it is also borrowed as mutable
+ drop(c1);
+}
+
+fn b() {
+ let mut x = 3;
+ let c1 = || set(&mut x);
+ let c2 = || get(&x);
+ //~^ ERROR cannot borrow `x` as immutable because it is also borrowed as mutable
+ drop(c1);
+}
+
+fn c() {
+ let mut x = 3;
+ let c1 = || set(&mut x);
+ let c2 = || x * 5;
+ //~^ ERROR cannot borrow `x` as immutable because it is also borrowed as mutable
+ drop(c1);
+}
+
+fn d() {
+ let mut x = 3;
+ let c2 = || x * 5;
+ x = 5;
+ //~^ ERROR cannot assign to `x` because it is borrowed
+ drop(c2);
+}
+
+fn e() {
+ let mut x = 3;
+ let c1 = || get(&x);
+ x = 5;
+ //~^ ERROR cannot assign to `x` because it is borrowed
+ drop(c1);
+}
+
+fn f() {
+ let mut x: Box<_> = Box::new(3);
+ let c1 = || get(&*x);
+ *x = 5;
+ //~^ ERROR cannot assign to `*x` because it is borrowed
+ drop(c1);
+}
+
+fn g() {
+ struct Foo {
+ f: Box<isize>
+ }
+
+ let mut x: Box<_> = Box::new(Foo { f: Box::new(3) });
+ let c1 = || get(&*x.f);
+ *x.f = 5;
+ //~^ ERROR cannot assign to `*x.f` because it is borrowed
+ drop(c1);
+}
+
+fn h() {
+ struct Foo {
+ f: Box<isize>
+ }
+
+ let mut x: Box<_> = Box::new(Foo { f: Box::new(3) });
+ let c1 = || get(&*x.f);
+ let c2 = || *x.f = 5;
+ //~^ ERROR cannot borrow `x` as mutable because it is also borrowed as immutable
+ drop(c1);
+}
+
+fn main() {
+}