rubocop 0.88.0 → 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 (320) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/bin/rubocop-profile +1 -0
  4. data/config/default.yml +96 -16
  5. data/lib/rubocop.rb +16 -4
  6. data/lib/rubocop/cli/command/auto_genenerate_config.rb +1 -1
  7. data/lib/rubocop/cli/command/base.rb +1 -0
  8. data/lib/rubocop/cli/command/execute_runner.rb +1 -1
  9. data/lib/rubocop/cli/command/show_cops.rb +2 -2
  10. data/lib/rubocop/cli/command/version.rb +2 -2
  11. data/lib/rubocop/comment_config.rb +5 -7
  12. data/lib/rubocop/config.rb +20 -3
  13. data/lib/rubocop/config_loader.rb +2 -2
  14. data/lib/rubocop/config_loader_resolver.rb +3 -3
  15. data/lib/rubocop/config_obsoletion.rb +6 -1
  16. data/lib/rubocop/config_validator.rb +2 -4
  17. data/lib/rubocop/cop/base.rb +2 -2
  18. data/lib/rubocop/cop/commissioner.rb +0 -1
  19. data/lib/rubocop/cop/correctors/line_break_corrector.rb +4 -4
  20. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +2 -2
  21. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  22. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +15 -18
  23. data/lib/rubocop/cop/force.rb +1 -0
  24. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +32 -11
  25. data/lib/rubocop/cop/generator/configuration_injector.rb +2 -2
  26. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +4 -12
  27. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +1 -1
  28. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +8 -8
  29. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +10 -7
  30. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +7 -8
  31. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -2
  32. data/lib/rubocop/cop/layout/block_alignment.rb +1 -1
  33. data/lib/rubocop/cop/layout/class_structure.rb +3 -7
  34. data/lib/rubocop/cop/layout/comment_indentation.rb +1 -1
  35. data/lib/rubocop/cop/layout/empty_lines.rb +0 -2
  36. data/lib/rubocop/cop/layout/extra_spacing.rb +22 -36
  37. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -1
  38. data/lib/rubocop/cop/layout/heredoc_indentation.rb +2 -2
  39. data/lib/rubocop/cop/layout/indentation_style.rb +0 -2
  40. data/lib/rubocop/cop/layout/leading_comment_space.rb +1 -1
  41. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +1 -1
  42. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +0 -2
  43. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +9 -1
  44. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +7 -4
  45. data/lib/rubocop/cop/lint/ambiguous_operator.rb +15 -10
  46. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +11 -13
  47. data/lib/rubocop/cop/lint/assignment_in_condition.rb +2 -2
  48. data/lib/rubocop/cop/lint/big_decimal_new.rb +10 -10
  49. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +50 -0
  50. data/lib/rubocop/cop/lint/boolean_symbol.rb +16 -11
  51. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  52. data/lib/rubocop/cop/lint/constant_resolution.rb +1 -1
  53. data/lib/rubocop/cop/lint/debugger.rb +7 -1
  54. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +9 -10
  55. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +17 -13
  56. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  57. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -1
  58. data/lib/rubocop/cop/lint/duplicate_methods.rb +7 -4
  59. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +60 -0
  60. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  61. data/lib/rubocop/cop/lint/else_layout.rb +1 -1
  62. data/lib/rubocop/cop/lint/empty_conditional_body.rb +67 -0
  63. data/lib/rubocop/cop/lint/empty_ensure.rb +5 -5
  64. data/lib/rubocop/cop/lint/empty_expression.rb +2 -2
  65. data/lib/rubocop/cop/lint/empty_interpolation.rb +5 -6
  66. data/lib/rubocop/cop/lint/empty_when.rb +2 -2
  67. data/lib/rubocop/cop/lint/ensure_return.rb +27 -29
  68. data/lib/rubocop/cop/lint/erb_new_arguments.rb +11 -10
  69. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  70. data/lib/rubocop/cop/lint/float_comparison.rb +93 -0
  71. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -1
  72. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +5 -4
  73. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +13 -14
  74. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +2 -2
  75. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +8 -8
  76. data/lib/rubocop/cop/lint/inherit_exception.rb +12 -7
  77. data/lib/rubocop/cop/lint/interpolation_check.rb +18 -15
  78. data/lib/rubocop/cop/lint/literal_as_condition.rb +4 -2
  79. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +7 -7
  80. data/lib/rubocop/cop/lint/loop.rb +23 -2
  81. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +6 -5
  82. data/lib/rubocop/cop/lint/missing_super.rb +99 -0
  83. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -1
  84. data/lib/rubocop/cop/lint/multiple_comparison.rb +6 -9
  85. data/lib/rubocop/cop/lint/nested_method_definition.rb +1 -1
  86. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  87. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
  88. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +27 -23
  89. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +2 -2
  90. data/lib/rubocop/cop/lint/number_conversion.rb +6 -9
  91. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +11 -13
  92. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +90 -0
  93. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +4 -10
  94. data/lib/rubocop/cop/lint/percent_string_array.rb +13 -12
  95. data/lib/rubocop/cop/lint/percent_symbol_array.rb +13 -12
  96. data/lib/rubocop/cop/lint/raise_exception.rb +12 -10
  97. data/lib/rubocop/cop/lint/rand_one.rb +2 -2
  98. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +16 -19
  99. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +7 -11
  100. data/lib/rubocop/cop/lint/redundant_require_statement.rb +4 -7
  101. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +13 -9
  102. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +6 -13
  103. data/lib/rubocop/cop/lint/redundant_with_index.rb +11 -14
  104. data/lib/rubocop/cop/lint/redundant_with_object.rb +11 -14
  105. data/lib/rubocop/cop/lint/regexp_as_condition.rb +4 -6
  106. data/lib/rubocop/cop/lint/require_parentheses.rb +2 -2
  107. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  108. data/lib/rubocop/cop/lint/rescue_type.rb +8 -8
  109. data/lib/rubocop/cop/lint/return_in_void_context.rb +2 -4
  110. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +3 -6
  111. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +14 -10
  112. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +7 -7
  113. data/lib/rubocop/cop/lint/script_permission.rb +10 -7
  114. data/lib/rubocop/cop/lint/self_assignment.rb +78 -0
  115. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +5 -11
  116. data/lib/rubocop/cop/lint/shadowed_argument.rb +3 -3
  117. data/lib/rubocop/cop/lint/shadowed_exception.rb +2 -2
  118. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +3 -3
  119. data/lib/rubocop/cop/lint/struct_new_override.rb +1 -1
  120. data/lib/rubocop/cop/lint/suppressed_exception.rb +4 -7
  121. data/lib/rubocop/cop/lint/to_json.rb +4 -6
  122. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +34 -0
  123. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +4 -4
  124. data/lib/rubocop/cop/lint/unified_integer.rb +4 -6
  125. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -1
  126. data/lib/rubocop/cop/lint/unreachable_loop.rb +174 -0
  127. data/lib/rubocop/cop/lint/unused_block_argument.rb +8 -3
  128. data/lib/rubocop/cop/lint/unused_method_argument.rb +8 -3
  129. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  130. data/lib/rubocop/cop/lint/uri_regexp.rb +11 -47
  131. data/lib/rubocop/cop/lint/useless_access_modifier.rb +25 -15
  132. data/lib/rubocop/cop/lint/useless_assignment.rb +4 -4
  133. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +6 -15
  134. data/lib/rubocop/cop/lint/useless_setter_call.rb +4 -6
  135. data/lib/rubocop/cop/lint/void.rb +3 -7
  136. data/lib/rubocop/cop/metrics/abc_size.rb +1 -1
  137. data/lib/rubocop/cop/metrics/block_length.rb +2 -2
  138. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  139. data/lib/rubocop/cop/metrics/class_length.rb +2 -2
  140. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
  141. data/lib/rubocop/cop/metrics/method_length.rb +2 -2
  142. data/lib/rubocop/cop/metrics/module_length.rb +2 -2
  143. data/lib/rubocop/cop/metrics/parameter_lists.rb +2 -6
  144. data/lib/rubocop/cop/metrics/perceived_complexity.rb +7 -8
  145. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +48 -5
  146. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +52 -24
  147. data/lib/rubocop/cop/metrics/utils/repeated_csend_discount.rb +37 -0
  148. data/lib/rubocop/cop/migration/department_name.rb +14 -16
  149. data/lib/rubocop/cop/mixin/alignment.rb +2 -1
  150. data/lib/rubocop/cop/mixin/array_min_size.rb +1 -1
  151. data/lib/rubocop/cop/mixin/check_line_breakable.rb +2 -2
  152. data/lib/rubocop/cop/mixin/code_length.rb +22 -5
  153. data/lib/rubocop/cop/mixin/hash_transform_method.rb +5 -11
  154. data/lib/rubocop/cop/mixin/line_length_help.rb +1 -3
  155. data/lib/rubocop/cop/mixin/method_complexity.rb +10 -2
  156. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +1 -2
  157. data/lib/rubocop/cop/mixin/percent_array.rb +2 -6
  158. data/lib/rubocop/cop/mixin/range_help.rb +18 -4
  159. data/lib/rubocop/cop/mixin/statement_modifier.rb +37 -8
  160. data/lib/rubocop/cop/mixin/surrounding_space.rb +0 -25
  161. data/lib/rubocop/cop/mixin/trailing_comma.rb +2 -4
  162. data/lib/rubocop/cop/mixin/uncommunicative_name.rb +6 -13
  163. data/lib/rubocop/cop/mixin/unused_argument.rb +4 -6
  164. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  165. data/lib/rubocop/cop/naming/ascii_identifiers.rb +3 -3
  166. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
  167. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  168. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +2 -2
  169. data/lib/rubocop/cop/naming/constant_name.rb +2 -2
  170. data/lib/rubocop/cop/naming/file_name.rb +3 -3
  171. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +2 -2
  172. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +2 -2
  173. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +2 -2
  174. data/lib/rubocop/cop/naming/method_parameter_name.rb +1 -1
  175. data/lib/rubocop/cop/naming/predicate_name.rb +3 -5
  176. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -11
  177. data/lib/rubocop/cop/registry.rb +3 -3
  178. data/lib/rubocop/cop/security/eval.rb +2 -2
  179. data/lib/rubocop/cop/security/json_load.rb +6 -8
  180. data/lib/rubocop/cop/security/marshal_load.rb +2 -4
  181. data/lib/rubocop/cop/security/open.rb +2 -2
  182. data/lib/rubocop/cop/security/yaml_load.rb +6 -6
  183. data/lib/rubocop/cop/style/access_modifier_declarations.rb +16 -9
  184. data/lib/rubocop/cop/style/accessor_grouping.rb +23 -21
  185. data/lib/rubocop/cop/style/alias.rb +41 -36
  186. data/lib/rubocop/cop/style/and_or.rb +9 -11
  187. data/lib/rubocop/cop/style/array_join.rb +6 -8
  188. data/lib/rubocop/cop/style/ascii_comments.rb +4 -4
  189. data/lib/rubocop/cop/style/attr.rb +11 -9
  190. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +2 -5
  191. data/lib/rubocop/cop/style/bare_percent_literals.rb +10 -12
  192. data/lib/rubocop/cop/style/begin_block.rb +2 -2
  193. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +9 -14
  194. data/lib/rubocop/cop/style/block_comments.rb +14 -18
  195. data/lib/rubocop/cop/style/block_delimiters.rb +23 -23
  196. data/lib/rubocop/cop/style/case_equality.rb +22 -3
  197. data/lib/rubocop/cop/style/case_like_if.rb +19 -16
  198. data/lib/rubocop/cop/style/class_and_module_children.rb +14 -11
  199. data/lib/rubocop/cop/style/class_check.rb +7 -9
  200. data/lib/rubocop/cop/style/class_methods.rb +7 -11
  201. data/lib/rubocop/cop/style/class_vars.rb +6 -10
  202. data/lib/rubocop/cop/style/collection_methods.rb +11 -17
  203. data/lib/rubocop/cop/style/colon_method_call.rb +8 -9
  204. data/lib/rubocop/cop/style/colon_method_definition.rb +6 -6
  205. data/lib/rubocop/cop/style/command_literal.rb +23 -24
  206. data/lib/rubocop/cop/style/comment_annotation.rb +15 -15
  207. data/lib/rubocop/cop/style/commented_keyword.rb +1 -1
  208. data/lib/rubocop/cop/style/conditional_assignment.rb +12 -3
  209. data/lib/rubocop/cop/style/constant_visibility.rb +3 -2
  210. data/lib/rubocop/cop/style/copyright.rb +12 -12
  211. data/lib/rubocop/cop/style/date_time.rb +1 -1
  212. data/lib/rubocop/cop/style/def_with_parentheses.rb +8 -10
  213. data/lib/rubocop/cop/style/dir.rb +7 -10
  214. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +7 -9
  215. data/lib/rubocop/cop/style/documentation.rb +6 -8
  216. data/lib/rubocop/cop/style/documentation_method.rb +1 -1
  217. data/lib/rubocop/cop/style/double_cop_disable_directive.rb +12 -15
  218. data/lib/rubocop/cop/style/double_negation.rb +2 -2
  219. data/lib/rubocop/cop/style/each_for_simple_loop.rb +5 -8
  220. data/lib/rubocop/cop/style/each_with_object.rb +16 -19
  221. data/lib/rubocop/cop/style/empty_case_condition.rb +19 -20
  222. data/lib/rubocop/cop/style/empty_else.rb +17 -19
  223. data/lib/rubocop/cop/style/empty_literal.rb +15 -16
  224. data/lib/rubocop/cop/style/empty_method.rb +10 -13
  225. data/lib/rubocop/cop/style/encoding.rb +5 -9
  226. data/lib/rubocop/cop/style/end_block.rb +4 -6
  227. data/lib/rubocop/cop/style/eval_with_location.rb +9 -7
  228. data/lib/rubocop/cop/style/even_odd.rb +7 -11
  229. data/lib/rubocop/cop/style/expand_path_arguments.rb +21 -20
  230. data/lib/rubocop/cop/style/explicit_block_argument.rb +102 -0
  231. data/lib/rubocop/cop/style/exponential_notation.rb +1 -1
  232. data/lib/rubocop/cop/style/float_division.rb +1 -1
  233. data/lib/rubocop/cop/style/for.rb +11 -15
  234. data/lib/rubocop/cop/style/format_string.rb +21 -19
  235. data/lib/rubocop/cop/style/format_string_token.rb +5 -7
  236. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +19 -41
  237. data/lib/rubocop/cop/style/global_std_stream.rb +65 -0
  238. data/lib/rubocop/cop/style/global_vars.rb +2 -2
  239. data/lib/rubocop/cop/style/guard_clause.rb +5 -6
  240. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +8 -1
  241. data/lib/rubocop/cop/style/hash_each_methods.rb +5 -8
  242. data/lib/rubocop/cop/style/hash_syntax.rb +4 -3
  243. data/lib/rubocop/cop/style/hash_transform_keys.rb +3 -2
  244. data/lib/rubocop/cop/style/hash_transform_values.rb +2 -1
  245. data/lib/rubocop/cop/style/identical_conditional_branches.rb +2 -2
  246. data/lib/rubocop/cop/style/if_inside_else.rb +3 -3
  247. data/lib/rubocop/cop/style/if_unless_modifier.rb +10 -32
  248. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -7
  249. data/lib/rubocop/cop/style/if_with_semicolon.rb +3 -6
  250. data/lib/rubocop/cop/style/implicit_runtime_error.rb +1 -1
  251. data/lib/rubocop/cop/style/infinite_loop.rb +24 -24
  252. data/lib/rubocop/cop/style/inline_comment.rb +3 -3
  253. data/lib/rubocop/cop/style/inverse_methods.rb +22 -32
  254. data/lib/rubocop/cop/style/lambda.rb +7 -12
  255. data/lib/rubocop/cop/style/lambda_call.rb +14 -13
  256. data/lib/rubocop/cop/style/line_end_concatenation.rb +19 -16
  257. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +2 -1
  258. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +16 -11
  259. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +4 -8
  260. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +8 -7
  261. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +2 -2
  262. data/lib/rubocop/cop/style/method_def_parentheses.rb +11 -16
  263. data/lib/rubocop/cop/style/min_max.rb +8 -12
  264. data/lib/rubocop/cop/style/missing_else.rb +13 -13
  265. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +10 -3
  266. data/lib/rubocop/cop/style/mixin_grouping.rb +24 -27
  267. data/lib/rubocop/cop/style/mixin_usage.rb +1 -1
  268. data/lib/rubocop/cop/style/module_function.rb +10 -13
  269. data/lib/rubocop/cop/style/multiline_if_modifier.rb +3 -10
  270. data/lib/rubocop/cop/style/multiline_if_then.rb +4 -10
  271. data/lib/rubocop/cop/style/multiline_memoization.rb +14 -12
  272. data/lib/rubocop/cop/style/multiline_method_signature.rb +2 -2
  273. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +4 -6
  274. data/lib/rubocop/cop/style/multiline_when_then.rb +7 -9
  275. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  276. data/lib/rubocop/cop/style/mutable_constant.rb +23 -20
  277. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +3 -1
  278. data/lib/rubocop/cop/style/numeric_predicate.rb +4 -0
  279. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +42 -0
  280. data/lib/rubocop/cop/style/parallel_assignment.rb +2 -2
  281. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -2
  282. data/lib/rubocop/cop/style/random_with_offset.rb +1 -0
  283. data/lib/rubocop/cop/style/redundant_condition.rb +15 -3
  284. data/lib/rubocop/cop/style/redundant_exception.rb +4 -0
  285. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +9 -9
  286. data/lib/rubocop/cop/style/redundant_sort.rb +23 -10
  287. data/lib/rubocop/cop/style/safe_navigation.rb +4 -4
  288. data/lib/rubocop/cop/style/signal_exception.rb +2 -0
  289. data/lib/rubocop/cop/style/single_argument_dig.rb +54 -0
  290. data/lib/rubocop/cop/style/single_line_methods.rb +1 -1
  291. data/lib/rubocop/cop/style/string_concatenation.rb +92 -0
  292. data/lib/rubocop/cop/style/struct_inheritance.rb +1 -1
  293. data/lib/rubocop/cop/style/symbol_array.rb +1 -1
  294. data/lib/rubocop/cop/style/symbol_proc.rb +1 -1
  295. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +1 -1
  296. data/lib/rubocop/cop/style/zero_length_predicate.rb +10 -6
  297. data/lib/rubocop/cop/team.rb +1 -1
  298. data/lib/rubocop/cop/tokens_util.rb +84 -0
  299. data/lib/rubocop/cop/util.rb +3 -13
  300. data/lib/rubocop/cop/variable_force.rb +0 -2
  301. data/lib/rubocop/cop/variable_force/branch.rb +1 -0
  302. data/lib/rubocop/cop/variable_force/variable.rb +2 -2
  303. data/lib/rubocop/cops_documentation_generator.rb +282 -0
  304. data/lib/rubocop/error.rb +1 -0
  305. data/lib/rubocop/formatter/disabled_config_formatter.rb +1 -1
  306. data/lib/rubocop/formatter/formatter_set.rb +1 -0
  307. data/lib/rubocop/formatter/junit_formatter.rb +1 -1
  308. data/lib/rubocop/options.rb +3 -3
  309. data/lib/rubocop/path_util.rb +19 -4
  310. data/lib/rubocop/rake_task.rb +1 -0
  311. data/lib/rubocop/rspec/expect_offense.rb +1 -1
  312. data/lib/rubocop/rspec/shared_contexts.rb +1 -5
  313. data/lib/rubocop/runner.rb +1 -1
  314. data/lib/rubocop/target_finder.rb +12 -9
  315. data/lib/rubocop/version.rb +2 -2
  316. metadata +21 -8
  317. data/lib/rubocop/cop/lint/useless_comparison.rb +0 -28
  318. data/lib/rubocop/cop/mixin/parser_diagnostic.rb +0 -37
  319. data/lib/rubocop/cop/mixin/too_many_lines.rb +0 -25
  320. data/lib/rubocop/cop/style/method_missing_super.rb +0 -34
