mirror of
https://gitea.invidious.io/iv-org/shard-ameba.git
synced 2024-08-15 00:53:29 +00:00
Split VerboseBlock#test method into a smaller pieces
This commit is contained in:
parent
4b7f3ba6ee
commit
5faf8da81c
1 changed files with 18 additions and 14 deletions
|
@ -117,7 +117,22 @@ module Ameba::Rule::Style
|
||||||
CALL_PATTERN % {call.name, args, name}
|
CALL_PATTERN % {call.name, args, name}
|
||||||
end
|
end
|
||||||
|
|
||||||
# ameba:disable Metrics/CyclomaticComplexity
|
protected def issue_for_valid(source, call : Crystal::Call, body : Crystal::Call)
|
||||||
|
return if exclude_calls_with_block && body.block
|
||||||
|
return if exclude_multiple_line_blocks && !same_location_lines?(call, body)
|
||||||
|
return if exclude_operators && operator?(body.name)
|
||||||
|
return if exclude_setters && setter?(body.name)
|
||||||
|
|
||||||
|
call_code =
|
||||||
|
call_code(call, body)
|
||||||
|
|
||||||
|
return unless valid_line_length?(call, call_code)
|
||||||
|
return unless valid_length?(call_code)
|
||||||
|
|
||||||
|
issue_for call.name_location, call.end_location,
|
||||||
|
MSG % call_code
|
||||||
|
end
|
||||||
|
|
||||||
def test(source, node : Crystal::Call)
|
def test(source, node : Crystal::Call)
|
||||||
# we are interested only in calls with block taking a single argument
|
# we are interested only in calls with block taking a single argument
|
||||||
#
|
#
|
||||||
|
@ -145,19 +160,8 @@ module Ameba::Rule::Style
|
||||||
# we skip auto-generated blocks - `(1..3).any?(&.odd?)`
|
# we skip auto-generated blocks - `(1..3).any?(&.odd?)`
|
||||||
return if arg.name.starts_with?("__arg")
|
return if arg.name.starts_with?("__arg")
|
||||||
|
|
||||||
return if exclude_calls_with_block && body.block
|
# add issue if the given nodes pass all of the checks
|
||||||
return if exclude_multiple_line_blocks && !same_location_lines?(node, body)
|
issue_for_valid source, node, body
|
||||||
return if exclude_operators && operator?(body.name)
|
|
||||||
return if exclude_setters && setter?(body.name)
|
|
||||||
|
|
||||||
call_code =
|
|
||||||
call_code(node, body)
|
|
||||||
|
|
||||||
return unless valid_line_length?(node, call_code)
|
|
||||||
return unless valid_length?(call_code)
|
|
||||||
|
|
||||||
issue_for node.name_location, node.end_location,
|
|
||||||
MSG % call_code
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue