rubocop 0.75.1 → 0.78.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (162) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/config/default.yml +339 -315
  4. data/lib/rubocop.rb +42 -31
  5. data/lib/rubocop/ast/builder.rb +1 -0
  6. data/lib/rubocop/ast/node.rb +5 -1
  7. data/lib/rubocop/ast/node/block_node.rb +2 -0
  8. data/lib/rubocop/ast/node/return_node.rb +24 -0
  9. data/lib/rubocop/cli.rb +11 -227
  10. data/lib/rubocop/cli/command.rb +21 -0
  11. data/lib/rubocop/cli/command/auto_genenerate_config.rb +105 -0
  12. data/lib/rubocop/cli/command/base.rb +33 -0
  13. data/lib/rubocop/cli/command/execute_runner.rb +76 -0
  14. data/lib/rubocop/cli/command/init_dotfile.rb +45 -0
  15. data/lib/rubocop/cli/command/show_cops.rb +73 -0
  16. data/lib/rubocop/cli/command/version.rb +17 -0
  17. data/lib/rubocop/cli/environment.rb +21 -0
  18. data/lib/rubocop/comment_config.rb +2 -2
  19. data/lib/rubocop/config.rb +8 -1
  20. data/lib/rubocop/config_loader.rb +1 -1
  21. data/lib/rubocop/config_loader_resolver.rb +2 -1
  22. data/lib/rubocop/config_obsoletion.rb +73 -11
  23. data/lib/rubocop/config_validator.rb +28 -19
  24. data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
  25. data/lib/rubocop/cop/bundler/gem_comment.rb +4 -4
  26. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +2 -2
  27. data/lib/rubocop/cop/commissioner.rb +15 -7
  28. data/lib/rubocop/cop/cop.rb +31 -6
  29. data/lib/rubocop/cop/corrector.rb +8 -7
  30. data/lib/rubocop/cop/correctors/space_corrector.rb +1 -2
  31. data/lib/rubocop/cop/generator/configuration_injector.rb +1 -1
  32. data/lib/rubocop/cop/internal_affairs.rb +1 -0
  33. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +59 -0
  34. data/lib/rubocop/cop/layout/{align_arguments.rb → argument_alignment.rb} +1 -1
  35. data/lib/rubocop/cop/layout/{align_array.rb → array_alignment.rb} +1 -1
  36. data/lib/rubocop/cop/layout/{indent_assignment.rb → assignment_indentation.rb} +1 -1
  37. data/lib/rubocop/cop/layout/comment_indentation.rb +10 -13
  38. data/lib/rubocop/cop/layout/empty_comment.rb +7 -16
  39. data/lib/rubocop/cop/layout/end_of_line.rb +8 -3
  40. data/lib/rubocop/cop/layout/extra_spacing.rb +1 -1
  41. data/lib/rubocop/cop/layout/{indent_first_argument.rb → first_argument_indentation.rb} +14 -12
  42. data/lib/rubocop/cop/layout/{indent_first_array_element.rb → first_array_element_indentation.rb} +4 -4
  43. data/lib/rubocop/cop/layout/{indent_first_hash_element.rb → first_hash_element_indentation.rb} +4 -4
  44. data/lib/rubocop/cop/layout/{indent_first_parameter.rb → first_parameter_indentation.rb} +3 -3
  45. data/lib/rubocop/cop/layout/{align_hash.rb → hash_alignment.rb} +8 -4
  46. data/lib/rubocop/cop/layout/{indent_heredoc.rb → heredoc_indentation.rb} +5 -5
  47. data/lib/rubocop/cop/layout/{leading_blank_lines.rb → leading_empty_lines.rb} +1 -1
  48. data/lib/rubocop/cop/{metrics → layout}/line_length.rb +41 -114
  49. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +1 -1
  50. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +1 -1
  51. data/lib/rubocop/cop/layout/{align_parameters.rb → parameter_alignment.rb} +1 -1
  52. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +2 -0
  53. data/lib/rubocop/cop/layout/space_around_keyword.rb +12 -0
  54. data/lib/rubocop/cop/layout/space_around_operators.rb +32 -7
  55. data/lib/rubocop/cop/layout/space_before_block_braces.rb +17 -0
  56. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +9 -7
  57. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +7 -4
  58. data/lib/rubocop/cop/layout/space_inside_parens.rb +6 -6
  59. data/lib/rubocop/cop/layout/{trailing_blank_lines.rb → trailing_empty_lines.rb} +1 -1
  60. data/lib/rubocop/cop/layout/trailing_whitespace.rb +18 -2
  61. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +1 -1
  62. data/lib/rubocop/cop/lint/{duplicated_key.rb → duplicate_hash_key.rb} +1 -1
  63. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  64. data/lib/rubocop/cop/lint/erb_new_arguments.rb +9 -8
  65. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -1
  66. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +2 -2
  67. data/lib/rubocop/cop/lint/{multiple_compare.rb → multiple_comparison.rb} +1 -1
  68. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +89 -0
  69. data/lib/rubocop/cop/lint/{unneeded_cop_disable_directive.rb → redundant_cop_disable_directive.rb} +25 -25
  70. data/lib/rubocop/cop/lint/{unneeded_cop_enable_directive.rb → redundant_cop_enable_directive.rb} +10 -12
  71. data/lib/rubocop/cop/lint/{unneeded_require_statement.rb → redundant_require_statement.rb} +1 -1
  72. data/lib/rubocop/cop/lint/{unneeded_splat_expansion.rb → redundant_splat_expansion.rb} +6 -6
  73. data/lib/rubocop/cop/lint/{string_conversion_in_interpolation.rb → redundant_string_coercion.rb} +1 -1
  74. data/lib/rubocop/cop/lint/redundant_with_index.rb +2 -2
  75. data/lib/rubocop/cop/lint/redundant_with_object.rb +2 -2
  76. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +5 -6
  77. data/lib/rubocop/cop/lint/{handle_exceptions.rb → suppressed_exception.rb} +1 -1
  78. data/lib/rubocop/cop/lint/useless_access_modifier.rb +57 -23
  79. data/lib/rubocop/cop/lint/useless_setter_call.rb +1 -1
  80. data/lib/rubocop/cop/lint/void.rb +4 -4
  81. data/lib/rubocop/cop/metrics/abc_size.rb +1 -1
  82. data/lib/rubocop/cop/metrics/method_length.rb +1 -1
  83. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +23 -6
  84. data/lib/rubocop/cop/mixin/alignment.rb +1 -1
  85. data/lib/rubocop/cop/mixin/{hash_alignment.rb → hash_alignment_styles.rb} +1 -1
  86. data/lib/rubocop/cop/mixin/line_length_help.rb +88 -0
  87. data/lib/rubocop/cop/mixin/method_complexity.rb +2 -1
  88. data/lib/rubocop/cop/mixin/nil_methods.rb +4 -4
  89. data/lib/rubocop/cop/mixin/rational_literal.rb +18 -0
  90. data/lib/rubocop/cop/mixin/statement_modifier.rb +7 -4
  91. data/lib/rubocop/cop/mixin/trailing_comma.rb +14 -9
  92. data/lib/rubocop/cop/naming/{uncommunicative_block_param_name.rb → block_parameter_name.rb} +3 -3
  93. data/lib/rubocop/cop/naming/file_name.rb +12 -5
  94. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +5 -5
  95. data/lib/rubocop/cop/naming/{uncommunicative_method_param_name.rb → method_parameter_name.rb} +3 -3
  96. data/lib/rubocop/cop/naming/predicate_name.rb +6 -6
  97. data/lib/rubocop/cop/offense.rb +11 -0
  98. data/lib/rubocop/cop/registry.rb +1 -1
  99. data/lib/rubocop/cop/style/alias.rb +1 -1
  100. data/lib/rubocop/cop/style/array_join.rb +1 -1
  101. data/lib/rubocop/cop/style/attr.rb +10 -2
  102. data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +6 -6
  103. data/lib/rubocop/cop/style/comment_annotation.rb +5 -5
  104. data/lib/rubocop/cop/style/conditional_assignment.rb +2 -2
  105. data/lib/rubocop/cop/style/copyright.rb +11 -7
  106. data/lib/rubocop/cop/style/double_cop_disable_directive.rb +2 -2
  107. data/lib/rubocop/cop/style/empty_case_condition.rb +2 -2
  108. data/lib/rubocop/cop/style/empty_literal.rb +2 -2
  109. data/lib/rubocop/cop/style/empty_method.rb +5 -5
  110. data/lib/rubocop/cop/style/eval_with_location.rb +1 -1
  111. data/lib/rubocop/cop/style/even_odd.rb +1 -1
  112. data/lib/rubocop/cop/style/format_string.rb +10 -7
  113. data/lib/rubocop/cop/style/format_string_token.rb +2 -0
  114. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +10 -0
  115. data/lib/rubocop/cop/style/guard_clause.rb +3 -2
  116. data/lib/rubocop/cop/style/hash_syntax.rb +2 -2
  117. data/lib/rubocop/cop/style/if_unless_modifier.rb +45 -3
  118. data/lib/rubocop/cop/style/infinite_loop.rb +5 -4
  119. data/lib/rubocop/cop/style/inverse_methods.rb +19 -13
  120. data/lib/rubocop/cop/style/ip_addresses.rb +4 -4
  121. data/lib/rubocop/cop/style/line_end_concatenation.rb +14 -10
  122. data/lib/rubocop/cop/style/method_def_parentheses.rb +17 -9
  123. data/lib/rubocop/cop/style/mixin_grouping.rb +1 -1
  124. data/lib/rubocop/cop/style/multiline_method_signature.rb +1 -1
  125. data/lib/rubocop/cop/style/multiline_when_then.rb +1 -1
  126. data/lib/rubocop/cop/style/nested_modifier.rb +4 -2
  127. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +5 -5
  128. data/lib/rubocop/cop/style/next.rb +5 -5
  129. data/lib/rubocop/cop/style/non_nil_check.rb +21 -9
  130. data/lib/rubocop/cop/style/numeric_literals.rb +7 -3
  131. data/lib/rubocop/cop/style/option_hash.rb +3 -3
  132. data/lib/rubocop/cop/style/{unneeded_capital_w.rb → redundant_capital_w.rb} +1 -1
  133. data/lib/rubocop/cop/style/{unneeded_condition.rb → redundant_condition.rb} +3 -3
  134. data/lib/rubocop/cop/style/{unneeded_interpolation.rb → redundant_interpolation.rb} +1 -1
  135. data/lib/rubocop/cop/style/redundant_parentheses.rb +3 -3
  136. data/lib/rubocop/cop/style/{unneeded_percent_q.rb → redundant_percent_q.rb} +1 -1
  137. data/lib/rubocop/cop/style/redundant_return.rb +27 -29
  138. data/lib/rubocop/cop/style/{unneeded_sort.rb → redundant_sort.rb} +5 -5
  139. data/lib/rubocop/cop/style/safe_navigation.rb +13 -10
  140. data/lib/rubocop/cop/style/semicolon.rb +2 -2
  141. data/lib/rubocop/cop/style/special_global_vars.rb +5 -7
  142. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +7 -1
  143. data/lib/rubocop/cop/style/trivial_accessors.rb +5 -5
  144. data/lib/rubocop/cop/style/while_until_modifier.rb +1 -1
  145. data/lib/rubocop/cop/team.rb +5 -0
  146. data/lib/rubocop/cop/util.rb +1 -1
  147. data/lib/rubocop/cop/utils/format_string.rb +10 -18
  148. data/lib/rubocop/cop/variable_force.rb +7 -5
  149. data/lib/rubocop/formatter/base_formatter.rb +2 -2
  150. data/lib/rubocop/formatter/clang_style_formatter.rb +1 -3
  151. data/lib/rubocop/formatter/json_formatter.rb +6 -5
  152. data/lib/rubocop/formatter/tap_formatter.rb +1 -3
  153. data/lib/rubocop/node_pattern.rb +4 -2
  154. data/lib/rubocop/options.rb +17 -11
  155. data/lib/rubocop/processed_source.rb +1 -1
  156. data/lib/rubocop/rake_task.rb +1 -0
  157. data/lib/rubocop/result_cache.rb +24 -8
  158. data/lib/rubocop/runner.rb +50 -29
  159. data/lib/rubocop/target_finder.rb +12 -6
  160. data/lib/rubocop/version.rb +1 -1
  161. metadata +44 -32
  162. data/lib/rubocop/cop/mixin/safe_mode.rb +0 -24