@@ -21,7 +21,9 @@ module RuboCop
21
21
  #
22
22
  # x < y && y < z
23
23
  # 10 <= x && x <= 20
24
- class MultipleComparison < Cop
24
+ class MultipleComparison < Base
25
+ extend AutoCorrector
26
+
25
27
  MSG = 'Use the `&&` operator to compare multiple values.'
26
28
 
27
29
  def_node_matcher :multiple_compare?, <<~PATTERN
@@ -29,16 +31,11 @@ module RuboCop
29
31
  PATTERN
30
32
 
31
33
  def on_send(node)
32
- return unless multiple_compare?(node)
33
-
34
- add_offense(node)
35
- end
34
+ return unless (center = multiple_compare?(node))
36
35
 
37
- def autocorrect(node)
38
- center = multiple_compare?(node)
39
- new_center = "#{center.source} && #{center.source}"
36
+ add_offense(node) do |corrector|
37
+ new_center = "#{center.source} && #{center.source}"
40
38
 
41
- lambda do |corrector|
42
39
  corrector.replace(center, new_center)
43
40
  end
44
41
  end
@@ -54,7 +54,7 @@ module RuboCop
54
54
  # end
55
55
  # end
56
56
  # end
57
- class NestedMethodDefinition < Cop
57
+ class NestedMethodDefinition < Base
58
58
  MSG = 'Method definitions must not be nested. ' \
