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
@@ -16,16 +16,14 @@ module RuboCop
16
16
  # if /foo/ =~ $_
17
17
  # do_something
18
18
  # end
19
- class RegexpAsCondition < Cop
19
+ class RegexpAsCondition < Base
20
+ extend AutoCorrector
21
+
20
22
  MSG = 'Do not use regexp literal as a condition.' \
21
23
  ' The regexp literal matches `$_` implicitly.'
22
24
 
23
25
  def on_match_current_line(node)
24
- add_offense(node)
25
- end
26
-
27
- def autocorrect(node)
28
- lambda do |corrector|
26
+ add_offense(node) do |corrector|
29
27
  corrector.replace(node, "#{node.source} =~ $_")
30
28
  end
31
29
  end
@@ -27,7 +27,7 @@ module RuboCop
27
27
  # if day.is?(:tuesday) && month == :jan
28
28
  # # ...
29
29
  # end
30
- class RequireParentheses < Cop
30
+ class RequireParentheses < Base
31
31
  include RangeHelp
32
32
 
33
33
  MSG = 'Use parentheses in the method call to avoid confusion about ' \
@@ -52,7 +52,7 @@ module RuboCop
52
52
  range = range_between(node.source_range.begin_pos,
53
53
  ternary.condition.source_range.end_pos)
54
54
 
55
- add_offense(range, location: range)
55
+ add_offense(range)
56
56
  end
57
57
 
58
58
  def check_predicate(predicate, node)
@@ -24,7 +24,7 @@ module RuboCop
24
24
  # rescue ArgumentError
25
25
  # handle_exception
26
26
  # end
27
- class RescueException < Cop
27
+ class RescueException < Base
28
28
  MSG = 'Avoid rescuing the `Exception` class. ' \
29
29
  'Perhaps you meant to rescue `StandardError`?'
30
30
 
@@ -34,8 +34,9 @@ module RuboCop
34
34
  # rescue NameError
35
35
  # baz
36
36
  # end
37
- class RescueType < Cop
37
+ class RescueType < Base
38
38
  include RescueNode
39
+ extend AutoCorrector
39
40
 
40
41
  MSG = 'Rescuing from `%<invalid_exceptions>s` will raise a ' \
41
42
  '`TypeError` instead of catching the actual exception.'
@@ -50,24 +51,23 @@ module RuboCop
50
51
  return if invalid_exceptions.empty?
51
52
 
52
53
  add_offense(
53
- node,
54
- location: node.loc.keyword.join(rescued.loc.expression),
54
+ node.loc.keyword.join(rescued.loc.expression),
55
55
  message: format(
56
56
  MSG, invalid_exceptions: invalid_exceptions.map(&:source)
57
57
  .join(', ')
58
58
  )
59
- )
59
+ ) do |corrector|
60
+ autocorrect(corrector, node)
61
+ end
60
62
  end
61
63
 
62
- def autocorrect(node)
64
+ def autocorrect(corrector, node)
63
65
  rescued, _, _body = *node
64
66
  range = Parser::Source::Range.new(node.loc.expression.source_buffer,
65
67
  node.loc.keyword.end_pos,
66
68
  rescued.loc.expression.end_pos)
67
69
 
68
- lambda do |corrector|
69
- corrector.replace(range, correction(*rescued))
70
- end
70
+ corrector.replace(range, correction(*rescued))
71
71
  end
72
72
 
73
73
  private
@@ -31,7 +31,7 @@ module RuboCop
31
31
  # def foo=(bar)
32
32
  # return
33
33
  # end
34
- class ReturnInVoidContext < Cop
34
+ class ReturnInVoidContext < Base
35
35
  MSG = 'Do not return a value in `%<method>s`.'
36
36
 
37
37
  def on_return(return_node)
@@ -45,9 +45,7 @@ module RuboCop
45
45
 
46
46
  return unless method_name && void_context_method?(method_name)
47
47
 
48
- add_offense(return_node,
49
- location: :keyword,
50
- message: format(message, method: method_name))
48
+ add_offense(return_node.loc.keyword, message: format(message, method: method_name))
51
49
  end
52
50
 
53
51
  private
@@ -23,7 +23,7 @@ module RuboCop
23
23
  #
24
24
  # x&.foo&.bar
