rubocop 0.87.1 → 0.89.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 (339) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/bin/rubocop-profile +32 -0
  4. data/config/default.yml +153 -22
  5. data/lib/rubocop.rb +22 -4
  6. data/lib/rubocop/cli.rb +2 -2
  7. data/lib/rubocop/cli/command/auto_genenerate_config.rb +3 -3
  8. data/lib/rubocop/cli/command/base.rb +1 -0
  9. data/lib/rubocop/cli/command/execute_runner.rb +1 -1
  10. data/lib/rubocop/cli/command/show_cops.rb +2 -2
  11. data/lib/rubocop/cli/command/version.rb +2 -2
  12. data/lib/rubocop/comment_config.rb +5 -7
  13. data/lib/rubocop/config.rb +20 -3
  14. data/lib/rubocop/config_loader.rb +22 -9
  15. data/lib/rubocop/config_loader_resolver.rb +3 -3
  16. data/lib/rubocop/config_obsoletion.rb +6 -1
  17. data/lib/rubocop/config_store.rb +4 -0
  18. data/lib/rubocop/config_validator.rb +2 -4
  19. data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
  20. data/lib/rubocop/cop/badge.rb +1 -1
  21. data/lib/rubocop/cop/base.rb +14 -6
  22. data/lib/rubocop/cop/commissioner.rb +0 -1
  23. data/lib/rubocop/cop/cop.rb +1 -1
  24. data/lib/rubocop/cop/correctors/line_break_corrector.rb +4 -4
  25. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -0
  26. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -2
  27. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  28. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +15 -18
  29. data/lib/rubocop/cop/force.rb +1 -0
  30. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +38 -12
  31. data/lib/rubocop/cop/generator/configuration_injector.rb +2 -2
  32. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +4 -12
  33. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +1 -1
  34. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +8 -8
  35. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +10 -7
  36. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +7 -8
  37. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -2
  38. data/lib/rubocop/cop/layout/block_alignment.rb +1 -1
  39. data/lib/rubocop/cop/layout/class_structure.rb +3 -7
  40. data/lib/rubocop/cop/layout/comment_indentation.rb +1 -1
  41. data/lib/rubocop/cop/layout/empty_lines.rb +0 -2
  42. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +1 -0
  43. data/lib/rubocop/cop/layout/end_alignment.rb +3 -2
  44. data/lib/rubocop/cop/layout/extra_spacing.rb +22 -36
  45. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -1
  46. data/lib/rubocop/cop/layout/heredoc_indentation.rb +2 -2
  47. data/lib/rubocop/cop/layout/indentation_style.rb +0 -2
  48. data/lib/rubocop/cop/layout/leading_comment_space.rb +1 -1
  49. data/lib/rubocop/cop/layout/multiline_block_layout.rb +16 -5
  50. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +1 -1
  51. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +0 -2
  52. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +3 -2
  53. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +33 -66
  54. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +3 -2
  55. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +7 -4
  56. data/lib/rubocop/cop/lint/ambiguous_operator.rb +15 -10
  57. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +11 -13
  58. data/lib/rubocop/cop/lint/assignment_in_condition.rb +2 -2
  59. data/lib/rubocop/cop/lint/big_decimal_new.rb +10 -10
  60. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +50 -0
  61. data/lib/rubocop/cop/lint/boolean_symbol.rb +16 -11
  62. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  63. data/lib/rubocop/cop/lint/constant_resolution.rb +1 -1
  64. data/lib/rubocop/cop/lint/debugger.rb +7 -1
  65. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +9 -10
  66. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +17 -13
  67. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +8 -2
  68. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  69. data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +39 -0
  70. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -1
  71. data/lib/rubocop/cop/lint/duplicate_methods.rb +9 -6
  72. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +60 -0
  73. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  74. data/lib/rubocop/cop/lint/else_layout.rb +1 -1
  75. data/lib/rubocop/cop/lint/empty_conditional_body.rb +67 -0
  76. data/lib/rubocop/cop/lint/empty_ensure.rb +5 -5
  77. data/lib/rubocop/cop/lint/empty_expression.rb +2 -2
  78. data/lib/rubocop/cop/lint/empty_interpolation.rb +5 -6
  79. data/lib/rubocop/cop/lint/empty_when.rb +2 -2
  80. data/lib/rubocop/cop/lint/ensure_return.rb +27 -29
  81. data/lib/rubocop/cop/lint/erb_new_arguments.rb +11 -10
  82. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  83. data/lib/rubocop/cop/lint/float_comparison.rb +93 -0
  84. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -1
  85. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +5 -4
  86. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +13 -14
  87. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +5 -4
  88. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +8 -8
  89. data/lib/rubocop/cop/lint/inherit_exception.rb +12 -7
  90. data/lib/rubocop/cop/lint/interpolation_check.rb +18 -15
  91. data/lib/rubocop/cop/lint/literal_as_condition.rb +14 -2
  92. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +7 -7
  93. data/lib/rubocop/cop/lint/loop.rb +23 -2
  94. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +6 -5
  95. data/lib/rubocop/cop/lint/missing_super.rb +99 -0
  96. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -1
  97. data/lib/rubocop/cop/lint/multiple_comparison.rb +6 -9
  98. data/lib/rubocop/cop/lint/nested_method_definition.rb +14 -20
  99. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  100. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
  101. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +82 -11
  102. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +2 -2
  103. data/lib/rubocop/cop/lint/number_conversion.rb +6 -9
  104. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +11 -13
  105. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +90 -0
  106. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +4 -10
  107. data/lib/rubocop/cop/lint/percent_string_array.rb +13 -12
  108. data/lib/rubocop/cop/lint/percent_symbol_array.rb +13 -12
  109. data/lib/rubocop/cop/lint/raise_exception.rb +12 -10
  110. data/lib/rubocop/cop/lint/rand_one.rb +2 -2
  111. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +16 -19
  112. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +7 -11
  113. data/lib/rubocop/cop/lint/redundant_require_statement.rb +4 -7
  114. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +13 -9
  115. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +6 -13
  116. data/lib/rubocop/cop/lint/redundant_with_index.rb +11 -14
  117. data/lib/rubocop/cop/lint/redundant_with_object.rb +11 -14
  118. data/lib/rubocop/cop/lint/regexp_as_condition.rb +4 -6
  119. data/lib/rubocop/cop/lint/require_parentheses.rb +2 -2
  120. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  121. data/lib/rubocop/cop/lint/rescue_type.rb +8 -8
  122. data/lib/rubocop/cop/lint/return_in_void_context.rb +2 -4
  123. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +3 -6
  124. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +14 -10
  125. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +7 -7
  126. data/lib/rubocop/cop/lint/script_permission.rb +10 -7
  127. data/lib/rubocop/cop/lint/self_assignment.rb +78 -0
  128. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +5 -11
  129. data/lib/rubocop/cop/lint/shadowed_argument.rb +3 -3
  130. data/lib/rubocop/cop/lint/shadowed_exception.rb +2 -2
  131. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +3 -3
  132. data/lib/rubocop/cop/lint/struct_new_override.rb +1 -1
  133. data/lib/rubocop/cop/lint/suppressed_exception.rb +4 -7
  134. data/lib/rubocop/cop/lint/to_json.rb +4 -6
  135. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +34 -0
  136. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +4 -4
  137. data/lib/rubocop/cop/lint/unified_integer.rb +4 -6
  138. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -1
  139. data/lib/rubocop/cop/lint/unreachable_loop.rb +174 -0
  140. data/lib/rubocop/cop/lint/unused_block_argument.rb +8 -3
  141. data/lib/rubocop/cop/lint/unused_method_argument.rb +8 -3
  142. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  143. data/lib/rubocop/cop/lint/uri_regexp.rb +11 -47
  144. data/lib/rubocop/cop/lint/useless_access_modifier.rb +25 -15
  145. data/lib/rubocop/cop/lint/useless_assignment.rb +4 -4
  146. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +6 -15
  147. data/lib/rubocop/cop/lint/useless_setter_call.rb +4 -6
  148. data/lib/rubocop/cop/lint/void.rb +3 -7
  149. data/lib/rubocop/cop/metrics/abc_size.rb +1 -1
  150. data/lib/rubocop/cop/metrics/block_length.rb +2 -2
  151. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  152. data/lib/rubocop/cop/metrics/class_length.rb +2 -2
  153. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
  154. data/lib/rubocop/cop/metrics/method_length.rb +2 -2
  155. data/lib/rubocop/cop/metrics/module_length.rb +2 -2
  156. data/lib/rubocop/cop/metrics/parameter_lists.rb +2 -6
  157. data/lib/rubocop/cop/metrics/perceived_complexity.rb +7 -8
  158. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +48 -5
  159. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +52 -24
  160. data/lib/rubocop/cop/metrics/utils/repeated_csend_discount.rb +37 -0
  161. data/lib/rubocop/cop/migration/department_name.rb +14 -16
  162. data/lib/rubocop/cop/mixin/alignment.rb +2 -1
  163. data/lib/rubocop/cop/mixin/array_min_size.rb +1 -1
  164. data/lib/rubocop/cop/mixin/check_line_breakable.rb +2 -2
  165. data/lib/rubocop/cop/mixin/code_length.rb +22 -5
  166. data/lib/rubocop/cop/mixin/hash_transform_method.rb +5 -11
  167. data/lib/rubocop/cop/mixin/line_length_help.rb +1 -3
  168. data/lib/rubocop/cop/mixin/method_complexity.rb +10 -2
  169. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +1 -2
  170. data/lib/rubocop/cop/mixin/percent_array.rb +2 -6
  171. data/lib/rubocop/cop/mixin/range_help.rb +18 -4
  172. data/lib/rubocop/cop/mixin/statement_modifier.rb +39 -10
  173. data/lib/rubocop/cop/mixin/surrounding_space.rb +0 -25
  174. data/lib/rubocop/cop/mixin/trailing_comma.rb +2 -4
  175. data/lib/rubocop/cop/mixin/uncommunicative_name.rb +6 -13
  176. data/lib/rubocop/cop/mixin/unused_argument.rb +4 -6
  177. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  178. data/lib/rubocop/cop/naming/ascii_identifiers.rb +3 -3
  179. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
  180. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  181. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +2 -2
  182. data/lib/rubocop/cop/naming/constant_name.rb +2 -2
  183. data/lib/rubocop/cop/naming/file_name.rb +3 -3
  184. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +2 -2
  185. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +2 -2
  186. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +2 -2
  187. data/lib/rubocop/cop/naming/method_parameter_name.rb +1 -1
  188. data/lib/rubocop/cop/naming/predicate_name.rb +3 -5
  189. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -11
  190. data/lib/rubocop/cop/registry.rb +3 -3
  191. data/lib/rubocop/cop/security/eval.rb +2 -2
  192. data/lib/rubocop/cop/security/json_load.rb +6 -8
  193. data/lib/rubocop/cop/security/marshal_load.rb +2 -4
  194. data/lib/rubocop/cop/security/open.rb +2 -2
  195. data/lib/rubocop/cop/security/yaml_load.rb +6 -6
  196. data/lib/rubocop/cop/style/access_modifier_declarations.rb +16 -9
  197. data/lib/rubocop/cop/style/accessor_grouping.rb +29 -20
  198. data/lib/rubocop/cop/style/alias.rb +41 -36
  199. data/lib/rubocop/cop/style/and_or.rb +9 -11
  200. data/lib/rubocop/cop/style/array_coercion.rb +63 -0
  201. data/lib/rubocop/cop/style/array_join.rb +6 -8
  202. data/lib/rubocop/cop/style/ascii_comments.rb +4 -4
  203. data/lib/rubocop/cop/style/attr.rb +11 -9
  204. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +5 -7
  205. data/lib/rubocop/cop/style/bare_percent_literals.rb +10 -12
  206. data/lib/rubocop/cop/style/begin_block.rb +2 -2
  207. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +14 -18
  208. data/lib/rubocop/cop/style/block_comments.rb +14 -18
  209. data/lib/rubocop/cop/style/block_delimiters.rb +23 -23
  210. data/lib/rubocop/cop/style/case_equality.rb +22 -3
  211. data/lib/rubocop/cop/style/case_like_if.rb +220 -0
  212. data/lib/rubocop/cop/style/class_and_module_children.rb +14 -11
  213. data/lib/rubocop/cop/style/class_check.rb +7 -9
  214. data/lib/rubocop/cop/style/class_methods.rb +7 -11
  215. data/lib/rubocop/cop/style/class_vars.rb +6 -10
  216. data/lib/rubocop/cop/style/collection_methods.rb +11 -17
  217. data/lib/rubocop/cop/style/colon_method_call.rb +8 -9
  218. data/lib/rubocop/cop/style/colon_method_definition.rb +6 -6
  219. data/lib/rubocop/cop/style/command_literal.rb +23 -24
  220. data/lib/rubocop/cop/style/comment_annotation.rb +15 -15
  221. data/lib/rubocop/cop/style/commented_keyword.rb +6 -3
  222. data/lib/rubocop/cop/style/conditional_assignment.rb +13 -4
  223. data/lib/rubocop/cop/style/constant_visibility.rb +3 -2
  224. data/lib/rubocop/cop/style/copyright.rb +12 -12
  225. data/lib/rubocop/cop/style/date_time.rb +1 -1
  226. data/lib/rubocop/cop/style/def_with_parentheses.rb +8 -10
  227. data/lib/rubocop/cop/style/dir.rb +7 -10
  228. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +7 -9
  229. data/lib/rubocop/cop/style/documentation.rb +6 -8
  230. data/lib/rubocop/cop/style/documentation_method.rb +1 -1
  231. data/lib/rubocop/cop/style/double_cop_disable_directive.rb +12 -15
  232. data/lib/rubocop/cop/style/double_negation.rb +2 -2
  233. data/lib/rubocop/cop/style/each_for_simple_loop.rb +5 -8
  234. data/lib/rubocop/cop/style/each_with_object.rb +16 -19
  235. data/lib/rubocop/cop/style/empty_case_condition.rb +19 -20
  236. data/lib/rubocop/cop/style/empty_else.rb +17 -19
  237. data/lib/rubocop/cop/style/empty_literal.rb +15 -16
  238. data/lib/rubocop/cop/style/empty_method.rb +10 -13
  239. data/lib/rubocop/cop/style/encoding.rb +5 -9
  240. data/lib/rubocop/cop/style/end_block.rb +4 -6
  241. data/lib/rubocop/cop/style/eval_with_location.rb +9 -7
  242. data/lib/rubocop/cop/style/even_odd.rb +7 -11
  243. data/lib/rubocop/cop/style/expand_path_arguments.rb +21 -20
  244. data/lib/rubocop/cop/style/explicit_block_argument.rb +102 -0
  245. data/lib/rubocop/cop/style/exponential_notation.rb +7 -9
  246. data/lib/rubocop/cop/style/float_division.rb +8 -11
  247. data/lib/rubocop/cop/style/for.rb +11 -15
  248. data/lib/rubocop/cop/style/format_string.rb +21 -19
  249. data/lib/rubocop/cop/style/format_string_token.rb +10 -12
  250. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +19 -41
  251. data/lib/rubocop/cop/style/global_std_stream.rb +65 -0
  252. data/lib/rubocop/cop/style/global_vars.rb +2 -2
  253. data/lib/rubocop/cop/style/guard_clause.rb +5 -6
  254. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +69 -0
  255. data/lib/rubocop/cop/style/hash_each_methods.rb +5 -8
  256. data/lib/rubocop/cop/style/hash_like_case.rb +76 -0
  257. data/lib/rubocop/cop/style/hash_syntax.rb +4 -3
  258. data/lib/rubocop/cop/style/hash_transform_keys.rb +3 -2
  259. data/lib/rubocop/cop/style/hash_transform_values.rb +2 -1
  260. data/lib/rubocop/cop/style/identical_conditional_branches.rb +2 -2
  261. data/lib/rubocop/cop/style/if_inside_else.rb +3 -3
  262. data/lib/rubocop/cop/style/if_unless_modifier.rb +18 -40
  263. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -7
  264. data/lib/rubocop/cop/style/if_with_semicolon.rb +3 -6
  265. data/lib/rubocop/cop/style/implicit_runtime_error.rb +1 -1
  266. data/lib/rubocop/cop/style/infinite_loop.rb +24 -24
  267. data/lib/rubocop/cop/style/inline_comment.rb +3 -3
  268. data/lib/rubocop/cop/style/inverse_methods.rb +22 -32
  269. data/lib/rubocop/cop/style/lambda.rb +7 -12
  270. data/lib/rubocop/cop/style/lambda_call.rb +14 -13
  271. data/lib/rubocop/cop/style/line_end_concatenation.rb +19 -16
  272. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +2 -1
  273. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +16 -11
  274. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +4 -8
  275. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +8 -7
  276. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +2 -2
  277. data/lib/rubocop/cop/style/method_def_parentheses.rb +11 -16
  278. data/lib/rubocop/cop/style/min_max.rb +8 -12
  279. data/lib/rubocop/cop/style/missing_else.rb +11 -21
  280. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +10 -3
  281. data/lib/rubocop/cop/style/mixin_grouping.rb +24 -27
  282. data/lib/rubocop/cop/style/mixin_usage.rb +1 -1
  283. data/lib/rubocop/cop/style/module_function.rb +10 -13
  284. data/lib/rubocop/cop/style/multiline_if_modifier.rb +3 -10
  285. data/lib/rubocop/cop/style/multiline_if_then.rb +4 -10
  286. data/lib/rubocop/cop/style/multiline_memoization.rb +14 -12
  287. data/lib/rubocop/cop/style/multiline_method_signature.rb +2 -2
  288. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +4 -6
  289. data/lib/rubocop/cop/style/multiline_when_then.rb +7 -9
  290. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  291. data/lib/rubocop/cop/style/mutable_constant.rb +23 -20
  292. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +3 -1
  293. data/lib/rubocop/cop/style/numeric_predicate.rb +7 -4
  294. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +42 -0
  295. data/lib/rubocop/cop/style/parallel_assignment.rb +5 -5
  296. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +1 -1
  297. data/lib/rubocop/cop/style/random_with_offset.rb +1 -0
  298. data/lib/rubocop/cop/style/redundant_condition.rb +15 -3
  299. data/lib/rubocop/cop/style/redundant_exception.rb +4 -0
  300. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +50 -0
  301. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +9 -9
  302. data/lib/rubocop/cop/style/redundant_sort.rb +26 -12
  303. data/lib/rubocop/cop/style/safe_navigation.rb +4 -4
  304. data/lib/rubocop/cop/style/signal_exception.rb +2 -0
  305. data/lib/rubocop/cop/style/single_argument_dig.rb +54 -0
  306. data/lib/rubocop/cop/style/single_line_methods.rb +1 -1
  307. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +3 -2
  308. data/lib/rubocop/cop/style/string_concatenation.rb +92 -0
  309. data/lib/rubocop/cop/style/struct_inheritance.rb +1 -1
  310. data/lib/rubocop/cop/style/symbol_array.rb +1 -1
  311. data/lib/rubocop/cop/style/symbol_proc.rb +1 -1
  312. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +9 -32
  313. data/lib/rubocop/cop/style/zero_length_predicate.rb +10 -6
  314. data/lib/rubocop/cop/team.rb +1 -1
  315. data/lib/rubocop/cop/tokens_util.rb +84 -0
  316. data/lib/rubocop/cop/util.rb +3 -13
  317. data/lib/rubocop/cop/variable_force.rb +0 -2
  318. data/lib/rubocop/cop/variable_force/branch.rb +1 -0
  319. data/lib/rubocop/cop/variable_force/variable.rb +7 -5
  320. data/lib/rubocop/cops_documentation_generator.rb +282 -0
  321. data/lib/rubocop/error.rb +1 -0
  322. data/lib/rubocop/file_finder.rb +12 -12
  323. data/lib/rubocop/formatter/disabled_config_formatter.rb +1 -1
  324. data/lib/rubocop/formatter/formatter_set.rb +1 -0
  325. data/lib/rubocop/formatter/junit_formatter.rb +1 -1
  326. data/lib/rubocop/options.rb +3 -3
  327. data/lib/rubocop/path_util.rb +17 -17
  328. data/lib/rubocop/rake_task.rb +1 -0
  329. data/lib/rubocop/result_cache.rb +12 -8
  330. data/lib/rubocop/rspec/expect_offense.rb +31 -5
  331. data/lib/rubocop/rspec/shared_contexts.rb +13 -14
  332. data/lib/rubocop/runner.rb +6 -7
  333. data/lib/rubocop/target_finder.rb +13 -10
  334. data/lib/rubocop/version.rb +2 -2
  335. metadata +28 -8
  336. data/lib/rubocop/cop/lint/useless_comparison.rb +0 -28
  337. data/lib/rubocop/cop/mixin/parser_diagnostic.rb +0 -37
  338. data/lib/rubocop/cop/mixin/too_many_lines.rb +0 -25
  339. data/lib/rubocop/cop/style/method_missing_super.rb +0 -34