59
59
  'Use `lambda` instead.'
60
60
 
@@ -15,7 +15,7 @@ module RuboCop
15
15
  # valid_attributes: %i[name content],
16
16
  # nested_attributes: %i[name content %i[incorrectly nested]]
17
17
  # }
18
- class NestedPercentLiteral < Cop
18
+ class NestedPercentLiteral < Base
19
19
  include PercentLiteral
20
20
 
21
21
  MSG = 'Within percent literals, nested percent literals do not ' \
@@ -22,7 +22,7 @@ module RuboCop
22
22
  # next acc if i.odd?
23
23
  # acc + i
24
24
  # end
25
- class NextWithoutAccumulator < Cop
25
+ class NextWithoutAccumulator < Base
26
26
  MSG = 'Use `next` with an accumulator argument in a `reduce`.'
27
27
 
28
28
  def_node_matcher :on_body_of_reduce, <<~PATTERN
@@ -51,7 +51,9 @@ module RuboCop
51
51
  # # good
52
52
  # Dir.glob(Rails.root.join('test', '*.rb')).sort.each(&method(:require))
53
53
  #
54
- class NonDeterministicRequireOrder < Cop
54
+ class NonDeterministicRequireOrder < Base
55
+ extend AutoCorrector
56
+
55
57
  MSG = 'Sort files before requiring them.'