25
25
  # x&.foo || bar
26
- class SafeNavigationChain < Cop
26
+ class SafeNavigationChain < Base
27
27
  include NilMethods
28
28
 
29
29
  MSG = 'Do not chain ordinary method call' \
@@ -45,7 +45,7 @@ module RuboCop
45
45
  Parser::Source::Range.new(node.source_range.source_buffer,
46
46
  safe_nav.source_range.end_pos,
47
47
  method_chain.source_range.end_pos)
48
- add_offense(node, location: location)
48
+ add_offense(location)
49
49
  end
50
50
  end
51
51
 
@@ -53,10 +53,7 @@ module RuboCop
53
53
 
54
54
  def method_chain(node)
55
55
  chain = node
56
- while chain.send_type?
57
- chain = chain.parent if chain.parent&.call_type?
58
- break # FIXME: Unconditional break. Why while "loop" then?
59
- end
56
+ chain = chain.parent if chain.send_type? && chain.parent&.call_type?
60
57
  chain
61
58
  end
62
59
  end
@@ -26,9 +26,10 @@ module RuboCop
26
26
  # # good
27
27
  # foo&.bar && (foobar.baz || foo&.baz)
28
28
  #
29
- class SafeNavigationConsistency < Cop
29
+ class SafeNavigationConsistency < Base
30
30
  include IgnoredNode
31
31
  include NilMethods
32
+ extend AutoCorrector
32
33
 
33
34
  MSG = 'Ensure that safe navigation is used consistently ' \
34
35
  'inside of `&&` and `||`.'
@@ -49,24 +50,27 @@ module RuboCop
49
50
  unsafe_method_calls(method_calls, safe_nav_receiver)
50
51
 
51
52
  unsafe_method_calls.each do |unsafe_method_call|
52
- location =
53
- node.loc.expression.join(unsafe_method_call.loc.expression)
54
- add_offense(unsafe_method_call,
55
- location: location)
53
+ location = location(node, unsafe_method_call)
54
+
55
+ add_offense(location) do |corrector|
56
+ autocorrect(corrector, unsafe_method_call)
57
+ end
56
58
 
57
59
  ignore_node(unsafe_method_call)
58
60
  end
59
61
  end
60
62
 
61
- def autocorrect(node)
63
+ private
64
+
65
+ def autocorrect(corrector, node)
62
66
  return unless node.dot?
63
67
 
64
- lambda do |corrector|
65
- corrector.insert_before(node.loc.dot, '&')
66
- end
68
+ corrector.insert_before(node.loc.dot, '&')
67
69
  end
68
70
 
69
- private
71
+ def location(node, unsafe_method_call)
72
+ node.loc.expression.join(unsafe_method_call.loc.expression)
73
+ end
70
74
 
71
75
  def top_conditional_ancestor(node)
72
76
  parent = node.parent
@@ -19,7 +19,9 @@ module RuboCop
19
19
  # return if foo && foo.empty?
20
20
  # return unless foo && foo.empty?
21
21
  #
22
- class SafeNavigationWithEmpty < Cop
22
+ class SafeNavigationWithEmpty < Base
23
+ extend AutoCorrector
24
+
23
25
  MSG = 'Avoid calling `empty?` with the safe navigation operator ' \
24
26
  'in conditionals.'
25
27
 
@@ -30,14 +32,12 @@ module RuboCop
30
32
  def on_if(node)
31
33
  return unless safe_navigation_empty_in_conditional?(node)
32
34
 
33
- add_offense(node.condition)
34
- end
35
+ condition = node.condition
35
36
 
36
- def autocorrect(node)
37
- lambda do |corrector|
38
- receiver = node.receiver.source
37
+ add_offense(condition) do |corrector|
38
+ receiver = condition.receiver.source
39
39
 
40
- corrector.replace(node, "#{receiver} && #{receiver}.#{node.method_name}")
40
+ corrector.replace(condition, "#{receiver} && #{receiver}.#{condition.method_name}")
41
41
  end
42
42
  end
43
43
  end
@@ -30,11 +30,13 @@ module RuboCop
30
30
  #
31
31
  # puts 'hello, world'
32
32
  #