@@ -21,9 +21,10 @@ module RuboCop
21
21
  # end
22
22
  #
23
23
  # The compact style is only forced for classes/modules with one child.
24
- class ClassAndModuleChildren < Cop
24
+ class ClassAndModuleChildren < Base
25
25
  include ConfigurableEnforcedStyle
26
26
  include RangeHelp
27
+ extend AutoCorrector
27
28
 
28
29
  NESTED_MSG = 'Use nested module/class definitions instead of ' \
29
30
  'compact style.'
@@ -40,14 +41,6 @@ module RuboCop
40
41
  check_style(node, node.body)
41
42
  end
42
43
 
43
- def autocorrect(node)
44
- lambda do |corrector|
45
- return if node.class_type? && node.parent_class && style != :nested
46
-
47
- nest_or_compact(corrector, node)
48
- end
49
- end
50
-
51
44
  private
52
45
 
53
46
  def nest_or_compact(corrector, node)
@@ -129,13 +122,23 @@ module RuboCop
129
122
  def check_nested_style(node)
130
123
  return unless compact_node_name?(node)
131
124
 
132
- add_offense(node, location: :name, message: NESTED_MSG)
125
+ add_offense(node.loc.name, message: NESTED_MSG) do |corrector|
126
+ autocorrect(corrector, node)
127
+ end
133
128
  end