56
58
 
57
59
  def on_block(node)
@@ -61,7 +63,9 @@ module RuboCop
61
63
  loop_variable(node.arguments) do |var_name|
62
64
  return unless var_is_required?(node.body, var_name)
63
65
 
64
- add_offense(node.send_node)
66
+ add_offense(node.send_node) do |corrector|
67
+ correct_block(corrector, node.send_node)
68
+ end
65
69
  end
66
70
  end
67
71
 
@@ -69,37 +73,37 @@ module RuboCop
69
73
  return unless method_require?(node)
70
74
  return unless unsorted_dir_pass?(node.parent)
71
75
 
72
- add_offense(node.parent)
76
+ parent_node = node.parent
77
+
78
+ add_offense(parent_node) do |corrector|
79
+ if parent_node.arguments.last&.block_pass_type?
80
+ correct_block_pass(corrector, parent_node)
81
+ else
82
+ correct_block(corrector, parent_node)
83
+ end
84
+ end
73
85
  end
74
86
 
75
- def autocorrect(node)
76
- return correct_block_pass(node) if node.arguments.last&.block_pass_type?
87
+ private
77
88
 
89
+ def correct_block(corrector, node)
78
90
  if unsorted_dir_block?(node)
79
- lambda do |corrector|
80
- corrector.replace(node, "#{node.source}.sort.each")
81
- end
91
+ corrector.replace(node, "#{node.source}.sort.each")
82
92
  else