@@ -155,7 +155,7 @@ module RuboCop
155
155
  return true if node.literal?
156
156
  return false unless node.send_type?
157
157
 
158
- node.method_name == :new
158
+ node.method?(:new)
159
159
  end
160
160
  end
161
161
  end
@@ -55,10 +55,10 @@ module RuboCop
55
55
  VOID_CONTEXT_TYPES = %i[def for block].freeze
56
56
  NONMUTATING_METHODS = %i[capitalize chomp chop collect compact
57
57
  delete_prefix delete_suffix downcase
58
- encode flatten gsub lstrip map next reject
59
- reverse rotate rstrip scrub select shuffle
60
- slice sort sort_by squeeze strip sub succ
61
- swapcase tr tr_s transform_values
58
+ encode flatten gsub lstrip map merge next
59
+ reject reverse rotate rstrip scrub select
60
+ shuffle slice sort sort_by squeeze strip sub
61
+ succ swapcase tr tr_s transform_values
62
62
  unicode_normalize uniq upcase].freeze
63
63
 
64
64
  def on_block(node)
@@ -11,7 +11,7 @@ module RuboCop
11
11
  include MethodComplexity
12
12
 
13
13
  MSG = 'Assignment Branch Condition size for %<method>s is too high. ' \
14
- '[%<complexity>.4g/%<max>.4g]'
14
+ '[%<abc_vector>s %<complexity>.4g/%<max>.4g]'
15
15
 