134
129
 
135
130
  def check_compact_style(node, body)
136
131
  return unless one_child?(body) && !compact_node_name?(node)
137
132
 
138
- add_offense(node, location: :name, message: COMPACT_MSG)
133
+ add_offense(node.loc.name, message: COMPACT_MSG) do |corrector|
134
+ autocorrect(corrector, node)
135
+ end
136
+ end
137
+
138
+ def autocorrect(corrector, node)
139
+ return if node.class_type? && node.parent_class && style != :nested
140
+
141
+ nest_or_compact(corrector, node)
139
142
  end
140
143
 
141
144
  def one_child?(body)
@@ -23,8 +23,9 @@ module RuboCop
23
23
  # var.kind_of?(Time)
24
24
  # var.kind_of?(String)
25
25
  #
26
- class ClassCheck < Cop
26
+ class ClassCheck < Base
27
27
  include ConfigurableEnforcedStyle
28
+ extend AutoCorrector
28
29
 
29
30
  MSG = 'Prefer `Object#%<prefer>s` over `Object#%<current>s`.'
30
31
 
@@ -34,15 +35,12 @@ module RuboCop
34
35
  class_check?(node) do |method_name|
35
36
  return if style == method_name
36
37
 
37
- add_offense(node, location: :selector)
38
- end
39
- end
40
-
41
- def autocorrect(node)
42
- lambda do |corrector|
43
- replacement = node.method?(:is_a?) ? 'kind_of?' : 'is_a?'
38
+ message = message(node)
39
+ add_offense(node.loc.selector, message: message) do |corrector|
40
+ replacement = node.method?(:is_a?) ? 'kind_of?' : 'is_a?'
44
41
 