83
- lambda do |corrector|
84
- source = node.receiver.source
85
- corrector.replace(node, "#{source}.sort.each")
86
- end
93
+ source = node.receiver.source
94
+
95
+ corrector.replace(node, "#{source}.sort.each")
87
96
  end
88
97
  end
89
98
 
90
- private
91
-
92
- def correct_block_pass(node)
99
+ def correct_block_pass(corrector, node)
93
100
  if unsorted_dir_glob_pass?(node)
94
- lambda do |corrector|
95
- block_arg = node.arguments.last
96
- corrector.remove(last_arg_range(node))
97
- corrector.insert_after(node, ".sort.each(#{block_arg.source})")
98
- end
101
+ block_arg = node.arguments.last
102
+
103
+ corrector.remove(last_arg_range(node))
104
+ corrector.insert_after(node, ".sort.each(#{block_arg.source})")
99
105
  else
100
- lambda do |corrector|
101
- corrector.replace(node.loc.selector, 'sort.each')
102
- end
106
+ corrector.replace(node.loc.selector, 'sort.each')
103
107
  end
104
108
  end
105
109
 
@@ -38,7 +38,7 @@ module RuboCop
38
38
  # end
39
39
  # end
40
40
  #
41
- class NonLocalExitFromIterator < Cop
41
+ class NonLocalExitFromIterator < Base
42
42
  MSG = 'Non-local exit from iterator, without return value. ' \