16
16
  private
17
17
 
@@ -20,7 +20,7 @@ module RuboCop
20
20
  alias on_defs on_def
21
21
 
22
22
  def on_block(node)
23
- return unless node.send_node.method_name == :define_method
23
+ return unless node.send_node.method?(:define_method)
24
24
 
25
25
  check_code_length(node)
26
26
  end
@@ -36,15 +36,17 @@ module RuboCop
36
36
  @node.each_node do |child|
37
37
  if child.assignment?
38
38
  @assignment += 1
39
- elsif BRANCH_NODES.include?(child.type)
39
+ elsif branch?(child)
40
40
  evaluate_branch_nodes(child)
41
- elsif CONDITION_NODES.include?(child.type)
42
- @condition += 1 if node_has_else_branch?(child)
43
- @condition += 1
41
+ elsif condition?(child)
42
+ evaluate_condition_node(child)
44
43
  end
45
44
  end
46
45
 
47
- Math.sqrt(@assignment**2 + @branch**2 + @condition**2).round(2)
46
+ [
47
+ Math.sqrt(@assignment**2 + @branch**2 + @condition**2).round(2),
48
+ "<#{@assignment}, #{@branch}, #{@condition}>"
49
+ ]
48
50
  end
49
51
 
50
52
  def evaluate_branch_nodes(node)
