forked from rubocop/rubocop
/
block_length.rb
74 lines (63 loc) · 1.88 KB
/
block_length.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# frozen_string_literal: true
module RuboCop
module Cop
module Metrics
# This cop checks if the length of a block exceeds some maximum value.
# Comment lines can optionally be ignored.
# The maximum allowed length is configurable.
# The cop can be configured to ignore blocks passed to certain methods.
#
# You can set literals you want to fold with `CountAsOne`.
# Available are: 'array', 'hash', and 'heredoc'. Each literal
# will be counted as one line regardless of its actual size.
#
# @example CountAsOne: ['array', 'heredoc']
#
# something do
# array = [ # +1
# 1,
# 2
# ]
#
# hash = { # +3
# key: 'value'
# }
#
# msg = <<~HEREDOC # +1
# Heredoc
# content.
# HEREDOC
# end # 5 points
#
# NOTE: This cop does not apply for `Struct` definitions.
class BlockLength < Base
include CodeLength
LABEL = 'Block'
def on_block(node)
return if excluded_method?(node)
return if node.class_constructor? || node.struct_constructor?
check_code_length(node)
end
private
def excluded_method?(node)
node_receiver = node.receiver&.source&.gsub(/\s+/, '')
node_method = String(node.method_name)
excluded_methods.any? do |config|
receiver, method = config.split('.')
unless method
method = receiver
receiver = node_receiver
end
method == node_method && receiver == node_receiver
end
end
def excluded_methods
cop_config['ExcludedMethods'] || []
end
def cop_label
LABEL
end
end
end
end
end