45
- corrector.replace(node.loc.selector, replacement)
42
+ corrector.replace(node.loc.selector, replacement)
43
+ end
46
44
  end
47
45
  end
48
46
 
@@ -20,7 +20,9 @@ module RuboCop
20
20
  # # ...
21
21
  # end
22
22
  # end
23
- class ClassMethods < Cop
23
+ class ClassMethods < Base
24
+ extend AutoCorrector
25
+
24
26
  MSG = 'Use `self.%<method>s` instead of `%<class>s.%<method>s`.'
25
27
 
26
28
  def on_class(node)
@@ -36,23 +38,17 @@ module RuboCop
36
38
  end
37
39
  alias on_module on_class
38
40
 
39
- def autocorrect(node)
40
- ->(corrector) { corrector.replace(node.loc.name, 'self') }
41
- end
42
-
43
41
  private
44
42
 
45
43
  def check_defs(name, node)
46
44
  # check if the class/module name matches the definee for the defs node
47
45
  return unless name == node.receiver
48
46
 
49
- add_offense(node.receiver, location: :name)
50
- end
51
-
52
- def message(node)
53
- _, class_name = *node
47
+ message = format(MSG, method: node.method_name, class: name.source)
54
48
 
55
- format(MSG, method: node.parent.method_name, class: class_name)
49
+ add_offense(node.receiver.loc.name, message: message) do |corrector|
50
+ corrector.replace(node.receiver, 'self')
51
+ end
56
52
  end
