summaryrefslogtreecommitdiffstats
path: root/src/test/ui/liveness
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
commit218caa410aa38c29984be31a5229b9fa717560ee (patch)
treec54bd55eeb6e4c508940a30e94c0032fbd45d677 /src/test/ui/liveness
parentReleasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz
rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/liveness')
-rw-r--r--src/test/ui/liveness/liveness-asm.rs45
-rw-r--r--src/test/ui/liveness/liveness-asm.stderr23
-rw-r--r--src/test/ui/liveness/liveness-assign-imm-local-after-ret.rs16
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.rs12
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.stderr12
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.rs12
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.stderr14
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.rs12
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.stderr15
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.rs12
-rw-r--r--src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.stderr15
-rw-r--r--src/test/ui/liveness/liveness-closure-require-ret.rs2
-rw-r--r--src/test/ui/liveness/liveness-closure-require-ret.stderr9
-rw-r--r--src/test/ui/liveness/liveness-consts.rs63
-rw-r--r--src/test/ui/liveness/liveness-consts.stderr63
-rw-r--r--src/test/ui/liveness/liveness-dead.rs39
-rw-r--r--src/test/ui/liveness/liveness-dead.stderr39
-rw-r--r--src/test/ui/liveness/liveness-derive.rs38
-rw-r--r--src/test/ui/liveness/liveness-derive.stderr21
-rw-r--r--src/test/ui/liveness/liveness-forgot-ret.rs6
-rw-r--r--src/test/ui/liveness/liveness-forgot-ret.stderr16
-rw-r--r--src/test/ui/liveness/liveness-issue-2163.rs8
-rw-r--r--src/test/ui/liveness/liveness-issue-2163.stderr12
-rw-r--r--src/test/ui/liveness/liveness-missing-ret2.rs7
-rw-r--r--src/test/ui/liveness/liveness-missing-ret2.stderr11
-rw-r--r--src/test/ui/liveness/liveness-move-call-arg.rs11
-rw-r--r--src/test/ui/liveness/liveness-move-call-arg.stderr26
-rw-r--r--src/test/ui/liveness/liveness-move-in-loop.rs17
-rw-r--r--src/test/ui/liveness/liveness-move-in-loop.stderr26
-rw-r--r--src/test/ui/liveness/liveness-move-in-while.rs13
-rw-r--r--src/test/ui/liveness/liveness-move-in-while.stderr46
-rw-r--r--src/test/ui/liveness/liveness-return-last-stmt-semi.rs18
-rw-r--r--src/test/ui/liveness/liveness-return-last-stmt-semi.stderr42
-rw-r--r--src/test/ui/liveness/liveness-unused.rs141
-rw-r--r--src/test/ui/liveness/liveness-unused.stderr116
-rw-r--r--src/test/ui/liveness/liveness-upvars.rs144
-rw-r--r--src/test/ui/liveness/liveness-upvars.stderr185
-rw-r--r--src/test/ui/liveness/liveness-use-after-move.rs8
-rw-r--r--src/test/ui/liveness/liveness-use-after-move.stderr20
-rw-r--r--src/test/ui/liveness/liveness-use-after-send.rs19
-rw-r--r--src/test/ui/liveness/liveness-use-after-send.stderr24
41 files changed, 0 insertions, 1378 deletions
diff --git a/src/test/ui/liveness/liveness-asm.rs b/src/test/ui/liveness/liveness-asm.rs
deleted file mode 100644
index ea5f033cb..000000000
--- a/src/test/ui/liveness/liveness-asm.rs
+++ /dev/null
@@ -1,45 +0,0 @@
-// Ensure inout asm! operands are marked as used by the liveness pass
-
-// only-x86_64
-// check-pass
-
-#![allow(dead_code)]
-#![warn(unused_assignments)]
-#![warn(unused_variables)]
-
-use std::arch::asm;
-
-// Test the single inout case
-unsafe fn f1(mut src: *const u8) {
- asm!("/*{0}*/", inout(reg) src); //~ WARN value assigned to `src` is never read
-}
-
-unsafe fn f2(mut src: *const u8) -> *const u8 {
- asm!("/*{0}*/", inout(reg) src);
- src
-}
-
-// Test the split inout case
-unsafe fn f3(mut src: *const u8) {
- asm!("/*{0}*/", inout(reg) src => src); //~ WARN value assigned to `src` is never read
-}
-
-unsafe fn f4(mut src: *const u8) -> *const u8 {
- asm!("/*{0}*/", inout(reg) src => src);
- src
-}
-
-// Tests the use of field projections
-struct S {
- field: *mut u8,
-}
-
-unsafe fn f5(src: &mut S) {
- asm!("/*{0}*/", inout(reg) src.field);
-}
-
-unsafe fn f6(src: &mut S) {
- asm!("/*{0}*/", inout(reg) src.field => src.field);
-}
-
-fn main() {}
diff --git a/src/test/ui/liveness/liveness-asm.stderr b/src/test/ui/liveness/liveness-asm.stderr
deleted file mode 100644
index 57d89e44d..000000000
--- a/src/test/ui/liveness/liveness-asm.stderr
+++ /dev/null
@@ -1,23 +0,0 @@
-warning: value assigned to `src` is never read
- --> $DIR/liveness-asm.rs:14:32
- |
-LL | asm!("/*{0}*/", inout(reg) src);
- | ^^^
- |
- = help: maybe it is overwritten before being read?
-note: the lint level is defined here
- --> $DIR/liveness-asm.rs:7:9
- |
-LL | #![warn(unused_assignments)]
- | ^^^^^^^^^^^^^^^^^^
-
-warning: value assigned to `src` is never read
- --> $DIR/liveness-asm.rs:24:39
- |
-LL | asm!("/*{0}*/", inout(reg) src => src);
- | ^^^
- |
- = help: maybe it is overwritten before being read?
-
-warning: 2 warnings emitted
-
diff --git a/src/test/ui/liveness/liveness-assign-imm-local-after-ret.rs b/src/test/ui/liveness/liveness-assign-imm-local-after-ret.rs
deleted file mode 100644
index b463f4368..000000000
--- a/src/test/ui/liveness/liveness-assign-imm-local-after-ret.rs
+++ /dev/null
@@ -1,16 +0,0 @@
-// run-pass
-
-#![allow(unreachable_code)]
-// pretty-expanded FIXME #23616
-
-#![allow(dead_code)]
-
-fn test() {
- let _v: isize;
- _v = 1;
- return;
- _v = 2;
-}
-
-pub fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.rs b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.rs
deleted file mode 100644
index 08911c5bd..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-fn test() {
- let v: isize;
- //~^ HELP consider making this binding mutable
- //~| SUGGESTION mut v
- loop {
- v = 1; //~ ERROR cannot assign twice to immutable variable `v`
- //~| NOTE cannot assign twice to immutable variable
- }
-}
-
-fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.stderr b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.stderr
deleted file mode 100644
index 66cdce7da..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-loop.stderr
+++ /dev/null
@@ -1,12 +0,0 @@
-error[E0384]: cannot assign twice to immutable variable `v`
- --> $DIR/liveness-assign-imm-local-in-loop.rs:6:9
- |
-LL | let v: isize;
- | - help: consider making this binding mutable: `mut v`
-...
-LL | v = 1;
- | ^^^^^ cannot assign twice to immutable variable
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0384`.
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.rs b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.rs
deleted file mode 100644
index 1752d9690..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-fn test() {
- let v: isize;
- //~^ HELP consider making this binding mutable
- //~| SUGGESTION mut v
- v = 2; //~ NOTE first assignment
- v += 1; //~ ERROR cannot assign twice to immutable variable `v`
- //~| NOTE cannot assign twice to immutable
- v.clone();
-}
-
-fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.stderr b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.stderr
deleted file mode 100644
index 5db9539cb..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-in-op-eq.stderr
+++ /dev/null
@@ -1,14 +0,0 @@
-error[E0384]: cannot assign twice to immutable variable `v`
- --> $DIR/liveness-assign-imm-local-in-op-eq.rs:6:5
- |
-LL | let v: isize;
- | - help: consider making this binding mutable: `mut v`
-...
-LL | v = 2;
- | ----- first assignment to `v`
-LL | v += 1;
- | ^^^^^^ cannot assign twice to immutable variable
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0384`.
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.rs b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.rs
deleted file mode 100644
index c9b16e439..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-fn test() {
- let b = Box::new(1); //~ NOTE first assignment
- //~| HELP consider making this binding mutable
- //~| SUGGESTION mut b
- drop(b);
- b = Box::new(2); //~ ERROR cannot assign twice to immutable variable `b`
- //~| NOTE cannot assign twice to immutable
- drop(b);
-}
-
-fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.stderr b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.stderr
deleted file mode 100644
index bb7e7e27a..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-drop.stderr
+++ /dev/null
@@ -1,15 +0,0 @@
-error[E0384]: cannot assign twice to immutable variable `b`
- --> $DIR/liveness-assign-imm-local-with-drop.rs:6:5
- |
-LL | let b = Box::new(1);
- | -
- | |
- | first assignment to `b`
- | help: consider making this binding mutable: `mut b`
-...
-LL | b = Box::new(2);
- | ^ cannot assign twice to immutable variable
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0384`.
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.rs b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.rs
deleted file mode 100644
index 4bb2db27a..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.rs
+++ /dev/null
@@ -1,12 +0,0 @@
-fn test() {
- let v: isize = 1; //~ NOTE first assignment
- //~| HELP consider making this binding mutable
- //~| SUGGESTION mut v
- v.clone();
- v = 2; //~ ERROR cannot assign twice to immutable variable `v`
- //~| NOTE cannot assign twice to immutable
- v.clone();
-}
-
-fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.stderr b/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.stderr
deleted file mode 100644
index 80458a70a..000000000
--- a/src/test/ui/liveness/liveness-assign/liveness-assign-imm-local-with-init.stderr
+++ /dev/null
@@ -1,15 +0,0 @@
-error[E0384]: cannot assign twice to immutable variable `v`
- --> $DIR/liveness-assign-imm-local-with-init.rs:6:5
- |
-LL | let v: isize = 1;
- | -
- | |
- | first assignment to `v`
- | help: consider making this binding mutable: `mut v`
-...
-LL | v = 2;
- | ^^^^^ cannot assign twice to immutable variable
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0384`.
diff --git a/src/test/ui/liveness/liveness-closure-require-ret.rs b/src/test/ui/liveness/liveness-closure-require-ret.rs
deleted file mode 100644
index b86d1fe4a..000000000
--- a/src/test/ui/liveness/liveness-closure-require-ret.rs
+++ /dev/null
@@ -1,2 +0,0 @@
-fn force<F>(f: F) -> isize where F: FnOnce() -> isize { f() }
-fn main() { println!("{}", force(|| {})); } //~ ERROR mismatched types
diff --git a/src/test/ui/liveness/liveness-closure-require-ret.stderr b/src/test/ui/liveness/liveness-closure-require-ret.stderr
deleted file mode 100644
index 07b2ef6cd..000000000
--- a/src/test/ui/liveness/liveness-closure-require-ret.stderr
+++ /dev/null
@@ -1,9 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/liveness-closure-require-ret.rs:2:37
- |
-LL | fn main() { println!("{}", force(|| {})); }
- | ^^ expected `isize`, found `()`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/src/test/ui/liveness/liveness-consts.rs b/src/test/ui/liveness/liveness-consts.rs
deleted file mode 100644
index 8fe2453ca..000000000
--- a/src/test/ui/liveness/liveness-consts.rs
+++ /dev/null
@@ -1,63 +0,0 @@
-// check-pass
-#![warn(unused)]
-#![allow(unreachable_code)]
-
-pub static A: i32 = {
- let mut i = 0;
- let mut a = 0; //~ WARN variable `a` is assigned to, but never used
- while i < 10 {
- i += 1;
- a += 1;
- }
- i
-};
-
-pub const B: u32 = {
- let mut b = 1;
- b += 1; //~ WARN value assigned to `b` is never read
- b = 42;
- b
-};
-
-pub enum E {
- V1 = {
- let e = 1; //~ WARN unused variable: `e`
- 1
- },
- V2 = {
- let _f = 10;
- 2
- }
-}
-
-pub fn f(x: [u8; { let s = 17; 100 }]) -> [u8; { let z = 18; 100 }] {
- //~^ WARN unused variable: `s`
- //~| WARN unused variable: `z`
- x
-}
-
-pub trait T {
- const T: usize = {
- let mut t = 10;
- t = t + t; //~ WARN value assigned to `t` is never read
- 20
- };
-}
-
-impl T for String {
- const T: usize = {
- let w = 10; //~ WARN unused variable: `w`
- loop {
- break;
- let _ = w;
- }
- 44
- };
-}
-
-fn main() {
- let _ = [(); {
- let z = 42; //~ WARN unused variable: `z`
- 35
- }];
-}
diff --git a/src/test/ui/liveness/liveness-consts.stderr b/src/test/ui/liveness/liveness-consts.stderr
deleted file mode 100644
index 6199ea96c..000000000
--- a/src/test/ui/liveness/liveness-consts.stderr
+++ /dev/null
@@ -1,63 +0,0 @@
-warning: variable `a` is assigned to, but never used
- --> $DIR/liveness-consts.rs:7:13
- |
-LL | let mut a = 0;
- | ^
- |
- = note: consider using `_a` instead
-note: the lint level is defined here
- --> $DIR/liveness-consts.rs:2:9
- |
-LL | #![warn(unused)]
- | ^^^^^^
- = note: `#[warn(unused_variables)]` implied by `#[warn(unused)]`
-
-warning: value assigned to `b` is never read
- --> $DIR/liveness-consts.rs:17:5
- |
-LL | b += 1;
- | ^
- |
- = help: maybe it is overwritten before being read?
- = note: `#[warn(unused_assignments)]` implied by `#[warn(unused)]`
-
-warning: unused variable: `e`
- --> $DIR/liveness-consts.rs:24:13
- |
-LL | let e = 1;
- | ^ help: if this is intentional, prefix it with an underscore: `_e`
-
-warning: unused variable: `s`
- --> $DIR/liveness-consts.rs:33:24
- |
-LL | pub fn f(x: [u8; { let s = 17; 100 }]) -> [u8; { let z = 18; 100 }] {
- | ^ help: if this is intentional, prefix it with an underscore: `_s`
-
-warning: unused variable: `z`
- --> $DIR/liveness-consts.rs:33:55
- |
-LL | pub fn f(x: [u8; { let s = 17; 100 }]) -> [u8; { let z = 18; 100 }] {
- | ^ help: if this is intentional, prefix it with an underscore: `_z`
-
-warning: value assigned to `t` is never read
- --> $DIR/liveness-consts.rs:42:9
- |
-LL | t = t + t;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: unused variable: `w`
- --> $DIR/liveness-consts.rs:49:13
- |
-LL | let w = 10;
- | ^ help: if this is intentional, prefix it with an underscore: `_w`
-
-warning: unused variable: `z`
- --> $DIR/liveness-consts.rs:60:13
- |
-LL | let z = 42;
- | ^ help: if this is intentional, prefix it with an underscore: `_z`
-
-warning: 8 warnings emitted
-
diff --git a/src/test/ui/liveness/liveness-dead.rs b/src/test/ui/liveness/liveness-dead.rs
deleted file mode 100644
index 004663c85..000000000
--- a/src/test/ui/liveness/liveness-dead.rs
+++ /dev/null
@@ -1,39 +0,0 @@
-#![allow(dead_code)]
-#![deny(unused_assignments)]
-
-fn f1(x: &mut isize) {
- *x = 1; // no error
-}
-
-fn f2() {
- let mut x: isize = 3; //~ ERROR: value assigned to `x` is never read
- x = 4;
- x.clone();
-}
-
-fn f3() {
- let mut x: isize = 3;
- x.clone();
- x = 4; //~ ERROR: value assigned to `x` is never read
-}
-
-fn f4(mut x: i32) { //~ ERROR: value passed to `x` is never read
- x = 4;
- x.clone();
-}
-
-fn f5(mut x: i32) {
- x.clone();
- x = 4; //~ ERROR: value assigned to `x` is never read
-}
-
-// #22630
-fn f6() {
- let mut done = false;
- while !done {
- done = true; // no error
- continue;
- }
-}
-
-fn main() {}
diff --git a/src/test/ui/liveness/liveness-dead.stderr b/src/test/ui/liveness/liveness-dead.stderr
deleted file mode 100644
index de6d5bd99..000000000
--- a/src/test/ui/liveness/liveness-dead.stderr
+++ /dev/null
@@ -1,39 +0,0 @@
-error: value assigned to `x` is never read
- --> $DIR/liveness-dead.rs:9:13
- |
-LL | let mut x: isize = 3;
- | ^
- |
- = help: maybe it is overwritten before being read?
-note: the lint level is defined here
- --> $DIR/liveness-dead.rs:2:9
- |
-LL | #![deny(unused_assignments)]
- | ^^^^^^^^^^^^^^^^^^
-
-error: value assigned to `x` is never read
- --> $DIR/liveness-dead.rs:17:5
- |
-LL | x = 4;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-error: value passed to `x` is never read
- --> $DIR/liveness-dead.rs:20:11
- |
-LL | fn f4(mut x: i32) {
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-error: value assigned to `x` is never read
- --> $DIR/liveness-dead.rs:27:5
- |
-LL | x = 4;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-error: aborting due to 4 previous errors
-
diff --git a/src/test/ui/liveness/liveness-derive.rs b/src/test/ui/liveness/liveness-derive.rs
deleted file mode 100644
index 1921d0d72..000000000
--- a/src/test/ui/liveness/liveness-derive.rs
+++ /dev/null
@@ -1,38 +0,0 @@
-// Test for interaction between #[automatically_derived] attribute used by
-// built-in derives and lints generated by liveness pass.
-//
-// edition:2018
-// check-pass
-#![warn(unused)]
-
-pub trait T: Sized {
- const N: usize;
- fn t(&self) -> Self;
-}
-
-impl T for u32 {
- const N: usize = {
- let a = 0; //~ WARN unused variable: `a`
- 4
- };
-
- fn t(&self) -> Self {
- let b = 16; //~ WARN unused variable: `b`
- 0
- }
-}
-
-#[automatically_derived]
-impl T for i32 {
- const N: usize = {
- let c = 0;
- 4
- };
-
- fn t(&self) -> Self {
- let d = 17;
- 0
- }
-}
-
-fn main() {}
diff --git a/src/test/ui/liveness/liveness-derive.stderr b/src/test/ui/liveness/liveness-derive.stderr
deleted file mode 100644
index c03d90991..000000000
--- a/src/test/ui/liveness/liveness-derive.stderr
+++ /dev/null
@@ -1,21 +0,0 @@
-warning: unused variable: `a`
- --> $DIR/liveness-derive.rs:15:13
- |
-LL | let a = 0;
- | ^ help: if this is intentional, prefix it with an underscore: `_a`
- |
-note: the lint level is defined here
- --> $DIR/liveness-derive.rs:6:9
- |
-LL | #![warn(unused)]
- | ^^^^^^
- = note: `#[warn(unused_variables)]` implied by `#[warn(unused)]`
-
-warning: unused variable: `b`
- --> $DIR/liveness-derive.rs:20:13
- |
-LL | let b = 16;
- | ^ help: if this is intentional, prefix it with an underscore: `_b`
-
-warning: 2 warnings emitted
-
diff --git a/src/test/ui/liveness/liveness-forgot-ret.rs b/src/test/ui/liveness/liveness-forgot-ret.rs
deleted file mode 100644
index b8c2bc734..000000000
--- a/src/test/ui/liveness/liveness-forgot-ret.rs
+++ /dev/null
@@ -1,6 +0,0 @@
-fn god_exists(a: isize) -> bool { return god_exists(a); }
-
-fn f(a: isize) -> isize { if god_exists(a) { return 5; }; }
-//~^ ERROR mismatched types
-
-fn main() { f(12); }
diff --git a/src/test/ui/liveness/liveness-forgot-ret.stderr b/src/test/ui/liveness/liveness-forgot-ret.stderr
deleted file mode 100644
index ddbdbdb0f..000000000
--- a/src/test/ui/liveness/liveness-forgot-ret.stderr
+++ /dev/null
@@ -1,16 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/liveness-forgot-ret.rs:3:19
- |
-LL | fn f(a: isize) -> isize { if god_exists(a) { return 5; }; }
- | - ^^^^^ expected `isize`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
- |
-help: consider returning the local binding `a`
- |
-LL | fn f(a: isize) -> isize { if god_exists(a) { return 5; }; a }
- | +
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/src/test/ui/liveness/liveness-issue-2163.rs b/src/test/ui/liveness/liveness-issue-2163.rs
deleted file mode 100644
index a632b5b9c..000000000
--- a/src/test/ui/liveness/liveness-issue-2163.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-use std::vec::Vec;
-
-fn main() {
- let a: Vec<isize> = Vec::new();
- a.iter().all(|_| -> bool {
- //~^ ERROR mismatched types
- });
-}
diff --git a/src/test/ui/liveness/liveness-issue-2163.stderr b/src/test/ui/liveness/liveness-issue-2163.stderr
deleted file mode 100644
index 2adc2d438..000000000
--- a/src/test/ui/liveness/liveness-issue-2163.stderr
+++ /dev/null
@@ -1,12 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/liveness-issue-2163.rs:5:30
- |
-LL | a.iter().all(|_| -> bool {
- | ______________________________^
-LL | |
-LL | | });
- | |_____^ expected `bool`, found `()`
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/src/test/ui/liveness/liveness-missing-ret2.rs b/src/test/ui/liveness/liveness-missing-ret2.rs
deleted file mode 100644
index a18669f72..000000000
--- a/src/test/ui/liveness/liveness-missing-ret2.rs
+++ /dev/null
@@ -1,7 +0,0 @@
-fn f() -> isize { //~ ERROR mismatched types
- // Make sure typestate doesn't interpret this match expression as
- // the function result
- match true { true => { } _ => {} };
-}
-
-fn main() { }
diff --git a/src/test/ui/liveness/liveness-missing-ret2.stderr b/src/test/ui/liveness/liveness-missing-ret2.stderr
deleted file mode 100644
index afdb733cd..000000000
--- a/src/test/ui/liveness/liveness-missing-ret2.stderr
+++ /dev/null
@@ -1,11 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/liveness-missing-ret2.rs:1:11
- |
-LL | fn f() -> isize {
- | - ^^^^^ expected `isize`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/src/test/ui/liveness/liveness-move-call-arg.rs b/src/test/ui/liveness/liveness-move-call-arg.rs
deleted file mode 100644
index 1bc2ea6b9..000000000
--- a/src/test/ui/liveness/liveness-move-call-arg.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-fn take(_x: Box<isize>) {}
-
-
-fn main() {
-
- let x: Box<isize> = Box::new(25);
-
- loop {
- take(x); //~ ERROR use of moved value: `x`
- }
-}
diff --git a/src/test/ui/liveness/liveness-move-call-arg.stderr b/src/test/ui/liveness/liveness-move-call-arg.stderr
deleted file mode 100644
index d14cd6cb4..000000000
--- a/src/test/ui/liveness/liveness-move-call-arg.stderr
+++ /dev/null
@@ -1,26 +0,0 @@
-error[E0382]: use of moved value: `x`
- --> $DIR/liveness-move-call-arg.rs:9:14
- |
-LL | let x: Box<isize> = Box::new(25);
- | - move occurs because `x` has type `Box<isize>`, which does not implement the `Copy` trait
-LL |
-LL | loop {
- | ---- inside of this loop
-LL | take(x);
- | ^ value moved here, in previous iteration of loop
- |
-note: consider changing this parameter type in function `take` to borrow instead if owning the value isn't necessary
- --> $DIR/liveness-move-call-arg.rs:1:13
- |
-LL | fn take(_x: Box<isize>) {}
- | ---- ^^^^^^^^^^ this parameter takes ownership of the value
- | |
- | in this function
-help: consider cloning the value if the performance cost is acceptable
- |
-LL | take(x.clone());
- | ++++++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0382`.
diff --git a/src/test/ui/liveness/liveness-move-in-loop.rs b/src/test/ui/liveness/liveness-move-in-loop.rs
deleted file mode 100644
index 064be14d6..000000000
--- a/src/test/ui/liveness/liveness-move-in-loop.rs
+++ /dev/null
@@ -1,17 +0,0 @@
-fn main() {
-
- let y: Box<isize> = 42.into();
- let mut x: Box<isize>;
-
- loop {
- println!("{}", y);
- loop {
- loop {
- loop {
- x = y; //~ ERROR use of moved value
- x.clone();
- }
- }
- }
- }
-}
diff --git a/src/test/ui/liveness/liveness-move-in-loop.stderr b/src/test/ui/liveness/liveness-move-in-loop.stderr
deleted file mode 100644
index a060914f1..000000000
--- a/src/test/ui/liveness/liveness-move-in-loop.stderr
+++ /dev/null
@@ -1,26 +0,0 @@
-error[E0382]: use of moved value: `y`
- --> $DIR/liveness-move-in-loop.rs:11:25
- |
-LL | let y: Box<isize> = 42.into();
- | - move occurs because `y` has type `Box<isize>`, which does not implement the `Copy` trait
-...
-LL | loop {
- | ---- inside of this loop
-LL | println!("{}", y);
-LL | loop {
- | ---- inside of this loop
-LL | loop {
- | ---- inside of this loop
-LL | loop {
- | ---- inside of this loop
-LL | x = y;
- | ^ value moved here, in previous iteration of loop
- |
-help: consider cloning the value if the performance cost is acceptable
- |
-LL | x = y.clone();
- | ++++++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0382`.
diff --git a/src/test/ui/liveness/liveness-move-in-while.rs b/src/test/ui/liveness/liveness-move-in-while.rs
deleted file mode 100644
index 7c0cd282c..000000000
--- a/src/test/ui/liveness/liveness-move-in-while.rs
+++ /dev/null
@@ -1,13 +0,0 @@
-fn main() {
-
- let y: Box<isize> = 42.into();
- let mut x: Box<isize>;
-
- loop {
- println!("{}", y); //~ ERROR borrow of moved value: `y`
- while true { while true { while true { x = y; x.clone(); } } }
- //~^ WARN denote infinite loops with
- //~| WARN denote infinite loops with
- //~| WARN denote infinite loops with
- }
-}
diff --git a/src/test/ui/liveness/liveness-move-in-while.stderr b/src/test/ui/liveness/liveness-move-in-while.stderr
deleted file mode 100644
index 4dff7447d..000000000
--- a/src/test/ui/liveness/liveness-move-in-while.stderr
+++ /dev/null
@@ -1,46 +0,0 @@
-warning: denote infinite loops with `loop { ... }`
- --> $DIR/liveness-move-in-while.rs:8:9
- |
-LL | while true { while true { while true { x = y; x.clone(); } } }
- | ^^^^^^^^^^ help: use `loop`
- |
- = note: `#[warn(while_true)]` on by default
-
-warning: denote infinite loops with `loop { ... }`
- --> $DIR/liveness-move-in-while.rs:8:22
- |
-LL | while true { while true { while true { x = y; x.clone(); } } }
- | ^^^^^^^^^^ help: use `loop`
-
-warning: denote infinite loops with `loop { ... }`
- --> $DIR/liveness-move-in-while.rs:8:35
- |
-LL | while true { while true { while true { x = y; x.clone(); } } }
- | ^^^^^^^^^^ help: use `loop`
-
-error[E0382]: borrow of moved value: `y`
- --> $DIR/liveness-move-in-while.rs:7:24
- |
-LL | let y: Box<isize> = 42.into();
- | - move occurs because `y` has type `Box<isize>`, which does not implement the `Copy` trait
-...
-LL | loop {
- | ---- inside of this loop
-LL | println!("{}", y);
- | ^ value borrowed here after move
-LL | while true { while true { while true { x = y; x.clone(); } } }
- | ---------- ---------- ---------- - value moved here, in previous iteration of loop
- | | | |
- | | | inside of this loop
- | | inside of this loop
- | inside of this loop
- |
- = note: this error originates in the macro `$crate::format_args_nl` which comes from the expansion of the macro `println` (in Nightly builds, run with -Z macro-backtrace for more info)
-help: consider cloning the value if the performance cost is acceptable
- |
-LL | while true { while true { while true { x = y.clone(); x.clone(); } } }
- | ++++++++
-
-error: aborting due to previous error; 3 warnings emitted
-
-For more information about this error, try `rustc --explain E0382`.
diff --git a/src/test/ui/liveness/liveness-return-last-stmt-semi.rs b/src/test/ui/liveness/liveness-return-last-stmt-semi.rs
deleted file mode 100644
index dff859429..000000000
--- a/src/test/ui/liveness/liveness-return-last-stmt-semi.rs
+++ /dev/null
@@ -1,18 +0,0 @@
-// regression test for #8005
-
-macro_rules! test { () => { fn foo() -> i32 { 1; } } }
- //~^ ERROR mismatched types
-
-fn no_return() -> i32 {} //~ ERROR mismatched types
-
-fn bar(x: u32) -> u32 { //~ ERROR mismatched types
- x * 2;
-}
-
-fn baz(x: u64) -> u32 { //~ ERROR mismatched types
- x * 2;
-}
-
-fn main() {
- test!();
-}
diff --git a/src/test/ui/liveness/liveness-return-last-stmt-semi.stderr b/src/test/ui/liveness/liveness-return-last-stmt-semi.stderr
deleted file mode 100644
index de0843aa6..000000000
--- a/src/test/ui/liveness/liveness-return-last-stmt-semi.stderr
+++ /dev/null
@@ -1,42 +0,0 @@
-error[E0308]: mismatched types
- --> $DIR/liveness-return-last-stmt-semi.rs:6:19
- |
-LL | fn no_return() -> i32 {}
- | --------- ^^^ expected `i32`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
-
-error[E0308]: mismatched types
- --> $DIR/liveness-return-last-stmt-semi.rs:8:19
- |
-LL | fn bar(x: u32) -> u32 {
- | --- ^^^ expected `u32`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
-LL | x * 2;
- | - help: remove this semicolon to return this value
-
-error[E0308]: mismatched types
- --> $DIR/liveness-return-last-stmt-semi.rs:12:19
- |
-LL | fn baz(x: u64) -> u32 {
- | --- ^^^ expected `u32`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
-
-error[E0308]: mismatched types
- --> $DIR/liveness-return-last-stmt-semi.rs:3:41
- |
-LL | macro_rules! test { () => { fn foo() -> i32 { 1; } } }
- | --- ^^^ expected `i32`, found `()`
- | |
- | implicitly returns `()` as its body has no tail or `return` expression
-...
-LL | test!();
- | ------- in this macro invocation
- |
- = note: this error originates in the macro `test` (in Nightly builds, run with -Z macro-backtrace for more info)
-
-error: aborting due to 4 previous errors
-
-For more information about this error, try `rustc --explain E0308`.
diff --git a/src/test/ui/liveness/liveness-unused.rs b/src/test/ui/liveness/liveness-unused.rs
deleted file mode 100644
index 9c7be15fc..000000000
--- a/src/test/ui/liveness/liveness-unused.rs
+++ /dev/null
@@ -1,141 +0,0 @@
-#![warn(unused)]
-#![deny(unused_variables)]
-#![deny(unused_assignments)]
-#![allow(dead_code, non_camel_case_types, trivial_numeric_casts)]
-
-use std::ops::AddAssign;
-
-fn f1(x: isize) {
- //~^ ERROR unused variable: `x`
-}
-
-fn f1b(x: &mut isize) {
- //~^ ERROR unused variable: `x`
-}
-
-#[allow(unused_variables)]
-fn f1c(x: isize) {}
-
-fn f1d() {
- let x: isize;
- //~^ ERROR unused variable: `x`
-}
-
-fn f2() {
- let x = 3;
- //~^ ERROR unused variable: `x`
-}
-
-fn f3() {
- let mut x = 3;
- //~^ ERROR variable `x` is assigned to, but never used
- x += 4;
- //~^ ERROR value assigned to `x` is never read
-}
-
-fn f3b() {
- let mut z = 3;
- //~^ ERROR variable `z` is assigned to, but never used
- loop {
- z += 4;
- }
-}
-
-#[allow(unused_variables)]
-fn f3c() {
- let mut z = 3;
- loop { z += 4; }
-}
-
-#[allow(unused_variables)]
-#[allow(unused_assignments)]
-fn f3d() {
- let mut x = 3;
- x += 4;
-}
-
-fn f4() {
- match Some(3) {
- Some(i) => {
- //~^ ERROR unused variable: `i`
- }
- None => {}
- }
-}
-
-enum tri {
- a(isize), b(isize), c(isize)
-}
-
-fn f4b() -> isize {
- match tri::a(3) {
- tri::a(i) | tri::b(i) | tri::c(i) => {
- i
- }
- }
-}
-
-fn f5a() {
- for x in 1..10 { }
- //~^ ERROR unused variable: `x`
-}
-
-fn f5b() {
- for (x, _) in [1, 2, 3].iter().enumerate() { }
- //~^ ERROR unused variable: `x`
-}
-
-fn f5c() {
- for (_, x) in [1, 2, 3].iter().enumerate() {
- //~^ ERROR unused variable: `x`
- continue;
- drop(*x as i32); //~ WARNING unreachable statement
- }
-}
-
-struct View<'a>(&'a mut [i32]);
-
-impl<'a> AddAssign<i32> for View<'a> {
- fn add_assign(&mut self, rhs: i32) {
- for lhs in self.0.iter_mut() {
- *lhs += rhs;
- }
- }
-}
-
-fn f6() {
- let mut array = [1, 2, 3];
- let mut v = View(&mut array);
-
- // ensure an error shows up for x even if lhs of an overloaded add assign
-
- let x;
- //~^ ERROR variable `x` is assigned to, but never used
-
- *({
- x = 0; //~ ERROR value assigned to `x` is never read
- &mut v
- }) += 1;
-}
-
-
-struct MutRef<'a>(&'a mut i32);
-
-impl<'a> AddAssign<i32> for MutRef<'a> {
- fn add_assign(&mut self, rhs: i32) {
- *self.0 += rhs;
- }
-}
-
-fn f7() {
- let mut a = 1;
- {
- // `b` does not trigger unused_variables
- let mut b = MutRef(&mut a);
- b += 1;
- }
- drop(a);
-}
-
-fn main() {
-}
diff --git a/src/test/ui/liveness/liveness-unused.stderr b/src/test/ui/liveness/liveness-unused.stderr
deleted file mode 100644
index f6c478ddb..000000000
--- a/src/test/ui/liveness/liveness-unused.stderr
+++ /dev/null
@@ -1,116 +0,0 @@
-warning: unreachable statement
- --> $DIR/liveness-unused.rs:92:9
- |
-LL | continue;
- | -------- any code following this expression is unreachable
-LL | drop(*x as i32);
- | ^^^^^^^^^^^^^^^^ unreachable statement
- |
-note: the lint level is defined here
- --> $DIR/liveness-unused.rs:1:9
- |
-LL | #![warn(unused)]
- | ^^^^^^
- = note: `#[warn(unreachable_code)]` implied by `#[warn(unused)]`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:8:7
- |
-LL | fn f1(x: isize) {
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
- |
-note: the lint level is defined here
- --> $DIR/liveness-unused.rs:2:9
- |
-LL | #![deny(unused_variables)]
- | ^^^^^^^^^^^^^^^^
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:12:8
- |
-LL | fn f1b(x: &mut isize) {
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:20:9
- |
-LL | let x: isize;
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:25:9
- |
-LL | let x = 3;
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: variable `x` is assigned to, but never used
- --> $DIR/liveness-unused.rs:30:13
- |
-LL | let mut x = 3;
- | ^
- |
- = note: consider using `_x` instead
-
-error: value assigned to `x` is never read
- --> $DIR/liveness-unused.rs:32:5
- |
-LL | x += 4;
- | ^
- |
- = help: maybe it is overwritten before being read?
-note: the lint level is defined here
- --> $DIR/liveness-unused.rs:3:9
- |
-LL | #![deny(unused_assignments)]
- | ^^^^^^^^^^^^^^^^^^
-
-error: variable `z` is assigned to, but never used
- --> $DIR/liveness-unused.rs:37:13
- |
-LL | let mut z = 3;
- | ^
- |
- = note: consider using `_z` instead
-
-error: unused variable: `i`
- --> $DIR/liveness-unused.rs:59:12
- |
-LL | Some(i) => {
- | ^ help: if this is intentional, prefix it with an underscore: `_i`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:79:9
- |
-LL | for x in 1..10 { }
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:84:10
- |
-LL | for (x, _) in [1, 2, 3].iter().enumerate() { }
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: unused variable: `x`
- --> $DIR/liveness-unused.rs:89:13
- |
-LL | for (_, x) in [1, 2, 3].iter().enumerate() {
- | ^ help: if this is intentional, prefix it with an underscore: `_x`
-
-error: variable `x` is assigned to, but never used
- --> $DIR/liveness-unused.rs:112:9
- |
-LL | let x;
- | ^
- |
- = note: consider using `_x` instead
-
-error: value assigned to `x` is never read
- --> $DIR/liveness-unused.rs:116:9
- |
-LL | x = 0;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-error: aborting due to 13 previous errors; 1 warning emitted
-
diff --git a/src/test/ui/liveness/liveness-upvars.rs b/src/test/ui/liveness/liveness-upvars.rs
deleted file mode 100644
index d446d57d3..000000000
--- a/src/test/ui/liveness/liveness-upvars.rs
+++ /dev/null
@@ -1,144 +0,0 @@
-// edition:2018
-// check-pass
-#![feature(generators)]
-#![warn(unused)]
-#![allow(unreachable_code)]
-
-pub fn unintentional_copy_one() {
- let mut last = None;
- let mut f = move |s| {
- last = Some(s); //~ WARN value assigned to `last` is never read
- //~| WARN unused variable: `last`
- };
- f("a");
- f("b");
- f("c");
- dbg!(last.unwrap());
-}
-
-pub fn unintentional_copy_two() {
- let mut sum = 0;
- (1..10).for_each(move |x| {
- sum += x; //~ WARN unused variable: `sum`
- });
- dbg!(sum);
-}
-
-pub fn f() {
- let mut c = 0;
-
- // Captured by value, but variable is dead on entry.
- let _ = move || {
- c = 1; //~ WARN value captured by `c` is never read
- println!("{}", c);
- };
- let _ = async move {
- c = 1; //~ WARN value captured by `c` is never read
- println!("{}", c);
- };
-
- // Read and written to, but never actually used.
- let _ = move || {
- c += 1; //~ WARN unused variable: `c`
- };
- let _ = async move {
- c += 1; //~ WARN value assigned to `c` is never read
- //~| WARN unused variable: `c`
- };
-
- let _ = move || {
- println!("{}", c);
- // Value is read by closure itself on later invocations.
- c += 1;
- };
- let b = Box::new(42);
- let _ = move || {
- println!("{}", c);
- // Never read because this is FnOnce closure.
- c += 1; //~ WARN value assigned to `c` is never read
- drop(b);
- };
- let _ = async move {
- println!("{}", c);
- // Never read because this is a generator.
- c += 1; //~ WARN value assigned to `c` is never read
- };
-}
-
-pub fn nested() {
- let mut d = None;
- let mut e = None;
- let _ = || {
- let _ = || {
- d = Some("d1"); //~ WARN value assigned to `d` is never read
- d = Some("d2");
- };
- let _ = move || {
- e = Some("e1"); //~ WARN value assigned to `e` is never read
- //~| WARN unused variable: `e`
- e = Some("e2"); //~ WARN value assigned to `e` is never read
- };
- };
-}
-
-pub fn g<T: Default>(mut v: T) {
- let _ = |r| {
- if r {
- v = T::default(); //~ WARN value assigned to `v` is never read
- } else {
- drop(v);
- }
- };
-}
-
-pub fn h<T: Copy + Default + std::fmt::Debug>() {
- let mut z = T::default();
- let _ = move |b| {
- loop {
- if b {
- z = T::default(); //~ WARN value assigned to `z` is never read
- //~| WARN unused variable: `z`
- } else {
- return;
- }
- }
- dbg!(z);
- };
-}
-
-async fn yield_now() {
- todo!();
-}
-
-pub fn async_generator() {
- let mut state: u32 = 0;
-
- let _ = async {
- state = 1;
- yield_now().await;
- state = 2;
- yield_now().await;
- state = 3;
- };
-
- let _ = async move {
- state = 4; //~ WARN value assigned to `state` is never read
- //~| WARN unused variable: `state`
- yield_now().await;
- state = 5; //~ WARN value assigned to `state` is never read
- };
-}
-
-pub fn generator() {
- let mut s: u32 = 0;
- let _ = |_| {
- s = 0;
- yield ();
- s = 1; //~ WARN value assigned to `s` is never read
- yield (s = 2);
- s = yield (); //~ WARN value assigned to `s` is never read
- s = 3;
- };
-}
-
-fn main() {}
diff --git a/src/test/ui/liveness/liveness-upvars.stderr b/src/test/ui/liveness/liveness-upvars.stderr
deleted file mode 100644
index 82f62371e..000000000
--- a/src/test/ui/liveness/liveness-upvars.stderr
+++ /dev/null
@@ -1,185 +0,0 @@
-warning: value assigned to `last` is never read
- --> $DIR/liveness-upvars.rs:10:9
- |
-LL | last = Some(s);
- | ^^^^
- |
- = help: maybe it is overwritten before being read?
-note: the lint level is defined here
- --> $DIR/liveness-upvars.rs:4:9
- |
-LL | #![warn(unused)]
- | ^^^^^^
- = note: `#[warn(unused_assignments)]` implied by `#[warn(unused)]`
-
-warning: unused variable: `last`
- --> $DIR/liveness-upvars.rs:10:9
- |
-LL | last = Some(s);
- | ^^^^
- |
- = help: did you mean to capture by reference instead?
- = note: `#[warn(unused_variables)]` implied by `#[warn(unused)]`
-
-warning: unused variable: `sum`
- --> $DIR/liveness-upvars.rs:22:9
- |
-LL | sum += x;
- | ^^^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value captured by `c` is never read
- --> $DIR/liveness-upvars.rs:32:9
- |
-LL | c = 1;
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value captured by `c` is never read
- --> $DIR/liveness-upvars.rs:36:9
- |
-LL | c = 1;
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: unused variable: `c`
- --> $DIR/liveness-upvars.rs:42:9
- |
-LL | c += 1;
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value assigned to `c` is never read
- --> $DIR/liveness-upvars.rs:45:9
- |
-LL | c += 1;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: unused variable: `c`
- --> $DIR/liveness-upvars.rs:45:9
- |
-LL | c += 1;
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value assigned to `c` is never read
- --> $DIR/liveness-upvars.rs:58:9
- |
-LL | c += 1;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `c` is never read
- --> $DIR/liveness-upvars.rs:64:9
- |
-LL | c += 1;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `d` is never read
- --> $DIR/liveness-upvars.rs:73:13
- |
-LL | d = Some("d1");
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `e` is never read
- --> $DIR/liveness-upvars.rs:77:13
- |
-LL | e = Some("e1");
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `e` is never read
- --> $DIR/liveness-upvars.rs:79:13
- |
-LL | e = Some("e2");
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: unused variable: `e`
- --> $DIR/liveness-upvars.rs:77:13
- |
-LL | e = Some("e1");
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value assigned to `v` is never read
- --> $DIR/liveness-upvars.rs:87:13
- |
-LL | v = T::default();
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `z` is never read
- --> $DIR/liveness-upvars.rs:99:17
- |
-LL | z = T::default();
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: unused variable: `z`
- --> $DIR/liveness-upvars.rs:99:17
- |
-LL | z = T::default();
- | ^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value assigned to `state` is never read
- --> $DIR/liveness-upvars.rs:125:9
- |
-LL | state = 4;
- | ^^^^^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `state` is never read
- --> $DIR/liveness-upvars.rs:128:9
- |
-LL | state = 5;
- | ^^^^^
- |
- = help: maybe it is overwritten before being read?
-
-warning: unused variable: `state`
- --> $DIR/liveness-upvars.rs:125:9
- |
-LL | state = 4;
- | ^^^^^
- |
- = help: did you mean to capture by reference instead?
-
-warning: value assigned to `s` is never read
- --> $DIR/liveness-upvars.rs:137:9
- |
-LL | s = 1;
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: value assigned to `s` is never read
- --> $DIR/liveness-upvars.rs:139:9
- |
-LL | s = yield ();
- | ^
- |
- = help: maybe it is overwritten before being read?
-
-warning: 22 warnings emitted
-
diff --git a/src/test/ui/liveness/liveness-use-after-move.rs b/src/test/ui/liveness/liveness-use-after-move.rs
deleted file mode 100644
index 46102ca1e..000000000
--- a/src/test/ui/liveness/liveness-use-after-move.rs
+++ /dev/null
@@ -1,8 +0,0 @@
-fn main() {
-
- let x: Box<_> = 5.into();
- let y = x;
-
- println!("{}", *x); //~ ERROR borrow of moved value: `x`
- y.clone();
-}
diff --git a/src/test/ui/liveness/liveness-use-after-move.stderr b/src/test/ui/liveness/liveness-use-after-move.stderr
deleted file mode 100644
index 3accba197..000000000
--- a/src/test/ui/liveness/liveness-use-after-move.stderr
+++ /dev/null
@@ -1,20 +0,0 @@
-error[E0382]: borrow of moved value: `x`
- --> $DIR/liveness-use-after-move.rs:6:20
- |
-LL | let x: Box<_> = 5.into();
- | - move occurs because `x` has type `Box<i32>`, which does not implement the `Copy` trait
-LL | let y = x;
- | - value moved here
-LL |
-LL | println!("{}", *x);
- | ^^ value borrowed here after move
- |
- = note: this error originates in the macro `$crate::format_args_nl` which comes from the expansion of the macro `println` (in Nightly builds, run with -Z macro-backtrace for more info)
-help: consider cloning the value if the performance cost is acceptable
- |
-LL | let y = x.clone();
- | ++++++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0382`.
diff --git a/src/test/ui/liveness/liveness-use-after-send.rs b/src/test/ui/liveness/liveness-use-after-send.rs
deleted file mode 100644
index 6fcd91a9d..000000000
--- a/src/test/ui/liveness/liveness-use-after-send.rs
+++ /dev/null
@@ -1,19 +0,0 @@
-use std::marker;
-
-fn send<T:Send + std::fmt::Debug>(ch: Chan<T>, data: T) {
- println!("{:?}", ch);
- println!("{:?}", data);
- panic!();
-}
-
-#[derive(Debug)]
-struct Chan<T>(isize, marker::PhantomData<T>);
-
-// Tests that "log(debug, message);" is flagged as using
-// message after the send deinitializes it
-fn test00_start(ch: Chan<Box<isize>>, message: Box<isize>, _count: Box<isize>) {
- send(ch, message);
- println!("{}", message); //~ ERROR borrow of moved value: `message`
-}
-
-fn main() { panic!(); }
diff --git a/src/test/ui/liveness/liveness-use-after-send.stderr b/src/test/ui/liveness/liveness-use-after-send.stderr
deleted file mode 100644
index 65d55ca8f..000000000
--- a/src/test/ui/liveness/liveness-use-after-send.stderr
+++ /dev/null
@@ -1,24 +0,0 @@
-error[E0382]: borrow of moved value: `message`
- --> $DIR/liveness-use-after-send.rs:16:20
- |
-LL | fn test00_start(ch: Chan<Box<isize>>, message: Box<isize>, _count: Box<isize>) {
- | ------- move occurs because `message` has type `Box<isize>`, which does not implement the `Copy` trait
-LL | send(ch, message);
- | ------- value moved here
-LL | println!("{}", message);
- | ^^^^^^^ value borrowed here after move
- |
-note: consider changing this parameter type in function `send` to borrow instead if owning the value isn't necessary
- --> $DIR/liveness-use-after-send.rs:3:54
- |
-LL | fn send<T:Send + std::fmt::Debug>(ch: Chan<T>, data: T) {
- | ---- in this function ^ this parameter takes ownership of the value
- = note: this error originates in the macro `$crate::format_args_nl` which comes from the expansion of the macro `println` (in Nightly builds, run with -Z macro-backtrace for more info)
-help: consider cloning the value if the performance cost is acceptable
- |
-LL | send(ch, message.clone());
- | ++++++++
-
-error: aborting due to previous error
-
-For more information about this error, try `rustc --explain E0382`.