43
43
  '`next`, `break`, `Array#find`, `Array#any?`, etc. ' \
44
44
  'is preferred.'
@@ -57,7 +57,7 @@ module RuboCop
57
57
  next unless node.arguments?
58
58
 
59
59
  if chained_send?(node.send_node)
60
- add_offense(return_node, location: :keyword)
60
+ add_offense(return_node.loc.keyword)
61
61
  break
62
62
  end
63
63
  end
@@ -20,7 +20,9 @@ module RuboCop
20
20
  # Integer('10', 10)
21
21
  # Float('10.2')
22
22
  # Complex('10')
23
- class NumberConversion < Cop
23
+ class NumberConversion < Base
24
+ extend AutoCorrector
25
+
24
26
  CONVERSION_METHOD_CLASS_MAPPING = {
25
27
  to_i: "#{Integer.name}(%<number_object>s, 10)",
26
28
  to_f: "#{Float.name}(%<number_object>s)",
@@ -49,14 +51,9 @@ module RuboCop
49
51
  to_method: to_method,
50
52
  corrected_method: correct_method(node, receiver)
51
53
  )
52
- add_offense(node, message: message)
53
- end
54
- end
55
-
56
- def autocorrect(node)
57
- lambda do |corrector|
58
- corrector.replace(node,
59
- correct_method(node, node.receiver))
54
+ add_offense(node, message: message) do |corrector|
55
+ corrector.replace(node, correct_method(node, node.receiver))
56
+ end
60
57
  end
61
58
  end
62
59
 
@@ -27,13 +27,14 @@ module RuboCop
27
27
  # # frozen_string_literal: true
28
28
  # p [''.frozen?, ''.encoding] #=> [true, #<Encoding:US-ASCII>]
29
29
  #
30
- class OrderedMagicComments < Cop
30
+ class OrderedMagicComments < Base
31
31
  include FrozenStringLiteral