57
53
  end
58
54
  end
@@ -45,23 +45,19 @@ module RuboCop
45
45
  # end
46
46
  # end
47
47
  #
48
- class ClassVars < Cop
49
- MSG = 'Replace class var %<class_var>s with a class ' \
50
- 'instance var.'
48
+ class ClassVars < Base
49
+ MSG = 'Replace class var %<class_var>s with a class instance var.'
51
50
 
52
51
  def on_cvasgn(node)
53
- add_offense(node, location: :name)
52
+ add_offense(node.loc.name, message: format(MSG, class_var: node.children.first))
54
53
  end
55
54
 
56
55
  def on_send(node)
57
56
  return unless node.method?(:class_variable_set)
58
57
 
59
- add_offense(node.first_argument)
60
- end
61
-
62
- def message(node)
63
- class_var, = *node
64
- format(MSG, class_var: class_var)
58
+ add_offense(
59
+ node.first_argument, message: format(MSG, class_var: node.first_argument.source)
60
+ )
65
61
  end
66
62
  end
67
63
  end
@@ -37,8 +37,9 @@ module RuboCop
37
37
  # items.select
38
38
  # items.include?
39
39
  #
40
- class CollectionMethods < Cop
40
+ class CollectionMethods < Base
41
41
  include MethodPreference