33
- class ScriptPermission < Cop
33
+ class ScriptPermission < Base
34
+ extend AutoCorrector
35
+
34
36
  MSG = "Script file %<file>s doesn't have execute permission."
35
37
  SHEBANG = '#!'
36
38
 
37
- def investigate(processed_source)
39
+ def on_new_investigation
38
40
  return if @options.key?(:stdin)
39
41
  return if Platform.windows?
40
42
  return unless processed_source.start_with?(SHEBANG)
@@ -42,17 +44,18 @@ module RuboCop
42
44
 
43
45
  comment = processed_source.comments[0]
44
46
  message = format_message_from(processed_source)
45
- add_offense(comment, message: message)
46
- end
47
47
 
48
- def autocorrect(node)
49
- lambda do |_corrector|
50
- FileUtils.chmod('+x', node.loc.expression.source_buffer.name)
48
+ add_offense(comment, message: message) do
49
+ autocorrect(comment) if autocorrect_requested?
51
50
  end
52
51
  end
53
52
 
54
53
  private
55
54
 
55
+ def autocorrect(comment)
56
+ FileUtils.chmod('+x', comment.loc.expression.source_buffer.name)
57
+ end
58
+
56
59
  def executable?(processed_source)
57
60
  # Returns true if stat is executable or if the operating system
58
61
  # doesn't distinguish executable files from nonexecutable files.
@@ -0,0 +1,78 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Lint
6
+ # This cop checks for self-assignments.
7
+ #
8
+ # @example
9
+ # # bad
10
+ # foo = foo
11
+ # foo, bar = foo, bar
12
+ # Foo = Foo
13
+ #
14
+ # # good
15
+ # foo = bar
16
+ # foo, bar = bar, foo
17
+ # Foo = Bar
18
+ #
19
+ class SelfAssignment < Base
20
+ MSG = 'Self-assignment detected.'
21
+
22
+ ASSIGNMENT_TYPE_TO_RHS_TYPE = {
23
+ lvasgn: :lvar,
24
+ ivasgn: :ivar,
25
+ cvasgn: :cvar,
26
+ gvasgn: :gvar
27
+ }.freeze
28
+
29
+ def on_lvasgn(node)
30
+ lhs, rhs = *node
31
+ return unless rhs
32
+
33
+ rhs_type = ASSIGNMENT_TYPE_TO_RHS_TYPE[node.type]
34
+
35
+ add_offense(node) if rhs.type == rhs_type && rhs.source == lhs.to_s
36
+ end
37
+ alias on_ivasgn on_lvasgn
38
+ alias on_cvasgn on_lvasgn
39
+ alias on_gvasgn on_lvasgn
40
+
41
+ def on_casgn(node)
42
+ lhs_scope, lhs_name, rhs = *node
43
+ return unless rhs&.const_type?
44
+
45
+ rhs_scope, rhs_name = *rhs
46
+ add_offense(node) if lhs_scope == rhs_scope && lhs_name == rhs_name
47
+ end
48
+
49
+ def on_masgn(node)
50
+ add_offense(node) if multiple_self_assignment?(node)
51
+ end
52
+
53
+ def on_or_asgn(node)
54
+ lhs, rhs = *node
55
+ add_offense(node) if rhs_matches_lhs?(rhs, lhs)
56
+ end
57
+ alias on_and_asgn on_or_asgn
58
+
59
+ private
60
+
61
+ def multiple_self_assignment?(node)
62
+ lhs, rhs = *node
63
+ return false unless rhs.array_type?
64
+ return false unless lhs.children.size == rhs.children.size
65
+
66
+ lhs.children.zip(rhs.children).all? do |lhs_item, rhs_item|
67
+ rhs_matches_lhs?(rhs_item, lhs_item)
68
+ end
69
+ end
70
+
71
+ def rhs_matches_lhs?(rhs, lhs)
72
+ rhs.type == ASSIGNMENT_TYPE_TO_RHS_TYPE[lhs.type] &&
73
+ rhs.children.first == lhs.children.first
74
+ end
75
+ end
76
+ end
77
+ end
78
+ end
@@ -34,8 +34,9 @@ module RuboCop
34
34
  # Foo.prepend Bar
35
35
  # Foo.extend Bar
36
36
  #
37
- class SendWithMixinArgument < Cop
37
+ class SendWithMixinArgument < Base
38
38
  include RangeHelp
