summaryrefslogtreecommitdiffstats
path: root/src/test/ui/type/type-check/assignment-in-if.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/type/type-check/assignment-in-if.rs')
-rw-r--r--src/test/ui/type/type-check/assignment-in-if.rs62
1 files changed, 0 insertions, 62 deletions
diff --git a/src/test/ui/type/type-check/assignment-in-if.rs b/src/test/ui/type/type-check/assignment-in-if.rs
deleted file mode 100644
index ada250df2..000000000
--- a/src/test/ui/type/type-check/assignment-in-if.rs
+++ /dev/null
@@ -1,62 +0,0 @@
-// Test that the parser does not attempt to parse struct literals
-// within assignments in if expressions.
-
-#![allow(unused_parens)]
-
-struct Foo {
- foo: usize
-}
-
-fn main() {
- let x = 1;
- let y: Foo;
-
- // `x { ... }` should not be interpreted as a struct literal here
- if x = x {
- //~^ ERROR mismatched types
- println!("{}", x);
- }
- // Explicit parentheses on the left should match behavior of above
- if (x = x) {
- //~^ ERROR mismatched types
- println!("{}", x);
- }
- // The struct literal interpretation is fine with explicit parentheses on the right
- if y = (Foo { foo: x }) {
- //~^ ERROR mismatched types
- println!("{}", x);
- }
- // "invalid left-hand side of assignment" error is suppresed
- if 3 = x {
- //~^ ERROR mismatched types
- println!("{}", x);
- }
- if (
- if true {
- x = 4 //~ ERROR mismatched types
- } else {
- x = 5 //~ ERROR mismatched types
- }
- ) {
- println!("{}", x);
- }
-
- if x == x && x = x && x == x {
- //~^ ERROR mismatched types
- //~| ERROR mismatched types
- //~| ERROR mismatched types
- println!("{}", x);
- }
-
- if x == x && x == x && x = x {
- //~^ ERROR mismatched types
- //~| ERROR mismatched types
- println!("{}", x);
- }
-
- if x = 1 && x == 1 {
- //~^ ERROR mismatched types
- //~| ERROR mismatched types
- println!("{}", x);
- }
-}