42
+ extend AutoCorrector
42
43
 
43
44
  MSG = 'Prefer `%<prefer>s` over `%<current>s`.'
44
45
 
@@ -47,31 +48,24 @@ module RuboCop
47
48
  end
48
49
 
49
50
  def on_send(node)
50
- return unless node.arguments.one? &&
51
- node.first_argument.block_pass_type?
51
+ return unless node.arguments.one? && node.first_argument.block_pass_type?
52
52
 
53
53
  check_method_node(node)
54
54
  end
55
55
 
56
- def autocorrect(node)
57
- lambda do |corrector|
58
- corrector.replace(node.loc.selector,
59
- preferred_method(node.loc.selector.source))
60
- end
61
- end
62
-
63
56
  private
64
57
 
65
- def message(node)
66
- format(MSG,
67
- prefer: preferred_method(node.method_name),
68
- current: node.method_name)
69
- end
70
-
71
58
  def check_method_node(node)
72
59
  return unless preferred_methods[node.method_name]
73
60
 
74
- add_offense(node, location: :selector)
61
+ message = message(node)
62
+ add_offense(node.loc.selector, message: message) do |corrector|
63
+ corrector.replace(node.loc.selector, preferred_method(node.loc.selector.source))
64
+ end
65
+ end
66
+
67
+ def message(node)
68
+ format(MSG, prefer: preferred_method(node.method_name), current: node.method_name)
75
69
  end
76
70
  end
77
71
  end
@@ -17,7 +17,9 @@ module RuboCop
17
17
  # FileUtils.rmdir(dir)
18
18
  # Marshal.dump(obj)
19
19
  #
20
- class ColonMethodCall < Cop
20
+ class ColonMethodCall < Base
21
+ extend AutoCorrector
22
+
21
23
  MSG = 'Do not use `::` for method calls.'
22
24
 
23
25
  def_node_matcher :java_type_node?, <<~PATTERN
@@ -30,17 +32,14 @@ module RuboCop
30
32
  end
31
33
 
32
34
  def on_send(node)
33
- # ignore Java interop code like Java::int
34
- return if java_type_node?(node)
35
-
36
35
  return unless node.receiver && node.double_colon?
37
36
  return if node.camel_case_method?
37
+ # ignore Java interop code like Java::int
38
+ return if java_type_node?(node)
38
39
 
39
- add_offense(node, location: :dot)
40
- end
41
-
42
- def autocorrect(node)
43
- ->(corrector) { corrector.replace(node.loc.dot, '.') }
40
+ add_offense(node.loc.dot) do |corrector|
41
+ corrector.replace(node.loc.dot, '.')
42
+ end
44
43
  end
45
44
  end
46
45
  end
@@ -19,17 +19,17 @@ module RuboCop
19
19
  # end
20
20
  # end
21
21
  #
22
- class ColonMethodDefinition < Cop
22
+ class ColonMethodDefinition < Base
23
+ extend AutoCorrector
24
+
23
25
  MSG = 'Do not use `::` for defining class methods.'
24
26
 
25
27
  def on_defs(node)
26
28
  return unless node.loc.operator.source == '::'
27
29
 
28
- add_offense(node, location: :operator)
29
- end
30
-
31
- def autocorrect(node)
32
- ->(corrector) { corrector.replace(node.loc.operator, '.') }
30
+ add_offense(node.loc.operator) do |corrector|
31
+ corrector.replace(node.loc.operator, '.')
32
+ end
33
33
  end
34
34
  end
35
35
  end
@@ -75,8 +75,9 @@ module RuboCop
75
75
  # @example AllowInnerBackticks: true
76
76
  # # good
77
77
  # `echo \`ls\``
78
- class CommandLiteral < Cop
78
+ class CommandLiteral < Base
79
79
  include ConfigurableEnforcedStyle
80
+ extend AutoCorrector
80
81
 
81
82
  MSG_USE_BACKTICKS = 'Use backticks around command string.'
82
83
  MSG_USE_PERCENT_X = 'Use `%x` around command string.'
@@ -85,43 +86,41 @@ module RuboCop
85
86
  return if node.heredoc?
86
87
 
87
88
  if backtick_literal?(node)
88
- check_backtick_literal(node)
89
+ check_backtick_literal(node, MSG_USE_PERCENT_X)
89
90
  else
90
- check_percent_x_literal(node)
91
- end
92
- end
93
-
94
- def autocorrect(node)
95
- return if contains_backtick?(node)
96
-
97
- replacement = if backtick_literal?(node)
98
- ['%x', ''].zip(preferred_delimiter).map(&:join)
99
- else
100
- %w[` `]
101
- end
102
-
103
- lambda do |corrector|
104
- corrector.replace(node.loc.begin, replacement.first)
105
- corrector.replace(node.loc.end, replacement.last)
91
+ check_percent_x_literal(node, MSG_USE_BACKTICKS)
106
92
  end
107
93
  end
108
94
 
109
95
  private
110
96
 
111
- def check_backtick_literal(node)
97
+ def check_backtick_literal(node, message)
112
98
  return if allowed_backtick_literal?(node)
113
99
 
114
- add_offense(node)
100
+ add_offense(node, message: message) do |corrector|
101
+ autocorrect(corrector, node)
102
+ end
115
103
  end
116
104
 
117
- def check_percent_x_literal(node)
105
+ def check_percent_x_literal(node, message)
118
106
  return if allowed_percent_x_literal?(node)
119
107
 
120
- add_offense(node)
108
+ add_offense(node, message: message) do |corrector|
109
+ autocorrect(corrector, node)
110
+ end
121
111
  end
122
112
 
123
- def message(node)
124
- backtick_literal?(node) ? MSG_USE_PERCENT_X : MSG_USE_BACKTICKS
113
+ def autocorrect(corrector, node)
114
+ return if contains_backtick?(node)
115
+
116
+ replacement = if backtick_literal?(node)
117
+ ['%x', ''].zip(preferred_delimiter).map(&:join)
118
+ else
119
+ %w[` `]
120
+ end
121
+
122
+ corrector.replace(node.loc.begin, replacement.first)
123
+ corrector.replace(node.loc.end, replacement.last)
125
124
  end
126
125
 
127
126
  def allowed_backtick_literal?(node)
@@ -30,9 +30,10 @@ module RuboCop
30
30
  #
31
31
  # # good
32
32
  # # OPTIMIZE: does not work
33
- class CommentAnnotation < Cop
33
+ class CommentAnnotation < Base
34
34
  include AnnotationComment
35
35
  include RangeHelp
36
+ extend AutoCorrector
36
37
 
37
38
  MSG = 'Annotation keywords like `%<keyword>s` should be all ' \
38
39
  'upper case, followed by a colon, and a space, ' \
@@ -40,7 +41,7 @@ module RuboCop
40
41
  MISSING_NOTE = 'Annotation comment, with keyword `%<keyword>s`, ' \
41
42
  'is missing a note.'
42
43
 
43
- def investigate(processed_source)
44
+ def on_new_investigation
44
45
  processed_source.comments.each_with_index do |comment, index|
45
46
  next unless first_comment_line?(processed_source.comments, index) ||
46
47
  inline_comment?(comment)
@@ -49,26 +50,25 @@ module RuboCop
49
50
  next unless annotation?(comment) &&
50
51
  !correct_annotation?(first_word, colon, space, note)
51
52
 
