rubocop 1.9.0 → 1.12.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (275) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +14 -14
  3. data/assets/output.html.erb +1 -1
  4. data/config/default.yml +70 -17
  5. data/config/obsoletion.yml +4 -0
  6. data/lib/rubocop.rb +5 -0
  7. data/lib/rubocop/cli/command/execute_runner.rb +1 -1
  8. data/lib/rubocop/cli/command/suggest_extensions.rb +3 -2
  9. data/lib/rubocop/comment_config.rb +43 -94
  10. data/lib/rubocop/config.rb +4 -1
  11. data/lib/rubocop/cop/base.rb +1 -0
  12. data/lib/rubocop/cop/bundler/duplicated_gem.rb +2 -1
  13. data/lib/rubocop/cop/bundler/gem_comment.rb +1 -0
  14. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +1 -0
  15. data/lib/rubocop/cop/bundler/ordered_gems.rb +1 -0
  16. data/lib/rubocop/cop/correctors/alignment_corrector.rb +3 -6
  17. data/lib/rubocop/cop/exclude_limit.rb +26 -0
  18. data/lib/rubocop/cop/gemspec/date_assignment.rb +57 -0
  19. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +2 -0
  20. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +1 -0
  21. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +2 -0
  22. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +2 -0
  23. data/lib/rubocop/cop/generator.rb +2 -2
  24. data/lib/rubocop/cop/internal_affairs.rb +1 -0
  25. data/lib/rubocop/cop/internal_affairs/example_description.rb +1 -0
  26. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +1 -0
  27. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +2 -0
  28. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +151 -0
  29. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -0
  30. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +2 -0
  31. data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +1 -0
  32. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +1 -0
  33. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -0
  34. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +3 -0
  35. data/lib/rubocop/cop/internal_affairs/style_detected_api_use.rb +4 -0
  36. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -0
  37. data/lib/rubocop/cop/layout/access_modifier_indentation.rb +11 -8
  38. data/lib/rubocop/cop/layout/argument_alignment.rb +6 -5
  39. data/lib/rubocop/cop/layout/array_alignment.rb +7 -6
  40. data/lib/rubocop/cop/layout/assignment_indentation.rb +6 -3
  41. data/lib/rubocop/cop/layout/block_alignment.rb +1 -0
  42. data/lib/rubocop/cop/layout/block_end_newline.rb +4 -8
  43. data/lib/rubocop/cop/layout/class_structure.rb +1 -0
  44. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +14 -15
  45. data/lib/rubocop/cop/layout/comment_indentation.rb +16 -16
  46. data/lib/rubocop/cop/layout/else_alignment.rb +9 -6
  47. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +20 -3
  48. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +37 -17
  49. data/lib/rubocop/cop/layout/extra_spacing.rb +2 -2
  50. data/lib/rubocop/cop/layout/first_argument_indentation.rb +27 -7
  51. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +9 -6
  52. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +22 -15
  53. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +6 -5
  54. data/lib/rubocop/cop/layout/indentation_consistency.rb +9 -6
  55. data/lib/rubocop/cop/layout/indentation_style.rb +27 -30
  56. data/lib/rubocop/cop/layout/indentation_width.rb +20 -9
  57. data/lib/rubocop/cop/layout/line_length.rb +2 -1
  58. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +26 -0
  59. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +18 -5
  60. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +10 -5
  61. data/lib/rubocop/cop/layout/parameter_alignment.rb +6 -5
  62. data/lib/rubocop/cop/layout/space_before_block_braces.rb +1 -1
  63. data/lib/rubocop/cop/layout/space_before_brackets.rb +9 -4
  64. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +1 -1
  65. data/lib/rubocop/cop/lint/big_decimal_new.rb +1 -0
  66. data/lib/rubocop/cop/lint/boolean_symbol.rb +1 -0
  67. data/lib/rubocop/cop/lint/constant_definition_in_block.rb +2 -0
  68. data/lib/rubocop/cop/lint/constant_resolution.rb +1 -0
  69. data/lib/rubocop/cop/lint/debugger.rb +60 -14
  70. data/lib/rubocop/cop/lint/deprecated_constants.rb +5 -0
  71. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +14 -4
  72. data/lib/rubocop/cop/lint/duplicate_branch.rb +1 -1
  73. data/lib/rubocop/cop/lint/duplicate_methods.rb +3 -0
  74. data/lib/rubocop/cop/lint/duplicate_require.rb +3 -2
  75. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -0
  76. data/lib/rubocop/cop/lint/else_layout.rb +1 -1
  77. data/lib/rubocop/cop/lint/erb_new_arguments.rb +1 -0
  78. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +1 -0
  79. data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +1 -0
  80. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +1 -0
  81. data/lib/rubocop/cop/lint/inherit_exception.rb +1 -0
  82. data/lib/rubocop/cop/lint/multiple_comparison.rb +5 -4
  83. data/lib/rubocop/cop/lint/nested_method_definition.rb +3 -0
  84. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -0
  85. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +7 -0
  86. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +3 -0
  87. data/lib/rubocop/cop/lint/number_conversion.rb +11 -2
  88. data/lib/rubocop/cop/lint/raise_exception.rb +2 -0
  89. data/lib/rubocop/cop/lint/rand_one.rb +1 -0
  90. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +1 -2
  91. data/lib/rubocop/cop/lint/redundant_require_statement.rb +1 -0
  92. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +1 -0
  93. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +7 -3
  94. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +1 -0
  95. data/lib/rubocop/cop/lint/redundant_with_index.rb +1 -0
  96. data/lib/rubocop/cop/lint/redundant_with_object.rb +1 -0
  97. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +1 -0
  98. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +1 -0
  99. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +1 -0
  100. data/lib/rubocop/cop/lint/shadowed_argument.rb +1 -0
  101. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +1 -0
  102. data/lib/rubocop/cop/lint/struct_new_override.rb +1 -0
  103. data/lib/rubocop/cop/lint/suppressed_exception.rb +44 -1
  104. data/lib/rubocop/cop/lint/symbol_conversion.rb +91 -3
  105. data/lib/rubocop/cop/lint/to_enum_arguments.rb +3 -0
  106. data/lib/rubocop/cop/lint/unified_integer.rb +1 -0
  107. data/lib/rubocop/cop/lint/unmodified_reduce_accumulator.rb +5 -0
  108. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -0
  109. data/lib/rubocop/cop/lint/unreachable_loop.rb +1 -0
  110. data/lib/rubocop/cop/lint/unused_method_argument.rb +1 -0
  111. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -0
  112. data/lib/rubocop/cop/lint/useless_access_modifier.rb +4 -0
  113. data/lib/rubocop/cop/lint/useless_setter_call.rb +1 -0
  114. data/lib/rubocop/cop/lint/useless_times.rb +3 -0
  115. data/lib/rubocop/cop/message_annotator.rb +4 -1
  116. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  117. data/lib/rubocop/cop/metrics/module_length.rb +1 -0
  118. data/lib/rubocop/cop/metrics/parameter_lists.rb +6 -2
  119. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +6 -4
  120. data/lib/rubocop/cop/metrics/utils/repeated_attribute_discount.rb +2 -0
  121. data/lib/rubocop/cop/mixin/alignment.rb +10 -3
  122. data/lib/rubocop/cop/mixin/check_line_breakable.rb +1 -1
  123. data/lib/rubocop/cop/mixin/code_length.rb +3 -1
  124. data/lib/rubocop/cop/mixin/comments_help.rb +5 -1
  125. data/lib/rubocop/cop/mixin/configurable_max.rb +1 -0
  126. data/lib/rubocop/cop/mixin/def_node.rb +1 -0
  127. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  128. data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +3 -0
  129. data/lib/rubocop/cop/mixin/empty_parameter.rb +1 -0
  130. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -0
  131. data/lib/rubocop/cop/mixin/hash_transform_method.rb +1 -0
  132. data/lib/rubocop/cop/mixin/line_length_help.rb +11 -6
  133. data/lib/rubocop/cop/mixin/method_complexity.rb +4 -1
  134. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +3 -1
  135. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +4 -23
  136. data/lib/rubocop/cop/mixin/negative_conditional.rb +3 -0
  137. data/lib/rubocop/cop/mixin/preferred_delimiters.rb +3 -3
  138. data/lib/rubocop/cop/mixin/rational_literal.rb +1 -0
  139. data/lib/rubocop/cop/mixin/safe_assignment.rb +5 -0
  140. data/lib/rubocop/cop/mixin/uncommunicative_name.rb +4 -6
  141. data/lib/rubocop/cop/mixin/visibility_help.rb +1 -0
  142. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -0
  143. data/lib/rubocop/cop/naming/constant_name.rb +2 -0
  144. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +6 -0
  145. data/lib/rubocop/cop/naming/method_name.rb +3 -0
  146. data/lib/rubocop/cop/naming/predicate_name.rb +1 -0
  147. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +10 -0
  148. data/lib/rubocop/cop/registry.rb +10 -1
  149. data/lib/rubocop/cop/security/eval.rb +1 -0
  150. data/lib/rubocop/cop/security/json_load.rb +1 -0
  151. data/lib/rubocop/cop/security/marshal_load.rb +1 -0
  152. data/lib/rubocop/cop/security/open.rb +1 -0
  153. data/lib/rubocop/cop/security/yaml_load.rb +1 -0
  154. data/lib/rubocop/cop/style/access_modifier_declarations.rb +3 -2
  155. data/lib/rubocop/cop/style/alias.rb +1 -0
  156. data/lib/rubocop/cop/style/and_or.rb +3 -1
  157. data/lib/rubocop/cop/style/arguments_forwarding.rb +3 -0
  158. data/lib/rubocop/cop/style/array_coercion.rb +2 -0
  159. data/lib/rubocop/cop/style/array_join.rb +1 -0
  160. data/lib/rubocop/cop/style/attr.rb +1 -0
  161. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +59 -71
  162. data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +62 -0
  163. data/lib/rubocop/cop/style/case_equality.rb +2 -1
  164. data/lib/rubocop/cop/style/case_like_if.rb +15 -4
  165. data/lib/rubocop/cop/style/class_equality_comparison.rb +3 -0
  166. data/lib/rubocop/cop/style/collection_compact.rb +2 -0
  167. data/lib/rubocop/cop/style/colon_method_call.rb +1 -0
  168. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  169. data/lib/rubocop/cop/style/commented_keyword.rb +10 -10
  170. data/lib/rubocop/cop/style/conditional_assignment.rb +2 -0
  171. data/lib/rubocop/cop/style/constant_visibility.rb +28 -0
  172. data/lib/rubocop/cop/style/date_time.rb +3 -0
  173. data/lib/rubocop/cop/style/dir.rb +1 -0
  174. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  175. data/lib/rubocop/cop/style/documentation.rb +30 -3
  176. data/lib/rubocop/cop/style/documentation_method.rb +1 -0
  177. data/lib/rubocop/cop/style/double_negation.rb +3 -2
  178. data/lib/rubocop/cop/style/each_for_simple_loop.rb +1 -0
  179. data/lib/rubocop/cop/style/each_with_object.rb +1 -0
  180. data/lib/rubocop/cop/style/empty_literal.rb +9 -0
  181. data/lib/rubocop/cop/style/endless_method.rb +1 -0
  182. data/lib/rubocop/cop/style/eval_with_location.rb +90 -28
  183. data/lib/rubocop/cop/style/even_odd.rb +1 -0
  184. data/lib/rubocop/cop/style/expand_path_arguments.rb +3 -0
  185. data/lib/rubocop/cop/style/explicit_block_argument.rb +2 -1
  186. data/lib/rubocop/cop/style/exponential_notation.rb +6 -7
  187. data/lib/rubocop/cop/style/float_division.rb +4 -0
  188. data/lib/rubocop/cop/style/format_string.rb +2 -0
  189. data/lib/rubocop/cop/style/format_string_token.rb +1 -0
  190. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +0 -3
  191. data/lib/rubocop/cop/style/global_std_stream.rb +1 -0
  192. data/lib/rubocop/cop/style/hash_conversion.rb +108 -0
  193. data/lib/rubocop/cop/style/hash_each_methods.rb +1 -0
  194. data/lib/rubocop/cop/style/hash_except.rb +1 -0
  195. data/lib/rubocop/cop/style/hash_like_case.rb +1 -0
  196. data/lib/rubocop/cop/style/hash_syntax.rb +16 -15
  197. data/lib/rubocop/cop/style/hash_transform_keys.rb +4 -0
  198. data/lib/rubocop/cop/style/hash_transform_values.rb +4 -0
  199. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +37 -11
  200. data/lib/rubocop/cop/style/implicit_runtime_error.rb +1 -0
  201. data/lib/rubocop/cop/style/inverse_methods.rb +2 -0
  202. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +46 -2
  203. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +19 -3
  204. data/lib/rubocop/cop/style/min_max.rb +1 -0
  205. data/lib/rubocop/cop/style/mixin_usage.rb +2 -0
  206. data/lib/rubocop/cop/style/module_function.rb +5 -0
  207. data/lib/rubocop/cop/style/multiline_method_signature.rb +10 -3
  208. data/lib/rubocop/cop/style/multiple_comparison.rb +21 -2
  209. data/lib/rubocop/cop/style/mutable_constant.rb +3 -0
  210. data/lib/rubocop/cop/style/negated_if_else_condition.rb +16 -2
  211. data/lib/rubocop/cop/style/nil_comparison.rb +6 -1
  212. data/lib/rubocop/cop/style/nil_lambda.rb +1 -0
  213. data/lib/rubocop/cop/style/non_nil_check.rb +7 -0
  214. data/lib/rubocop/cop/style/numeric_literals.rb +6 -9
  215. data/lib/rubocop/cop/style/numeric_predicate.rb +4 -1
  216. data/lib/rubocop/cop/style/option_hash.rb +1 -0
  217. data/lib/rubocop/cop/style/or_assignment.rb +2 -0
  218. data/lib/rubocop/cop/style/parallel_assignment.rb +6 -0
  219. data/lib/rubocop/cop/style/parentheses_around_condition.rb +1 -0
  220. data/lib/rubocop/cop/style/proc.rb +1 -0
  221. data/lib/rubocop/cop/style/random_with_offset.rb +5 -0
  222. data/lib/rubocop/cop/style/redundant_assignment.rb +1 -0
  223. data/lib/rubocop/cop/style/redundant_begin.rb +44 -4
  224. data/lib/rubocop/cop/style/redundant_conditional.rb +2 -0
  225. data/lib/rubocop/cop/style/redundant_exception.rb +2 -0
  226. data/lib/rubocop/cop/style/redundant_fetch_block.rb +2 -0
  227. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +1 -0
  228. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -0
  229. data/lib/rubocop/cop/style/redundant_parentheses.rb +13 -0
  230. data/lib/rubocop/cop/style/redundant_return.rb +4 -0
  231. data/lib/rubocop/cop/style/redundant_self.rb +7 -3
  232. data/lib/rubocop/cop/style/redundant_self_assignment.rb +2 -0
  233. data/lib/rubocop/cop/style/redundant_sort.rb +1 -0
  234. data/lib/rubocop/cop/style/redundant_sort_by.rb +1 -0
  235. data/lib/rubocop/cop/style/regexp_literal.rb +1 -1
  236. data/lib/rubocop/cop/style/rescue_modifier.rb +17 -14
  237. data/lib/rubocop/cop/style/rescue_standard_error.rb +2 -0
  238. data/lib/rubocop/cop/style/return_nil.rb +6 -0
  239. data/lib/rubocop/cop/style/safe_navigation.rb +2 -0
  240. data/lib/rubocop/cop/style/sample.rb +1 -0
  241. data/lib/rubocop/cop/style/signal_exception.rb +3 -0
  242. data/lib/rubocop/cop/style/single_argument_dig.rb +1 -0
  243. data/lib/rubocop/cop/style/single_line_methods.rb +4 -1
  244. data/lib/rubocop/cop/style/slicing_with_range.rb +1 -0
  245. data/lib/rubocop/cop/style/sole_nested_conditional.rb +20 -4
  246. data/lib/rubocop/cop/style/special_global_vars.rb +3 -3
  247. data/lib/rubocop/cop/style/stderr_puts.rb +1 -0
  248. data/lib/rubocop/cop/style/string_chars.rb +38 -0
  249. data/lib/rubocop/cop/style/string_concatenation.rb +1 -0
  250. data/lib/rubocop/cop/style/string_hash_keys.rb +2 -0
  251. data/lib/rubocop/cop/style/strip.rb +1 -0
  252. data/lib/rubocop/cop/style/struct_inheritance.rb +3 -0
  253. data/lib/rubocop/cop/style/symbol_proc.rb +25 -1
  254. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -0
  255. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +5 -0
  256. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +1 -1
  257. data/lib/rubocop/cop/style/trivial_accessors.rb +1 -0
  258. data/lib/rubocop/cop/style/unless_logical_operators.rb +105 -0
  259. data/lib/rubocop/cop/style/unpack_first.rb +1 -0
  260. data/lib/rubocop/cop/style/yoda_condition.rb +1 -0
  261. data/lib/rubocop/cop/style/zero_length_predicate.rb +5 -0
  262. data/lib/rubocop/cop/util.rb +4 -1
  263. data/lib/rubocop/directive_comment.rb +69 -9
  264. data/lib/rubocop/ext/regexp_parser.rb +3 -6
  265. data/lib/rubocop/formatter/clang_style_formatter.rb +4 -2
  266. data/lib/rubocop/formatter/offense_count_formatter.rb +1 -1
  267. data/lib/rubocop/formatter/simple_text_formatter.rb +2 -1
  268. data/lib/rubocop/formatter/tap_formatter.rb +4 -2
  269. data/lib/rubocop/formatter/worst_offenders_formatter.rb +1 -1
  270. data/lib/rubocop/magic_comment.rb +1 -1
  271. data/lib/rubocop/name_similarity.rb +1 -1
  272. data/lib/rubocop/target_finder.rb +1 -0
  273. data/lib/rubocop/target_ruby.rb +21 -13
  274. data/lib/rubocop/version.rb +1 -1
  275. metadata +14 -7