@@ -55,11 +57,26 @@ module RuboCop
55
57
  end
56
58
  end
57
59
 
58
- def node_has_else_branch?(node)
60
+ def evaluate_condition_node(node)
61
+ @condition += 1 if else_branch?(node)
62
+ @condition += 1
63
+ end
64
+
65
+ def else_branch?(node)
59
66
  %i[case if].include?(node.type) &&
60
67
  node.else? &&
61
68
  node.loc.else.is?('else')
62
69
  end
70
+
71
+ private
72
+
73
+ def branch?(node)
74
+ BRANCH_NODES.include?(node.type)
75
+ end
76
+
77
+ def condition?(node)
78
+ CONDITION_NODES.include?(node.type)
79
+ end
63
80
  end
64
81
  end
65
82
  end
@@ -35,7 +35,7 @@ module RuboCop
35
35
  # If this offense is within a line range that is already being
36
36
  # realigned by autocorrect, we report the offense without
37
37
  # autocorrecting it. Two rewrites in the same area by the same
38
- # cop can not be handled. The next iteration will find the
38
+ # cop cannot be handled. The next iteration will find the
39
39
  # offense again and correct it.
40
40
  add_offense(nil, location: expr)
41
41
  else
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  # Common functionality for checking hash alignment.
6
- module HashAlignment
6
+ module HashAlignmentStyles
7
7
  # Handles calculation of deltas when the enforced style is 'key'.
8
8
  class KeyAlignment
9
9
  def checkable_layout?(_node)
