mirror of
https://gitea.invidious.io/iv-org/shard-ameba.git
synced 2024-08-15 00:53:29 +00:00
Merge pull request #451 from crystal-ameba/tweak-useless-assign
Refactor `Lint/UselessAssign` rule a bit
This commit is contained in:
commit
590640b559
2 changed files with 24 additions and 11 deletions
|
@ -461,7 +461,7 @@ module Ameba::Rule::Lint
|
||||||
expect_issue subject, <<-CRYSTAL
|
expect_issue subject, <<-CRYSTAL
|
||||||
class A
|
class A
|
||||||
foo : String? = "foo"
|
foo : String? = "foo"
|
||||||
# ^^^^^^^^^^^^^^^^^^^^^ error: Useless assignment to variable `foo`
|
# ^^^ error: Useless assignment to variable `foo`
|
||||||
|
|
||||||
def method
|
def method
|
||||||
foo = "bar"
|
foo = "bar"
|
||||||
|
@ -992,7 +992,7 @@ module Ameba::Rule::Lint
|
||||||
it "reports if it's not referenced at a top level" do
|
it "reports if it's not referenced at a top level" do
|
||||||
expect_issue subject, <<-CRYSTAL
|
expect_issue subject, <<-CRYSTAL
|
||||||
a : String?
|
a : String?
|
||||||
# ^^^^^^^^^ error: Useless assignment to variable `a`
|
# ^{} error: Useless assignment to variable `a`
|
||||||
CRYSTAL
|
CRYSTAL
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1000,7 +1000,7 @@ module Ameba::Rule::Lint
|
||||||
expect_issue subject, <<-CRYSTAL
|
expect_issue subject, <<-CRYSTAL
|
||||||
def foo
|
def foo
|
||||||
a : String?
|
a : String?
|
||||||
# ^^^^^^^^^^^ error: Useless assignment to variable `a`
|
# ^ error: Useless assignment to variable `a`
|
||||||
end
|
end
|
||||||
CRYSTAL
|
CRYSTAL
|
||||||
end
|
end
|
||||||
|
@ -1009,7 +1009,7 @@ module Ameba::Rule::Lint
|
||||||
expect_issue subject, <<-CRYSTAL
|
expect_issue subject, <<-CRYSTAL
|
||||||
class Foo
|
class Foo
|
||||||
a : String?
|
a : String?
|
||||||
# ^^^^^^^^^^^ error: Useless assignment to variable `a`
|
# ^ error: Useless assignment to variable `a`
|
||||||
end
|
end
|
||||||
CRYSTAL
|
CRYSTAL
|
||||||
end
|
end
|
||||||
|
|
|
@ -43,17 +43,30 @@ module Ameba::Rule::Lint
|
||||||
|
|
||||||
scope.variables.each do |var|
|
scope.variables.each do |var|
|
||||||
next if var.ignored? || var.used_in_macro? || var.captured_by_block?
|
next if var.ignored? || var.used_in_macro? || var.captured_by_block?
|
||||||
|
|
||||||
if scope.assigns_type_dec?(var.name)
|
if scope.assigns_type_dec?(var.name)
|
||||||
next if exclude_type_declarations?
|
next if exclude_type_declarations? || expressions_with_call?(node)
|
||||||
# exclude type declarations within calls
|
|
||||||
if node.is_a?(Crystal::Expressions)
|
|
||||||
next if node.expressions.first?.is_a?(Crystal::Call)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
var.assignments.each do |assign|
|
var.assignments.each do |assign|
|
||||||
next if assign.referenced?
|
check_assignment(source, assign, var)
|
||||||
issue_for assign.target_node, MSG % var.name
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
private def expressions_with_call?(node)
|
||||||
|
node.is_a?(Crystal::Expressions) &&
|
||||||
|
node.expressions.first?.is_a?(Crystal::Call)
|
||||||
|
end
|
||||||
|
|
||||||
|
private def check_assignment(source, assign, var)
|
||||||
|
return if assign.referenced?
|
||||||
|
|
||||||
|
case target_node = assign.target_node
|
||||||
|
when Crystal::TypeDeclaration
|
||||||
|
issue_for target_node.var, MSG % var.name
|
||||||
|
else
|
||||||
|
issue_for target_node, MSG % var.name
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue