blob: 9228e2e5312e4aa7cc0386bc65d83ecb08e57127 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
// This test has some extra semis in it that the pretty-printer won't
// reproduce so we don't want to automatically reformat it
// no-reformat
/*
*
* When you write a block-expression thing followed by
* a lone unary operator, you can get a surprising parse:
*
* if (...) { ... }
* -num;
*
* for example, or:
*
* if (...) { ... }
* *box;
*
* These will parse as subtraction and multiplication binops.
* To get them to parse "the way you want" you need to brace
* the leading unops:
* if (...) { ... }
* {-num};
*
* or alternatively, semi-separate them:
*
* if (...) { ... };
* -num;
*
* This seems a little wonky, but the alternative is to lower
* precedence of such block-like exprs to the point where
* you have to parenthesize them to get them to occur in the
* RHS of a binop. For example, you'd have to write:
*
* 12 + (if (foo) { 13 } else { 14 });
*
* rather than:
*
* 12 + if (foo) { 13 } else { 14 };
*
* Since we want to maintain the ability to write the latter,
* we leave the parens-burden on the trailing unop case.
*
*/
fn main() {
let num = 12;
assert if (true) { 12 } else { 12 } - num == 0;
assert 12 - if (true) { 12 } else { 12 } == 0;
if (true) { 12; } {-num};
if (true) { 12; }; {-num};
if (true) { 12; };;; -num;
}
|