Do not report anonymous block arguments in Lint/UnusedArgument

This commit is contained in:
Sijawusz Pur Rahnama 2022-12-12 18:14:49 +01:00
parent 4533e52aa5
commit 9df66e890b
3 changed files with 17 additions and 2 deletions

View file

@ -132,6 +132,15 @@ module Ameba::Rule::Lint
subject.catch(s).should_not be_valid subject.catch(s).should_not be_valid
end end
it "doesn't report if it's an anonymous block" do
s = Source.new %(
def method(&)
yield 1
end
)
subject.catch(s).should be_valid
end
it "doesn't report if variable is referenced implicitly" do it "doesn't report if variable is referenced implicitly" do
s = Source.new %( s = Source.new %(
class Bar < Foo class Bar < Foo

View file

@ -31,7 +31,12 @@ module Ameba::AST
def initialize(@node, @variable) def initialize(@node, @variable)
end end
# Returns `true` if the name starts with '_', `false` if not. # Returns `true` if the `name` is empty, `false` otherwise.
def anonymous?
name.blank?
end
# Returns `true` if the `name` starts with '_', `false` otherwise.
def ignored? def ignored?
name.starts_with? '_' name.starts_with? '_'
end end

View file

@ -55,7 +55,8 @@ module Ameba::Rule::Lint
private def find_unused_arguments(source, scope) private def find_unused_arguments(source, scope)
scope.arguments.each do |argument| scope.arguments.each do |argument|
next if argument.ignored? || scope.references?(argument.variable) next if argument.anonymous? || argument.ignored?
next if scope.references?(argument.variable)
name_suggestion = scope.node.is_a?(Crystal::Block) ? '_' : "_#{argument.name}" name_suggestion = scope.node.is_a?(Crystal::Block) ? '_' : "_#{argument.name}"
issue_for argument.node, MSG % {argument.name, name_suggestion} issue_for argument.node, MSG % {argument.name, name_suggestion}