diff options
Diffstat (limited to 'lib/src/lints')
-rw-r--r-- | lib/src/lints/empty_pattern.rs | 37 | ||||
-rw-r--r-- | lib/src/lints/redundant_pattern_bind.rs | 41 | ||||
-rw-r--r-- | lib/src/lints/unquoted_splice.rs | 33 |
3 files changed, 111 insertions, 0 deletions
diff --git a/lib/src/lints/empty_pattern.rs b/lib/src/lints/empty_pattern.rs new file mode 100644 index 0000000..6fb7558 --- /dev/null +++ b/lib/src/lints/empty_pattern.rs | |||
@@ -0,0 +1,37 @@ | |||
1 | use crate::{make, Lint, Metadata, Report, Rule, Suggestion}; | ||
2 | |||
3 | use if_chain::if_chain; | ||
4 | use macros::lint; | ||
5 | use rnix::{ | ||
6 | types::{Pattern, TypedNode}, | ||
7 | NodeOrToken, SyntaxElement, SyntaxKind, | ||
8 | }; | ||
9 | |||
10 | #[lint( | ||
11 | name = "empty pattern", | ||
12 | note = "Found empty pattern in function argument", | ||
13 | code = 10, | ||
14 | match_with = SyntaxKind::NODE_PATTERN | ||
15 | )] | ||
16 | struct EmptyPattern; | ||
17 | |||
18 | impl Rule for EmptyPattern { | ||
19 | fn validate(&self, node: &SyntaxElement) -> Option<Report> { | ||
20 | if_chain! { | ||
21 | if let NodeOrToken::Node(node) = node; | ||
22 | if let Some(pattern) = Pattern::cast(node.clone()); | ||
23 | // no patterns within `{ }` | ||
24 | if pattern.entries().count() == 0; | ||
25 | // pattern is not bound | ||
26 | if pattern.at().is_none(); | ||
27 | then { | ||
28 | let at = node.text_range(); | ||
29 | let message = "This pattern is empty, use `_` instead"; | ||
30 | let replacement = make::ident("_").node().clone(); | ||
31 | Some(Self::report().suggest(at, message, Suggestion::new(at, replacement))) | ||
32 | } else { | ||
33 | None | ||
34 | } | ||
35 | } | ||
36 | } | ||
37 | } | ||
diff --git a/lib/src/lints/redundant_pattern_bind.rs b/lib/src/lints/redundant_pattern_bind.rs new file mode 100644 index 0000000..aebc549 --- /dev/null +++ b/lib/src/lints/redundant_pattern_bind.rs | |||
@@ -0,0 +1,41 @@ | |||
1 | use crate::{Lint, Metadata, Report, Rule, Suggestion}; | ||
2 | |||
3 | use if_chain::if_chain; | ||
4 | use macros::lint; | ||
5 | use rnix::{ | ||
6 | types::{Pattern, TokenWrapper, TypedNode}, | ||
7 | NodeOrToken, SyntaxElement, SyntaxKind, | ||
8 | }; | ||
9 | |||
10 | #[lint( | ||
11 | name = "redundant pattern bind", | ||
12 | note = "Found redundant pattern bind in function argument", | ||
13 | code = 10, | ||
14 | match_with = SyntaxKind::NODE_PATTERN | ||
15 | )] | ||
16 | struct RedundantPatternBind; | ||
17 | |||
18 | impl Rule for RedundantPatternBind { | ||
19 | fn validate(&self, node: &SyntaxElement) -> Option<Report> { | ||
20 | if_chain! { | ||
21 | if let NodeOrToken::Node(node) = node; | ||
22 | if let Some(pattern) = Pattern::cast(node.clone()); | ||
23 | // no patterns within `{ }` | ||
24 | if pattern.entries().count() == 0; | ||
25 | |||
26 | // pattern is just ellipsis | ||
27 | if pattern.ellipsis(); | ||
28 | |||
29 | // pattern is bound | ||
30 | if let Some(ident) = pattern.at(); | ||
31 | then { | ||
32 | let at = node.text_range(); | ||
33 | let message = format!("This pattern bind is redundant, use `{}` instead", ident.as_str()); | ||
34 | let replacement = ident.node().clone(); | ||
35 | Some(Self::report().suggest(at, message, Suggestion::new(at, replacement))) | ||
36 | } else { | ||
37 | None | ||
38 | } | ||
39 | } | ||
40 | } | ||
41 | } | ||
diff --git a/lib/src/lints/unquoted_splice.rs b/lib/src/lints/unquoted_splice.rs new file mode 100644 index 0000000..4d1ed69 --- /dev/null +++ b/lib/src/lints/unquoted_splice.rs | |||
@@ -0,0 +1,33 @@ | |||
1 | use crate::{make, Lint, Metadata, Report, Rule, Suggestion}; | ||
2 | |||
3 | use if_chain::if_chain; | ||
4 | use macros::lint; | ||
5 | use rnix::{ | ||
6 | types::{Dynamic, TypedNode}, | ||
7 | NodeOrToken, SyntaxElement, SyntaxKind, | ||
8 | }; | ||
9 | |||
10 | #[lint( | ||
11 | name = "unquoted splice", | ||
12 | note = "Found unquoted splice expression", | ||
13 | code = 9, | ||
14 | match_with = SyntaxKind::NODE_DYNAMIC | ||
15 | )] | ||
16 | struct UnquotedSplice; | ||
17 | |||
18 | impl Rule for UnquotedSplice { | ||
19 | fn validate(&self, node: &SyntaxElement) -> Option<Report> { | ||
20 | if_chain! { | ||
21 | if let NodeOrToken::Node(node) = node; | ||
22 | if Dynamic::cast(node.clone()).is_some(); | ||
23 | then { | ||
24 | let at = node.text_range(); | ||
25 | let replacement = make::quote(&node).node().clone(); | ||
26 | let message = "Consider quoting this splice expression"; | ||
27 | Some(Self::report().suggest(at, message, Suggestion::new(at, replacement))) | ||
28 | } else { | ||
29 | None | ||
30 | } | ||
31 | } | ||
32 | } | ||
33 | } | ||