39
+ extend AutoCorrector
39
40
 
40
41
  MSG = 'Use `%<method>s %<module_name>s` instead of `%<bad_method>s`.'
41
42
  MIXIN_METHODS = %i[include prepend extend].freeze
@@ -53,16 +54,9 @@ module RuboCop
53
54
  method, module_name.source, bad_location(node).source
54
55
  )
55
56
 
56
- add_offense(node, location: bad_location(node), message: message)
57
- end
58
- end
59
-
60
- def autocorrect(node)
61
- send_with_mixin_argument?(node) do |method, module_name|
62
- lambda do |corrector|
63
- corrector.replace(
64
- bad_location(node), "#{method} #{module_name.source}"
65
- )
57
+ bad_location = bad_location(node)
58
+ add_offense(bad_location, message: message) do |corrector|
59
+ corrector.replace(bad_location, "#{method} #{module_name.source}")
66
60
  end
67
61
  end
68
62
  end
@@ -63,14 +63,14 @@ module RuboCop
63
63
  # bar
64
64
  # end
65
65
  #
66
- class ShadowedArgument < Cop
66
+ class ShadowedArgument < Base
67
67
  MSG = 'Argument `%<argument>s` was shadowed by a local variable ' \
68
68
  'before it was used.'
69
69
 
70
70
  def_node_search :uses_var?, '(lvar %)'
71
71
 
72
- def join_force?(force_class)
73
- force_class == VariableForce
72
+ def self.joining_forces
73
+ VariableForce
74
74
  end
75
75
 
76
76
  def after_leaving_scope(scope, _variable_table)
@@ -43,7 +43,7 @@ module RuboCop
43
43
  # handle_standard_error
44
44
  # end
45
45
  #
46
- class ShadowedException < Cop
46
+ class ShadowedException < Base
47
47
  include RescueNode
48
48
  include RangeHelp
49
49
 
@@ -62,7 +62,7 @@ module RuboCop
62
62
  return if !rescue_group_rescues_multiple_levels &&
63
63
  sorted?(rescued_groups)
64
64
 
65
- add_offense(node, location: offense_range(rescues))
65
+ add_offense(offense_range(rescues))
66
66
  end
67
67
 
68
68
  private
@@ -31,11 +31,11 @@ module RuboCop
31
31
  # do_something(bar)
32
32
  # end
33
33
  # end
34
- class ShadowingOuterLocalVariable < Cop
34
+ class ShadowingOuterLocalVariable < Base
35
35
  MSG = 'Shadowing outer local variable - `%<variable>s`.'
36
36
 
37
- def join_force?(force_class)
38
- force_class == VariableForce
37
+ def self.joining_forces
38
+ VariableForce
39
39
  end
40
40
 
41
41
  def before_declaring_variable(variable, variable_table)
@@ -21,7 +21,7 @@ module RuboCop
21
21
  # g.clone #=> #<struct Good id=1, name="foo">
22
22
  # g.count #=> 2
23
23
  #
24
- class StructNewOverride < Cop
24
+ class StructNewOverride < Base
25
25
  MSG = '`%<member_name>s` member overrides `Struct#%<method_name>s`' \
26
26
  ' and it may be unexpected.'
27
27
 
@@ -64,7 +64,7 @@ module RuboCop
64
64
  # rescue
65
65
  # # do nothing
66
66
  # end
67
- class SuppressedException < Cop
67
+ class SuppressedException < Base
68
68
  MSG = 'Do not suppress exceptions.'
69
69
 
70
70
  def on_resbody(node)
@@ -77,13 +77,10 @@ module RuboCop
77
77
  private
78
78
 
79
79
  def comment_between_rescue_and_end?(node)
80
- end_line = nil
81
- node.each_ancestor(:kwbegin, :def, :defs, :block) do |ancestor|
82
- end_line = ancestor.loc.end.line
83
- break
84
- end
85
- return false unless end_line
80
+ ancestor = node.each_ancestor(:kwbegin, :def, :defs, :block).first
81
+ return unless ancestor
86
82
 
83
+ end_line = ancestor.loc.end.line
87
84
  processed_source[node.first_line...end_line].any? { |line| comment_line?(line) }
88
85
  end
89
86
  end