diff options
author | Dmitry <[email protected]> | 2020-08-14 19:32:05 +0100 |
---|---|---|
committer | Dmitry <[email protected]> | 2020-08-14 19:32:05 +0100 |
commit | 178c3e135a2a249692f7784712492e7884ae0c00 (patch) | |
tree | ac6b769dbf7162150caa0c1624786a4dd79ff3be /crates/syntax/src/validation | |
parent | 06ff8e6c760ff05f10e868b5d1f9d79e42fbb49c (diff) | |
parent | c2594daf2974dbd4ce3d9b7ec72481764abaceb5 (diff) |
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'crates/syntax/src/validation')
-rw-r--r-- | crates/syntax/src/validation/block.rs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/crates/syntax/src/validation/block.rs b/crates/syntax/src/validation/block.rs new file mode 100644 index 000000000..ad9901468 --- /dev/null +++ b/crates/syntax/src/validation/block.rs | |||
@@ -0,0 +1,22 @@ | |||
1 | //! Logic for validating block expressions i.e. `ast::BlockExpr`. | ||
2 | |||
3 | use crate::{ | ||
4 | ast::{self, AstNode, AttrsOwner}, | ||
5 | SyntaxError, | ||
6 | SyntaxKind::*, | ||
7 | }; | ||
8 | |||
9 | pub(crate) fn validate_block_expr(block: ast::BlockExpr, errors: &mut Vec<SyntaxError>) { | ||
10 | if let Some(parent) = block.syntax().parent() { | ||
11 | match parent.kind() { | ||
12 | FN | EXPR_STMT | BLOCK_EXPR => return, | ||
13 | _ => {} | ||
14 | } | ||
15 | } | ||
16 | errors.extend(block.attrs().map(|attr| { | ||
17 | SyntaxError::new( | ||
18 | "A block in this position cannot accept inner attributes", | ||
19 | attr.syntax().text_range(), | ||
20 | ) | ||
21 | })) | ||
22 | } | ||