Skip to content

Commit a40261a

Browse files
committed
Auto merge of #24798 - steveklabnik:rollup, r=steveklabnik
- Successful merges: #24662, #24722, #24725, #24729, #24736, #24749, #24751, #24766, #24769, #24772, #24775, #24790 - Failed merges: #24760
2 parents f9e53c7 + 23b1d17 commit a40261a

18 files changed

+596
-391
lines changed

src/doc/grammar.md

+24-15
Original file line numberDiff line numberDiff line change
@@ -152,19 +152,19 @@ token : simple_token | ident | literal | symbol | whitespace token ;
152152

153153
<p id="keyword-table-marker"></p>
154154

155-
| | | | | |
156-
|----------|----------|----------|----------|--------|
157-
| abstract | alignof | as | become | box |
158-
| break | const | continue | crate | do |
159-
| else | enum | extern | false | final |
160-
| fn | for | if | impl | in |
161-
| let | loop | match | mod | move |
162-
| mut | offsetof | once | override | priv |
163-
| proc | pub | pure | ref | return |
164-
| sizeof | static | self | struct | super |
165-
| true | trait | type | typeof | unsafe |
166-
| unsized | use | virtual | where | while |
167-
| yield | | | | |
155+
| | | | | |
156+
|----------|----------|----------|----------|---------|
157+
| abstract | alignof | as | become | box |
158+
| break | const | continue | crate | do |
159+
| else | enum | extern | false | final |
160+
| fn | for | if | impl | in |
161+
| let | loop | macro | match | mod |
162+
| move | mut | offsetof | override | priv |
163+
| proc | pub | pure | ref | return |
164+
| Self | self | sizeof | static | struct |
165+
| super | trait | true | type | typeof |
166+
| unsafe | unsized | use | virtual | where |
167+
| while | yield | | | |
168168

169169

170170
Each of these keywords has special meaning in its grammar, and all of them are
@@ -524,6 +524,15 @@ array_elems : [expr [',' expr]*] | [expr ',' ".." expr] ;
524524
idx_expr : expr '[' expr ']' ;
525525
```
526526

527+
### Range expressions
528+
529+
```antlr
530+
range_expr : expr ".." expr |
531+
expr ".." |
532+
".." expr |
533+
".." ;
534+
```
535+
527536
### Unary operator expressions
528537

529538
**FIXME:** grammar?
@@ -610,7 +619,7 @@ lambda_expr : '|' ident_list '|' expr ;
610619
### While loops
611620

612621
```antlr
613-
while_expr : "while" no_struct_literal_expr '{' block '}' ;
622+
while_expr : [ lifetime ':' ] "while" no_struct_literal_expr '{' block '}' ;
614623
```
615624

616625
### Infinite loops
@@ -634,7 +643,7 @@ continue_expr : "continue" [ lifetime ];
634643
### For expressions
635644

636645
```antlr
637-
for_expr : "for" pat "in" no_struct_literal_expr '{' block '}' ;
646+
for_expr : [ lifetime ':' ] "for" pat "in" no_struct_literal_expr '{' block '}' ;
638647
```
639648

640649
### If expressions

0 commit comments

Comments
 (0)