52
- add_offense(
53
- comment,
54
- location: annotation_range(comment, margin,
55
- first_word, colon, space),
56
- message: format(note ? MSG : MISSING_NOTE, keyword: first_word)
57
- )
53
+ range = annotation_range(comment, margin, first_word, colon, space)
54
+
55
+ register_offense(range, note, first_word)
58
56
  end
59
57
  end
60
58
 
61
- def autocorrect(comment)
62
- margin, first_word, colon, space, note = split_comment(comment)
63
- return if note.nil?
59
+ private
64
60
 
65
- range = annotation_range(comment, margin, first_word, colon, space)
61
+ def register_offense(range, note, first_word)
62
+ add_offense(
63
+ range,
64
+ message: format(note ? MSG : MISSING_NOTE, keyword: first_word)
65
+ ) do |corrector|
66
+ next if note.nil?
66
67
 
67
- ->(corrector) { corrector.replace(range, "#{first_word.upcase}: ") }
68
+ corrector.replace(range, "#{first_word.upcase}: ")
69
+ end
68
70
  end
69
71
 
70
- private
71
-
72
72
  def first_comment_line?(comments, index)
73
73
  index.zero? ||
74
74
  comments[index - 1].loc.line < comments[index].loc.line - 1
@@ -38,7 +38,7 @@ module RuboCop
38
38
  '`%<keyword>s` keyword.'
39
39
 
40
40
  def investigate(processed_source)
41
- processed_source.each_comment do |comment|
41
+ processed_source.comments.each do |comment|
42
42
  add_offense(comment) if offensive?(comment)
43
43
  end
44
44
  end
@@ -46,17 +46,20 @@ module RuboCop
46
46
  private
47
47
 
48
48
  KEYWORDS = %w[begin class def end module].freeze
49
+ KEYWORD_REGEXES = KEYWORDS.map { |w| /^\s*#{w}\s/ }.freeze
50
+
49
51
  ALLOWED_COMMENTS = %w[
50
52
  :nodoc:
51
53
  :yields:
52
54
  rubocop:disable
53
55
  rubocop:todo
54
56
  ].freeze
57
+ ALLOWED_COMMENT_REGEXES = ALLOWED_COMMENTS.map { |c| /#\s*#{c}/ }.freeze
55
58
 
56
59
  def offensive?(comment)
57
60
  line = line(comment)
58
- KEYWORDS.any? { |word| /^\s*#{word}\s/.match?(line) } &&
59
- ALLOWED_COMMENTS.none? { |c| /#\s*#{c}/.match?(line) }
61
+ KEYWORD_REGEXES.any? { |r| r.match?(line) } &&
62
+ ALLOWED_COMMENT_REGEXES.none? { |r| r.match?(line) }
60
63
  end
61
64
 
62
65
  def message(comment)
@@ -30,7 +30,7 @@ module RuboCop
30
30
  end
31
31
 
32
32
  def tail(branch)
33
- branch.begin_type? ? [*branch].last : branch
33
+ branch.begin_type? ? Array(branch).last : branch
34
34
  end
35
35
 
36
36
  # rubocop:disable Metrics/AbcSize
@@ -43,7 +43,7 @@ module RuboCop
43
43
  when :and_asgn, :or_asgn
44
44
  "#{node.children[0].source} #{node.loc.operator.source} "
45
45
  when :casgn
46
- "#{node.children[1]} = "
46
+ lhs_for_casgn(node)
47
47
  when *ConditionalAssignment::VARIABLE_ASSIGNMENT_TYPES
48
48
  "#{node.children[0]} = "
49
49
  else
@@ -67,7 +67,7 @@ module RuboCop
67
67
 
68
68
  private
69
69
 
70
- def expand_elsif(node, elsif_branches = []) # rubocop:todo Metrics/CyclomaticComplexity
70
+ def expand_elsif(node, elsif_branches = [])
71
71
  return [] if node.nil? || !node.if_type? || !node.elsif?
72
72
 
73
73
  elsif_branches << node.if_branch
@@ -93,6 +93,15 @@ module RuboCop
93
93
  end
94
94
  end
95
95
 
96
+ def lhs_for_casgn(node)
97
+ namespace = node.children[0]
98
+ if namespace.nil? || namespace.cbase_type?
99
+ "#{namespace&.source}#{node.children[1]} = "
100
+ else
101
+ "#{namespace.source}::#{node.children[1]} = "
102
+ end
103
+ end
104
+
96
105
  def setter_method?(method_name)
97
106
  method_name.to_s.end_with?(EQUAL) &&
98
107
  !%i[!= == === >= <=].include?(method_name)
@@ -224,7 +233,7 @@ module RuboCop
224
233
  def_node_matcher :assignment_type?, <<~PATTERN
225
234
  {
226
235
  #{ASSIGNMENT_TYPES.join(' ')}
227
- (send _recv {:[]= :<< :=~ :!~ :<=> #end_with_eq?} ...)
236
+ (send _recv {:[]= :<< :=~ :!~ :<=> #end_with_eq? :< :>} ...)
228
237
  }
229
238
  PATTERN
230
239