Add AST::NodeVisitor::Category simplifying code a bit

This commit is contained in:
Sijawusz Pur Rahnama 2023-06-12 21:35:09 +02:00
parent aceb054aa0
commit 38b6751bc0
10 changed files with 34 additions and 58 deletions

View file

@ -8,13 +8,16 @@ module Ameba::AST
# visitor = Ameba::AST::NodeVisitor.new(rule, source)
# ```
class NodeVisitor < BaseVisitor
enum Category
Macro
end
# List of nodes to be visited by Ameba's rules.
NODES = {
Alias,
IsA,
Assign,
Call,
Block,
Call,
Case,
ClassDef,
ClassVar,
@ -25,20 +28,38 @@ module Ameba::AST
HashLiteral,
If,
InstanceVar,
IsA,
LibDef,
ModuleDef,
NilLiteral,
StringInterpolation,
Unless,
Until,
Var,
When,
While,
Until,
}
@skip : Array(Crystal::ASTNode.class)?
def initialize(@rule, @source, skip = nil)
def self.category_to_node_classes(category : Category)
case category
in .macro?
[
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
end
end
def initialize(@rule, @source, skip : Category)
initialize @rule, @source,
skip: NodeVisitor.category_to_node_classes(skip)
end
def initialize(@rule, @source, skip : Array? = nil)
@skip = skip.try &.map(&.as(Crystal::ASTNode.class))
super @rule, @source
end

View file

@ -36,12 +36,7 @@ module Ameba::Rule::Lint
MSG = "Avoid using `not_nil!`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -34,12 +34,7 @@ module Ameba::Rule::Lint
MSG = "Use `%s! {...}` instead of `%s {...}.not_nil!`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -59,12 +59,7 @@ module Ameba::Rule::Performance
MSG = "Use bang method variant `%s!` after chained `%s` call"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -31,12 +31,7 @@ module Ameba::Rule::Performance
MSG = "Use `compact_map {...}` instead of `map {...}.compact`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -36,12 +36,7 @@ module Ameba::Rule::Performance
MSG_REVERSE = "Use `reverse_each.find {...}` instead of `%s {...}.%s`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -31,12 +31,7 @@ module Ameba::Rule::Performance
MSG = "Use `flat_map {...}` instead of `map {...}.flatten`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -32,12 +32,7 @@ module Ameba::Rule::Performance
MSG = "Use `%s {...}` instead of `map {...}.%s`"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -42,12 +42,7 @@ module Ameba::Rule::Performance
MSG = "Use `count {...}` instead of `%s {...}.size`."
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)

View file

@ -49,12 +49,7 @@ module Ameba::Rule::Style
OLD = "%s {...}"
def test(source)
AST::NodeVisitor.new self, source, skip: [
Crystal::Macro,
Crystal::MacroExpression,
Crystal::MacroIf,
Crystal::MacroFor,
]
AST::NodeVisitor.new self, source, skip: :macro
end
def test(source, node : Crystal::Call)