@@ -74,7 +74,7 @@ module RuboCop
74
74
  # else 250
75
75
  # end
76
76
  #
77
- # @example IgnoreLiteralBranches: true
77
+ # @example IgnoreConstantBranches: true
78
78
  # # good
79
79
  # case size
80
80
  # when "small" then SMALL_SIZE
@@ -82,6 +82,7 @@ module RuboCop
82
82
  end
83
83
  end
84
84
 
85
+ # @!method method_alias?(node)
85
86
  def_node_matcher :method_alias?, <<~PATTERN
86
87
  (alias (sym $_name) sym)
87
88
  PATTERN
@@ -94,10 +95,12 @@ module RuboCop
94
95
  found_instance_method(node, name)
95
96
  end
96
97
 
98
+ # @!method alias_method?(node)
97
99
  def_node_matcher :alias_method?, <<~PATTERN
98
100
  (send nil? :alias_method (sym $_name) _)
99
101
  PATTERN
100
102
 
103
+ # @!method sym_name(node)
101
104
  def_node_matcher :sym_name, '(sym $_name)'
102
105
  def on_send(node)
103
106
  if (name = alias_method?(node))
@@ -21,11 +21,12 @@ module RuboCop
21
21
  #
22
22
  class DuplicateRequire < Base
23
23
  MSG = 'Duplicate `%<method>s` detected.'