@@ -0,0 +1,88 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ # Help methods for determining if a line is too long.
6
+ module LineLengthHelp
7
+ private
8
+
9
+ def ignore_cop_directives?
10
+ config.for_cop('Layout/LineLength')['IgnoreCopDirectives']
11
+ end
12
+
13
+ def directive_on_source_line?(line_index)
14
+ source_line_number = line_index + processed_source.buffer.first_line
15
+ comment =
16
+ processed_source.comments
17
+ .detect { |e| e.location.line == source_line_number }
18
+
19
+ return false unless comment
20
+
21
+ comment.text.match(CommentConfig::COMMENT_DIRECTIVE_REGEXP)
22
+ end
23
+
24
+ def allow_uri?
25
+ config.for_cop('Layout/LineLength')['AllowURI']
26
+ end
27
+
28
+ def allowed_uri_position?(line, uri_range)
29
+ uri_range.begin < max_line_length &&
30
+ (uri_range.end == line_length(line) ||
31
+ uri_range.end == line_length(line) - 1)
32
+ end
33
+
34
+ def line_length(line)
35
+ line.length + indentation_difference(line)
36
+ end
37
+
38
+ def find_excessive_uri_range(line)
39
+ last_uri_match = match_uris(line).last
40
+ return nil unless last_uri_match
41
+
42
+ begin_position, end_position = last_uri_match.offset(0).map do |pos|
43
+ pos + indentation_difference(line)
44
+ end
45
+ return nil if begin_position < max_line_length &&
46
+ end_position < max_line_length
47
+
48
+ begin_position...end_position
49
+ end
50
+
51
+ def match_uris(string)
52
+ matches = []
53
+ string.scan(uri_regexp) do
54
+ matches << $LAST_MATCH_INFO if valid_uri?($LAST_MATCH_INFO[0])
55
+ end
56
+ matches
57
+ end
58
+
59
+ def indentation_difference(line)
60
+ return 0 unless tab_indentation_width
61
+
62
+ line.match(/^\t*/)[0].size * (tab_indentation_width - 1)
63
+ end
64
+
65
+ def tab_indentation_width
66
+ config.for_cop('Layout/Tab')['IndentationWidth']
67
+ end
68
+
69
+ def uri_regexp
70
+ @uri_regexp ||=
71
+ URI::DEFAULT_PARSER
72
+ .make_regexp(config.for_cop('Layout/LineLength')['URISchemes'])
73
+ end
74
+
75
+ def valid_uri?(uri_ish_string)
76
+ URI.parse(uri_ish_string)
77
+ true
78
+ rescue URI::InvalidURIError, NoMethodError
79
+ false
80
+ end
81
+
82
+ def line_length_without_directive(line)
83
+ before_comment, = line.split(CommentConfig::COMMENT_DIRECTIVE_REGEXP)
84
+ before_comment.rstrip.length
85
+ end
86
+ end
87
+ end
88
+ end
@@ -32,13 +32,14 @@ module RuboCop
32
32
  return unless node.body
33
33
 
34
34
  max = cop_config['Max']
35
- complexity = complexity(node.body)
35
+ complexity, abc_vector = complexity(node.body)
36
36
 
37
37
  return unless complexity > max
38
38
 
39
39
  msg = format(self.class::MSG,
40
40
  method: method_name,
41
41
  complexity: complexity,
42
+ abc_vector: abc_vector,
42
43
  max: max)
43
44
 
44
45
  add_offense(node, message: msg) do
@@ -5,20 +5,20 @@ module RuboCop
5
5
  # This module provides a list of methods that are:
6
6
  # 1. In the NilClass by default
7
7
  # 2. Added to NilClass by explicitly requiring any standard libraries
8
- # 3. Cop's configuration parameter Whitelist.
8
+ # 3. Cop's configuration parameter AllowedMethods.
9
9
  module NilMethods
10
10
  private
11
11
 
12
12
  def nil_methods
13
- nil.methods + other_stdlib_methods + whitelist
13
+ nil.methods + other_stdlib_methods + allowed_methods
14
14
  end
15
15
 
16
16
  def other_stdlib_methods
17
17
  [:to_d]
18
18
  end
19
19
 
20
- def whitelist
21
- cop_config['Whitelist'].map(&:to_sym)
20
+ def allowed_methods
21
+ cop_config['AllowedMethods'].map(&:to_sym)
22
22
  end
23
23
  end
24
24
  end
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ # Common functionality for handling Rational literals.
6
+ module RationalLiteral
7
+ extend NodePattern::Macros
8
+
9
+ private
10
+
11
+ def_node_matcher :rational_literal?, <<~PATTERN
12
+ (send
13
+ (int _) :/
14
+ (rational _))
15
+ PATTERN
16
+ end
17
+ end
18
+ end
@@ -41,17 +41,20 @@ module RuboCop
41
41
  end
42
42
 