32
+ extend AutoCorrector
32
33
 
33
34
  MSG = 'The encoding magic comment should precede all other ' \
34
35
  'magic comments.'
35
36
 
36
- def investigate(processed_source)
37
+ def on_new_investigation
37
38
  return if processed_source.buffer.source.empty?
38
39
 
39
40
  encoding_line, frozen_string_literal_line = magic_comment_lines
@@ -43,24 +44,21 @@ module RuboCop
43
44
 
44
45
  range = processed_source.buffer.line_range(encoding_line + 1)
45
46
 
46
- add_offense(range, location: range)
47
+ add_offense(range) do |corrector|
48
+ autocorrect(corrector, encoding_line, frozen_string_literal_line)
49
+ end
47
50
  end
48
51
 
49
- def autocorrect(_node)
50
- encoding_line, frozen_string_literal_line = magic_comment_lines
52
+ private
51
53
 
54
+ def autocorrect(corrector, encoding_line, frozen_string_literal_line)
52
55
  range1 = processed_source.buffer.line_range(encoding_line + 1)
53
- range2 =
54
- processed_source.buffer.line_range(frozen_string_literal_line + 1)
56
+ range2 = processed_source.buffer.line_range(frozen_string_literal_line + 1)
55
57
 
56
- lambda do |corrector|
57
- corrector.replace(range1, range2.source)
58
- corrector.replace(range2, range1.source)
59
- end
58
+ corrector.replace(range1, range2.source)
59
+ corrector.replace(range2, range1.source)
60
60
  end
61
61
 
62
- private
63
-
64
62
  def magic_comment_lines
65
63
  lines = [nil, nil]
66
64
 
@@ -0,0 +1,90 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Lint
6
+ # This cops looks for references of Regexp captures that are out of range
7
+ # and thus always returns nil.
8
+ #
9
+ # @example
10
+ #
11
+ # /(foo)bar/ =~ 'foobar'
12
+ #
13
+ # # bad - always returns nil
14
+ #
15
+ # puts $2 # => nil
16
+ #
17
+ # # good
18
+ #
19
+ # puts $1 # => foo
20
+ #
21
+ class OutOfRangeRegexpRef < Base
22
+ MSG = 'Do not use out of range reference for the Regexp.'
23
+
24
+ REGEXP_RECEIVER_METHODS = %i[=~ === match].to_set.freeze
25
+ REGEXP_ARGUMENT_METHODS = %i[=~ match grep gsub gsub! sub sub! [] slice slice! index rindex
26
+ scan partition rpartition start_with? end_with?].to_set.freeze
27
+ REGEXP_CAPTURE_METHODS = (REGEXP_RECEIVER_METHODS + REGEXP_ARGUMENT_METHODS).freeze
28
+
29
+ def on_new_investigation
30
+ @valid_ref = 0
31
+ end
32
+
33
+ def on_match_with_lvasgn(node)
34
+ check_regexp(node.children.first)
35
+ end
36
+
37
+ def on_send(node)
38
+ return unless REGEXP_CAPTURE_METHODS.include?(node.method_name)
39
+
40
+ @valid_ref = nil
41
+
42
+ if node.receiver&.regexp_type?
43
+ check_regexp(node.receiver)
44
+ elsif node.first_argument&.regexp_type? \
45
+ && REGEXP_ARGUMENT_METHODS.include?(node.method_name)
46
+ check_regexp(node.first_argument)
47
+ end
48
+ end
49
+
50
+ def on_when(node)
51
+ regexp_conditions = node.conditions.select(&:regexp_type?)
52
+
53
+ @valid_ref = regexp_conditions.map do |condition|
54
+ check_regexp(condition)
55
+ end.compact.max
56
+ end
57
+
58
+ def on_nth_ref(node)
59
+ backref, = *node
60
+ return if @valid_ref.nil?
61
+
62
+ add_offense(node) if backref > @valid_ref
63
+ end
64
+
65
+ private
66
+
67
+ def check_regexp(regexp)
68
+ return if contain_non_literal?(regexp)
69
+
70
+ tree = Regexp::Parser.parse(regexp.content)
71
+ @valid_ref = regexp_captures(tree)
72
+ end
73
+
74
+ def contain_non_literal?(node)
75
+ node.children.size != 2 || !node.children.first.str_type?
76
+ end
77
+
78
+ def regexp_captures(tree)
79
+ named_capture = numbered_capture = 0
80
+ tree.each_expression do |e|
81
+ if e.type?(:group)
82
+ e.respond_to?(:name) ? named_capture += 1 : numbered_capture += 1
83
+ end
84
+ end
85
+ named_capture.positive? ? named_capture : numbered_capture
86
+ end
87
+ end
88
+ end
89
+ end
90
+ end
@@ -15,8 +15,9 @@ module RuboCop
15
15
  # do_something(foo)