24
- REQUIRE_METHODS = %i[require require_relative].freeze
24
+ REQUIRE_METHODS = Set.new(%i[require require_relative]).freeze
25
25
  RESTRICT_ON_SEND = REQUIRE_METHODS
26
26
 
27
+ # @!method require_call?(node)
27
28
  def_node_matcher :require_call?, <<~PATTERN
28
- (send {nil? (const _ :Kernel)} {:#{REQUIRE_METHODS.join(' :')}} _)
29
+ (send {nil? (const _ :Kernel)} %REQUIRE_METHODS _)
29
30
  PATTERN
30
31
 
31
32
  def on_new_investigation
@@ -25,6 +25,7 @@ module RuboCop
25
25
  MSG = 'The argument to each_with_object cannot be immutable.'
26
26
  RESTRICT_ON_SEND = %i[each_with_object].freeze
27
27
 
28
+ # @!method each_with_object?(node)
28
29
  def_node_matcher :each_with_object?, <<~PATTERN
29
30
  ({send csend} _ :each_with_object $_)
30
31
  PATTERN
@@ -47,7 +47,7 @@ module RuboCop
47
47
  MSG = 'Odd `else` layout detected. Did you mean to use `elsif`?'
48
48
 
49
49
  def on_if(node)
50
- return if node.ternary? || node.elsif?
50
+ return if node.ternary?
51
51
 
52
52
  check(node)
53
53
  end
@@ -80,6 +80,7 @@ module RuboCop
80
80
 
81
81
  RESTRICT_ON_SEND = %i[new].freeze
82
82
 
83
+ # @!method erb_new_with_non_keyword_arguments(node)
83
84
  def_node_matcher :erb_new_with_non_keyword_arguments, <<~PATTERN
84
85
  (send
85
86
  (const {nil? cbase} :ERB) :new $...)
@@ -92,6 +92,7 @@ module RuboCop
92
92
  end
93
93
  end
94
94
 
95
+ # @!method called_on_string?(node)
95
96
  def_node_matcher :called_on_string?, <<~PATTERN
96
97
  {(send {nil? const_type?} _ (str _) ...)
97
98
  (send (str ...) ...)}
@@ -24,6 +24,7 @@ module RuboCop
24
24
 
25
25
  MSG = 'Use `Hash#compare_by_identity` instead of using `object_id` for keys.'
26
26
 
27
+ # @!method id_as_hash_key?(node)
27
28
  def_node_matcher :id_as_hash_key?, <<~PATTERN
28
29
  (send _ {:key? :has_key? :fetch :[] :[]=} (send _ :object_id) ...)
29
30
  PATTERN
@@ -53,6 +53,7 @@ module RuboCop
53
53
  ALTERNATIVE_PROTECTED = '`protected` inside a `class << self` ' \
54
54
  'block'
55
55
 
56
+ # @!method private_class_methods(node)
56
57
  def_node_search :private_class_methods, <<~PATTERN
57
58
  (send nil? :private_class_method $...)
58
59
  PATTERN
@@ -58,6 +58,7 @@ module RuboCop
58
58
 
59
59
  RESTRICT_ON_SEND = %i[new].freeze
60
60
 
61
+ # @!method class_new_call?(node)
61
62
  def_node_matcher :class_new_call?, <<~PATTERN
62
63
  (send
63
64
  (const {cbase nil?} :Class) :new
@@ -11,14 +11,10 @@ module RuboCop
11
11
  # @example
12
12
  #
13
13
  # # bad
14
- #
15
14
  # x < y < z
16
15
  # 10 <= x <= 20
17
16
  #
18
- # @example
19
- #
20
17
  # # good
21
- #
22
18
  # x < y && y < z
23
19
  # 10 <= x && x <= 20
24
20
  class MultipleComparison < Base
@@ -26,14 +22,19 @@ module RuboCop
26
22
 
27
23
  MSG = 'Use the `&&` operator to compare multiple values.'
28
24
  COMPARISON_METHODS = %i[< > <= >=].freeze
25
+ SET_OPERATION_OPERATORS = %i[& | ^].freeze
29
26
  RESTRICT_ON_SEND = COMPARISON_METHODS
30
27
 
28
+ # @!method multiple_compare?(node)
31
29
  def_node_matcher :multiple_compare?, <<~PATTERN
32
30
  (send (send _ {:< :> :<= :>=} $_) {:#{COMPARISON_METHODS.join(' :')}} _)
33
31
  PATTERN
34
32
 
35
33
  def on_send(node)
36
34
  return unless (center = multiple_compare?(node))
35
+ # It allows multiple comparison using `&`, `|`, and `^` set operation operators.
36
+ # e.g. `x >= y & y < z`
37
+ return if center.send_type? && SET_OPERATION_OPERATORS.include?(center.method_name)
37
38
 
38
39
  add_offense(node) do |corrector|
39
40
  new_center = "#{center.source} && #{center.source}"
@@ -81,14 +81,17 @@ module RuboCop
81
81
  class_or_module_or_struct_new_call?(child)
82
82
  end
83
83
 
84
+ # @!method eval_call?(node)
84
85
  def_node_matcher :eval_call?, <<~PATTERN
85
86
  (block (send _ {:instance_eval :class_eval :module_eval} ...) ...)
86
87
  PATTERN
87
88
 
89
+ # @!method exec_call?(node)
88
90
  def_node_matcher :exec_call?, <<~PATTERN
89
91
  (block (send _ {:instance_exec :class_exec :module_exec} ...) ...)
90
92
  PATTERN
91
93
 
94
+ # @!method class_or_module_or_struct_new_call?(node)
92
95
  def_node_matcher :class_or_module_or_struct_new_call?, <<~PATTERN
93
96
  (block (send (const {nil? cbase} {:Class :Module :Struct}) :new ...) ...)
94
97
  PATTERN
@@ -25,6 +25,7 @@ module RuboCop
25
25
  class NextWithoutAccumulator < Base
26
26
  MSG = 'Use `next` with an accumulator argument in a `reduce`.'
27
27
 
28
+ # @!method on_body_of_reduce(node)
28
29
  def_node_matcher :on_body_of_reduce, <<~PATTERN
29
30
  (block (send _recv {:reduce :inject} !sym) _blockargs $(begin ...))
30
31
  PATTERN
@@ -129,32 +129,39 @@ module RuboCop
129
129
  unsorted_dir_glob_pass?(node) || unsorted_dir_each_pass?(node)
130
130
  end
131
131
 
132
+ # @!method unsorted_dir_block?(node)
132
133
  def_node_matcher :unsorted_dir_block?, <<~PATTERN
133
134
  (send (const {nil? cbase} :Dir) :glob ...)
134
135
  PATTERN
135
136
 
137
+ # @!method unsorted_dir_each?(node)
136
138
  def_node_matcher :unsorted_dir_each?, <<~PATTERN
137
139
  (send (send (const {nil? cbase} :Dir) {:[] :glob} ...) :each)
138
140
  PATTERN
139
141
 
142
+ # @!method method_require?(node)
140
143
  def_node_matcher :method_require?, <<~PATTERN
141
144
  (block-pass (send nil? :method (sym :require)))
142
145
  PATTERN
143
146
 
147
+ # @!method unsorted_dir_glob_pass?(node)
144
148
  def_node_matcher :unsorted_dir_glob_pass?, <<~PATTERN
145
149
  (send (const {nil? cbase} :Dir) :glob ...
146
150
  (block-pass (send nil? :method (sym :require))))
147
151
  PATTERN
148
152
 
153
+ # @!method unsorted_dir_each_pass?(node)
149
154
  def_node_matcher :unsorted_dir_each_pass?, <<~PATTERN
150
155
  (send (send (const {nil? cbase} :Dir) {:[] :glob} ...) :each
151
156
  (block-pass (send nil? :method (sym :require))))
152
157
  PATTERN
153
158
 
159
+ # @!method loop_variable(node)
154
160
  def_node_matcher :loop_variable, <<~PATTERN
155
161
  (args (arg $_))
156
162
  PATTERN
157
163
 
164
+ # @!method var_is_required?(node, name)
158
165
  def_node_search :var_is_required?, <<~PATTERN
159
166
  (send nil? :require (lvar %1))
160
167
  PATTERN
@@ -73,7 +73,10 @@ module RuboCop
73
73
  !return_node.children.empty?
74
74
  end
75
75
 
76
+ # @!method chained_send?(node)
76
77
  def_node_matcher :chained_send?, '(send !nil? ...)'
78
+
79
+ # @!method define_method?(node)
77
80
  def_node_matcher :define_method?, <<~PATTERN
78
81
  (send _ {:define_method :define_singleton_method} _)
79
82
  PATTERN
@@ -58,14 +58,16 @@ module RuboCop
58
58
  }.freeze
59
59
  MSG = 'Replace unsafe number conversion with number '\
60
60
  'class parsing, instead of using '\
61
- '%<current>s, use stricter '\
62
- '%<corrected_method>s.'
61
+ '`%<current>s`, use stricter '\
62
+ '`%<corrected_method>s`.'
63
63
  METHODS = CONVERSION_METHOD_CLASS_MAPPING.keys.map(&:inspect).join(' ')
64
64
 
65
+ # @!method to_method(node)
65
66
  def_node_matcher :to_method, <<~PATTERN
66
67
  (send $_ ${#{METHODS}})
67
68
  PATTERN
68
69
 
70
+ # @!method to_method_symbol(node)
69
71
  def_node_matcher :to_method_symbol, <<~PATTERN
70
72
  {(send _ $_ ${(sym ${#{METHODS}})} ...)
71
73
  (send _ $_ ${(block_pass (sym ${#{METHODS}}))} ...)}
@@ -103,6 +105,8 @@ module RuboCop
103
105
  corrected_method: correct_sym_method(to_method)
104
106
  )
105
107
  add_offense(node, message: message) do |corrector|
108
+ remove_parentheses(corrector, node) if node.parenthesized?
109
+
106
110
  corrector.replace(sym_node, correct_sym_method(to_method))
107
111
  end
108
112
  end
@@ -118,6 +122,11 @@ module RuboCop
118
122
  "{ |i| #{body} }"
119
123
  end
120
124
 
125
+ def remove_parentheses(corrector, node)
126
+ corrector.replace(node.loc.begin, ' ')
127
+ corrector.remove(node.loc.end)
128
+ end
129
+
121
130
  def ignore_receiver?(receiver)
122
131
  if receiver.send_type? && ignored_method?(receiver.method_name)
123
132
  true
@@ -33,10 +33,12 @@ module RuboCop
33
33
  MSG = 'Use `StandardError` over `Exception`.'
34
34
  RESTRICT_ON_SEND = %i[raise fail].freeze
35
35
 
36
+ # @!method exception?(node)
36
37
  def_node_matcher :exception?, <<~PATTERN
37
38
  (send nil? {:raise :fail} $(const ${cbase nil?} :Exception) ... )
38
39
  PATTERN
39
40
 
41
+ # @!method exception_new_with_message?(node)
40
42
  def_node_matcher :exception_new_with_message?, <<~PATTERN
41
43
  (send nil? {:raise :fail}
42
44
  (send $(const ${cbase nil?} :Exception) :new ... ))
@@ -25,6 +25,7 @@ module RuboCop
25
25
  'Perhaps you meant `rand(2)` or `rand`?'
26
26
  RESTRICT_ON_SEND = %i[rand].freeze
27
27
 
28
+ # @!method rand_one?(node)
28
29
  def_node_matcher :rand_one?, <<~PATTERN
29
30
  (send {(const {nil? cbase} :Kernel) nil?} :rand {(int {-1 1}) (float {-1.0 1.0})})
30
31
  PATTERN
@@ -174,8 +174,7 @@ module RuboCop
174
174
  end
175
175
 
176
176
  def directive_count(comment)
177
- match = comment.text.match(CommentConfig::COMMENT_DIRECTIVE_REGEXP)
178
- _, cops_string = match.captures
177
+ _, cops_string = DirectiveComment.new(comment).match_captures
179
178
  cops_string.split(/,\s*/).size
180
179
  end
181
180
 
@@ -28,6 +28,7 @@ module RuboCop
28
28
  MSG = 'Remove unnecessary `require` statement.'
29
29
  RESTRICT_ON_SEND = %i[require].freeze
30
30
 
31
+ # @!method unnecessary_require_statement?(node)
31
32
  def_node_matcher :unnecessary_require_statement?, <<~PATTERN
32
33
  (send nil? :require
33
34
  (str {"enumerator" "rational" "complex" "thread"}))
@@ -43,6 +43,7 @@ module RuboCop
43
43
 
44
44
  NIL_SPECIFIC_METHODS = (nil.methods - Object.new.methods).to_set.freeze
45
45
 
46
+ # @!method respond_to_nil_specific_method?(node)
46
47
  def_node_matcher :respond_to_nil_specific_method?, <<~PATTERN
47
48
  (csend _ :respond_to? (sym %NIL_SPECIFIC_METHODS))
48
49
  PATTERN
@@ -79,6 +79,7 @@ module RuboCop
79
79
  PERCENT_CAPITAL_I = '%I'
80
80
  ASSIGNMENT_TYPES = %i[lvasgn ivasgn cvasgn gvasgn].freeze
81
81
 
82
+ # @!method array_new?(node)
82
83
  def_node_matcher :array_new?, <<~PATTERN
83
84
  {
84
85
  $(send (const {nil? cbase} :Array) :new ...)
@@ -86,6 +87,7 @@ module RuboCop
86
87
  }
87
88
  PATTERN
88
89
 
90
+ # @!method literal_expansion(node)
89
91
  def_node_matcher :literal_expansion, <<~PATTERN
90
92
  (splat {$({str dstr int float array} ...) (block $#array_new? ...) $#array_new?} ...)
91
93
  PATTERN
@@ -140,13 +142,15 @@ module RuboCop
140
142
  def replacement_range_and_content(node)
141
143
  variable, = *node
142
144
  loc = node.loc
145
+ expression = loc.expression
143
146
 
144
147
  if array_new?(variable)
145
- [node.parent.loc.expression, variable.source]
148
+ expression = node.parent.loc.expression if node.parent.array_type?
149
+ [expression, variable.source]
146
150
  elsif !variable.array_type?
147
- [loc.expression, "[#{variable.source}]"]
151
+ [expression, "[#{variable.source}]"]
148
152
  elsif redundant_brackets?(node)
149
- [loc.expression, remove_brackets(variable)]
153
+ [expression, remove_brackets(variable)]
150
154
  else
151
155
  [loc.operator, '']
152
156
  end
@@ -25,6 +25,7 @@ module RuboCop
25
25
  MSG_SELF = 'Use `self` instead of `Object#to_s` in ' \
26
26
  'interpolation.'
27
27
 
28
+ # @!method to_s_without_args?(node)
28
29
  def_node_matcher :to_s_without_args?, '(send _ :to_s)'
29
30
 
30
31
  def on_interpolation(begin_node)
@@ -33,6 +33,7 @@ module RuboCop
33
33
  MSG_EACH_WITH_INDEX = 'Use `each` instead of `each_with_index`.'
34
34
  MSG_WITH_INDEX = 'Remove redundant `with_index`.'
35
35
 
36
+ # @!method redundant_with_index?(node)
36
37
  def_node_matcher :redundant_with_index?, <<~PATTERN
37
38
  (block
38
39
  $(send
@@ -34,6 +34,7 @@ module RuboCop
34
34
 
35
35
  MSG_WITH_OBJECT = 'Remove redundant `with_object`.'
36
36
 
37
+ # @!method redundant_with_object?(node)
37
38
  def_node_matcher :redundant_with_object?, <<~PATTERN
38
39
  (block
39
40
  $(send _ {:each_with_object :with_object}
@@ -29,6 +29,7 @@ module RuboCop
29
29
  MSG = 'Do not chain ordinary method call' \
30
30
  ' after safe navigation operator.'
31
31
 
32
+ # @!method bad_method?(node)
32
33
  def_node_matcher :bad_method?, <<~PATTERN
33
34
  {
34
35
  (send $(csend ...) $_ ...)
@@ -25,6 +25,7 @@ module RuboCop
25
25
  MSG = 'Avoid calling `empty?` with the safe navigation operator ' \
26
26
  'in conditionals.'
27
27
 
28
+ # @!method safe_navigation_empty_in_conditional?(node)
28
29
  def_node_matcher :safe_navigation_empty_in_conditional?, <<~PATTERN
29
30
  (if (csend (send ...) :empty?) ...)
30
31
  PATTERN
@@ -43,6 +43,7 @@ module RuboCop
43
43
  SEND_METHODS = %i[send public_send __send__].freeze
44
44
  RESTRICT_ON_SEND = SEND_METHODS
45
45
 
46
+ # @!method send_with_mixin_argument?(node)
46
47
  def_node_matcher :send_with_mixin_argument?, <<~PATTERN
47
48
  (send
48
49
  (const _ _) {:#{SEND_METHODS.join(' :')}}
@@ -67,6 +67,7 @@ module RuboCop
67
67
  MSG = 'Argument `%<argument>s` was shadowed by a local variable ' \
68
68
  'before it was used.'
69
69
 
70
+ # @!method uses_var?(node)
70
71
  def_node_search :uses_var?, '(lvar %)'
71
72
 
72
73
  def self.joining_forces
@@ -42,6 +42,7 @@ module RuboCop
42
42
  class ShadowingOuterLocalVariable < Base
43
43
  MSG = 'Shadowing outer local variable - `%<variable>s`.'
44
44
 
45
+ # @!method ractor_block?(node)
45
46
  def_node_matcher :ractor_block?, <<~PATTERN
46
47
  (block (send (const nil? :Ractor) :new ...) ...)
47
48
  PATTERN
@@ -29,6 +29,7 @@ module RuboCop
29
29
  STRUCT_METHOD_NAMES = Struct.instance_methods
30
30
  STRUCT_MEMBER_NAME_TYPES = %i[sym str].freeze
31
31
 
32
+ # @!method struct_new(node)
32
33
  def_node_matcher :struct_new, <<~PATTERN
33
34
  (send
34
35
  (const ${nil? cbase} :Struct) :new ...)
@@ -64,12 +64,51 @@ module RuboCop
64
64
  # rescue
65
65
  # # do nothing
66
66
  # end
67
+ #
68
+ # @example AllowNil: true (default)
69
+ #
70
+ # # good
71
+ # def some_method
72
+ # do_something
73
+ # rescue
74
+ # nil
75
+ # end
76
+ #
77
+ # # good
78
+ # begin
79
+ # do_something
80
+ # rescue
81
+ # # do nothing
82
+ # end
83
+ #
84
+ # # good
85
+ # do_something rescue nil
86
+ #
87
+ # @example AllowNil: false
88
+ #
89
+ # # bad
90
+ # def some_method
91
+ # do_something
92
+ # rescue
93
+ # nil
94
+ # end
95
+ #
96
+ # # bad
97
+ # begin
98
+ # do_something
99
+ # rescue
100
+ # nil
101
+ # end
102
+ #
103
+ # # bad
104
+ # do_something rescue nil
67
105
  class SuppressedException < Base
68
106
  MSG = 'Do not suppress exceptions.'
69
107
 
70
108
  def on_resbody(node)
71
- return if node.body
109
+ return if node.body && !nil_body?(node)
72
110
  return if cop_config['AllowComments'] && comment_between_rescue_and_end?(node)
111
+ return if cop_config['AllowNil'] && nil_body?(node)
73
112
 
74
113
  add_offense(node)
75
114
  end
@@ -83,6 +122,10 @@ module RuboCop
83
122
  end_line = ancestor.loc.end.line
84
123
  processed_source[node.first_line...end_line].any? { |line| comment_line?(line) }
85
124
  end
125
+
126
+ def nil_body?(node)
127
+ node.body&.nil_type?
128
+ end
86
129
  end
87
130
  end
88
131
  end