43
43
  def length_in_modifier_form(node, cond, body_length)
44
- indentation = node.loc.keyword.column * indentation_multiplier
45
- kw_length = node.loc.keyword.size
44
+ keyword = node.loc.keyword
45
+
46
+ indentation = keyword.column * indentation_multiplier
47
+ kw_length = keyword.size
46
48
  cond_length = cond.source_range.size
47
49
  space = 1
50
+
48
51
  indentation + body_length + space + kw_length + space + cond_length
49
52
  end
50
53
 
51
54
  def max_line_length
52
- return unless config.for_cop('Metrics/LineLength')['Enabled']
55
+ return unless config.for_cop('Layout/LineLength')['Enabled']
53
56
 
54
- config.for_cop('Metrics/LineLength')['Max']
57
+ config.for_cop('Layout/LineLength')['Max']
55
58
  end
56
59
 
57
60
  def indentation_multiplier
@@ -18,12 +18,7 @@ module RuboCop
18
18
 
19
19
  def check(node, items, kind, begin_pos, end_pos)
20
20
  after_last_item = range_between(begin_pos, end_pos)
21
-
22
- # If there is any heredoc in items, then match the comma succeeding
23
- # any whitespace (except newlines), otherwise allow for newlines
24
- comma_regex = any_heredoc?(items) ? /\A[^\S\n]*,/ : /\A\s*,/
25
- comma_offset = after_last_item.source =~ comma_regex &&
26
- after_last_item.source.index(',')
21
+ comma_offset = comma_offset(items, after_last_item)
27
22
 
28
23
  if comma_offset && !inside_comment?(after_last_item, comma_offset)
29
24
  check_comma(node, kind, after_last_item.begin_pos + comma_offset)
@@ -32,6 +27,13 @@ module RuboCop
32
27
  end
33
28
  end
34
29
 
30
+ def comma_offset(items, range)
31
+ # If there is any heredoc in items, then match the comma succeeding
32
+ # any whitespace (except newlines), otherwise allow for newlines
33
+ comma_regex = any_heredoc?(items) ? /\A[^\S\n]*,/ : /\A\s*,/
34
+ range.source =~ comma_regex && range.source.index(',')
35
+ end
36
+
35
37
  def check_comma(node, kind, comma_pos)
36
38
  return if should_have_comma?(style, node)
37
39
 
@@ -91,9 +93,12 @@ module RuboCop
91
93
  end
92
94
 
93
95
  def method_name_and_arguments_on_same_line?(node)
94
- %i[send csend].include?(node.type) &&
95
- node.loc.selector.line == node.arguments.last.last_line &&
96
- node.last_line == node.arguments.last.last_line
96
+ return false unless node.call_type?
97
+
98
+ line = node.loc.selector.nil? ? node.loc.line : node.loc.selector.line
99
+
100
+ line == node.last_argument.last_line &&
101
+ node.last_line == node.last_argument.last_line
97
102
  end
98
103
 
99
104
  # A single argument with the closing bracket on the same line as the end
@@ -11,9 +11,9 @@ module RuboCop
11
11
  # The `AllowNamesEndingInNumbers` config option takes a boolean. When
12
12
  # set to false, this cop will register offenses for names ending with
13
13
  # numbers. Its default is false. The `AllowedNames` config option
14
- # takes an array of whitelisted names that will never register an
14
+ # takes an array of permitted names that will never register an
15
15
  # offense. The `ForbiddenNames` config option takes an array of
16
- # blacklisted names that will always register an offense.
16
+ # restricted names that will always register an offense.
17
17
  #
18
18
  # @example
19
19
  # # bad
@@ -35,7 +35,7 @@ module RuboCop
35
35
  # foo { |speed, distance| speed * distance }
36
36
  #
37
37
  # baz { |age, height, gender| do_stuff(age, height, gender) }
38
- class UncommunicativeBlockParamName < Cop
38
+ class BlockParameterName < Cop
39
39
  include UncommunicativeName
40
40
 
41
41
  def on_block(node)
@@ -50,14 +50,11 @@ module RuboCop
50
50
  def for_bad_filename(file_path)
51
51
  basename = File.basename(file_path)
52
52
  msg = if filename_good?(basename)
53
- return unless expect_matching_definition?
54
- return if find_class_or_module(processed_source.ast,
55
- to_namespace(file_path))
53
+ return if matching_definition?(file_path)
56
54
 