16
16
  # do_something (2 + 3) * 4
17
17
  # do_something (foo * bar).baz
18
- class ParenthesesAsGroupedExpression < Cop
18
+ class ParenthesesAsGroupedExpression < Base
19
19
  include RangeHelp
20
+ extend AutoCorrector
20
21
 
21
22
  MSG = '`(...)` interpreted as grouped expression.'
22
23
 
@@ -28,18 +29,11 @@ module RuboCop
28
29
 
29
30
  range = space_range(node.first_argument.source_range, space_length)
30
31
 
31
- add_offense(node, location: range)
32
- end
33
- alias on_csend on_send
34
-
35
- def autocorrect(node)
36
- space_length = spaces_before_left_parenthesis(node)
37
- range = space_range(node.first_argument.source_range, space_length)
38
-
39
- lambda do |corrector|
32
+ add_offense(range) do |corrector|
40
33
  corrector.remove(range)
41
34
  end
42
35
  end
36
+ alias on_csend on_send
43
37
 
44
38
  private
45
39
 
@@ -20,8 +20,9 @@ module RuboCop
20
20
  # # good
21
21
  #
22
22
  # %w(foo bar)
23
- class PercentStringArray < Cop
23
+ class PercentStringArray < Base
24
24
  include PercentLiteral
25
+ extend AutoCorrector
25
26
 
26
27
  QUOTES_AND_COMMAS = [/,$/, /^'.*'$/, /^".*"$/].freeze
27
28
  LEADING_QUOTE = /^['"]/.freeze
@@ -37,24 +38,24 @@ module RuboCop
37
38
  def on_percent_literal(node)
38
39
  return unless contains_quotes_or_commas?(node)
39
40
 
40
- add_offense(node)
41
+ add_offense(node) do |corrector|
42
+ autocorrect(corrector, node)
43
+ end
41
44
  end
42
45
 
43
- def autocorrect(node)
44
- lambda do |corrector|
45
- node.each_value do |value|
46
- range = value.loc.expression
46
+ private
47
+
48
+ def autocorrect(corrector, node)
49
+ node.each_value do |value|
50
+ range = value.loc.expression
47
51
 
48
- match = range.source.match(TRAILING_QUOTE)
49
- corrector.remove_trailing(range, match[0].length) if match
52
+ match = range.source.match(TRAILING_QUOTE)
53
+ corrector.remove_trailing(range, match[0].length) if match
50
54
 
51
- corrector.remove_leading(range, 1) if LEADING_QUOTE.match?(range.source)
52
- end
55
+ corrector.remove_leading(range, 1) if LEADING_QUOTE.match?(range.source)
53
56
  end
54
57
  end
55
58
 
56
- private
57
-
58
59
  def contains_quotes_or_commas?(node)
59
60
  node.values.any? do |value|
60
61
  literal = value.children.first.to_s.scrub
@@ -20,8 +20,9 @@ module RuboCop
20
20
  # # good
21
21
  #
22
22
  # %i(foo bar)
23
- class PercentSymbolArray < Cop
23
+ class PercentSymbolArray < Base
24
24
  include PercentLiteral
25
+ extend AutoCorrector
25
26
 
26
27
  MSG = "Within `%i`/`%I`, ':' and ',' are unnecessary and may be " \
27
28
  'unwanted in the resulting symbols.'
@@ -33,23 +34,23 @@ module RuboCop
33
34
  def on_percent_literal(node)
34
35
  return unless contains_colons_or_commas?(node)
35
36
 
36
- add_offense(node)
37
+ add_offense(node) do |corrector|
38
+ autocorrect(corrector, node)
39
+ end
37
40
  end
38
41
 
39
- def autocorrect(node)
40
- lambda do |corrector|
41
- node.children.each do |child|
42
- range = child.loc.expression
42
+ private
43
+
44
+ def autocorrect(corrector, node)
45
+ node.children.each do |child|
46
+ range = child.loc.expression
43
47
 
44
- corrector.remove_trailing(range, 1) if range.source.end_with?(',')
45
- corrector.remove_leading(range, 1) if
46
- range.source.start_with?(':')
47
- end
48
+ corrector.remove_trailing(range, 1) if range.source.end_with?(',')
49
+ corrector.remove_leading(range, 1) if
50
+ range.source.start_with?(':')
48
51
  end
49
52
  end
50
53
 
51
- private
52
-
53
54
  def contains_colons_or_commas?(node)
54
55
  node.children.any? do |child|
55
56
  literal = child.children.first.to_s