57
55
  no_definition_message(basename, file_path)
58
56
  else
59
- return if ignore_executable_scripts? &&
60
- processed_source.start_with?('#!')
57
+ return if bad_filename_allowed?
61
58
 
62
59
  other_message(basename)
63
60
  end
@@ -65,6 +62,16 @@ module RuboCop
65
62
  yield source_range(processed_source.buffer, 1, 0), msg
66
63
  end
67
64
 
65
+ def matching_definition?(file_path)
66
+ return true unless expect_matching_definition?
67
+
68
+ find_class_or_module(processed_source.ast, to_namespace(file_path))
69
+ end
70
+
71
+ def bad_filename_allowed?
72
+ ignore_executable_scripts? && processed_source.start_with?('#!')
73
+ end
74
+
68
75
  def no_definition_message(basename, file_path)
69
76
  format(MSG_NO_DEFINITION,
70
77
  basename: basename,
@@ -5,7 +5,7 @@ module RuboCop
5
5
  module Naming
6
6
  # This cop checks that your heredocs are using meaningful delimiters.
7
7
  # By default it disallows `END` and `EO*`, and can be configured through
8
- # blacklisting additional delimiters.
8
+ # forbidden listing additional delimiters.
9
9
  #
10
10
  # @example
11
11
  #
@@ -41,13 +41,13 @@ module RuboCop
41
41
 
42
42
  return false unless delimiters =~ /\w/
43
43
 
44
- blacklisted_delimiters.none? do |blacklisted_delimiter|
45
- delimiters =~ Regexp.new(blacklisted_delimiter)
44
+ forbidden_delimiters.none? do |forbidden_delimiter|
45
+ delimiters =~ Regexp.new(forbidden_delimiter)
46
46
  end
47
47
  end
48
48
 
49
- def blacklisted_delimiters
50
- cop_config['Blacklist'] || []
49
+ def forbidden_delimiters
50
+ cop_config['ForbiddenDelimiters'] || []
51
51
  end
52
52
  end
53
53
  end
@@ -11,9 +11,9 @@ module RuboCop
11
11
  # The `AllowNamesEndingInNumbers` config option takes a boolean. When
12
12
  # set to false, this cop will register offenses for names ending with
13
13
  # numbers. Its default is false. The `AllowedNames` config option
14
- # takes an array of whitelisted names that will never register an
14
+ # takes an array of permitted names that will never register an
15
15
  # offense. The `ForbiddenNames` config option takes an array of
16
- # blacklisted names that will always register an offense.
16
+ # restricted names that will always register an offense.
17
17
  #
18
18
  # @example
19
19
  # # bad
@@ -43,7 +43,7 @@ module RuboCop
43
43
  # def baz(age_a, height_b, gender_c)
44
44
  # do_stuff(age_a, height_b, gender_c)
45
45
  # end
46
- class UncommunicativeMethodParamName < Cop
46
+ class MethodParameterName < Cop
47
47
  include UncommunicativeName
48
48
 
49
49
  def on_def(node)
@@ -70,11 +70,11 @@ module RuboCop
70
70
  !method_name.match(/^#{prefix}[^0-9]/) ||
71
71
  method_name == expected_name(method_name, prefix) ||
72
72
  method_name.end_with?('=') ||
73
- predicate_whitelist.include?(method_name)
73
+ allowed_methods.include?(method_name)
74
74
  end
75
75
 
76
76
  def expected_name(method_name, prefix)
77
- new_name = if prefix_blacklist.include?(prefix)
77
+ new_name = if forbidden_prefixes.include?(prefix)
78
78
  method_name.sub(prefix, '')
79
79
  else
80
80
  method_name.dup
@@ -87,16 +87,16 @@ module RuboCop
87
87
  "Rename `#{method_name}` to `#{new_name}`."
88
88
  end
89
89
 
90
- def prefix_blacklist
91
- cop_config['NamePrefixBlacklist']
90
+ def forbidden_prefixes
91
+ cop_config['ForbiddenPrefixes']
92
92
  end
93
93
 
94
94
  def predicate_prefixes
95
95
  cop_config['NamePrefix']
96
96
  end
97
97
 
98
- def predicate_whitelist
99
- cop_config['NameWhitelist']
98
+ def allowed_methods
99
+ cop_config['AllowedMethods']
100
100
  end
101
101
 
102
102
  def method_definition_macros(macro_name)