rubocop 1.24.1 → 1.64.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 (742) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.txt +1 -1
  3. data/README.md +11 -8
  4. data/assets/output.css.erb +159 -0
  5. data/assets/output.html.erb +1 -160
  6. data/config/default.yml +707 -100
  7. data/config/obsoletion.yml +40 -2
  8. data/exe/rubocop +15 -7
  9. data/lib/rubocop/arguments_env.rb +17 -0
  10. data/lib/rubocop/arguments_file.rb +17 -0
  11. data/lib/rubocop/cache_config.rb +29 -0
  12. data/lib/rubocop/cached_data.rb +11 -3
  13. data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +47 -11
  14. data/lib/rubocop/cli/command/execute_runner.rb +15 -10
  15. data/lib/rubocop/cli/command/init_dotfile.rb +1 -1
  16. data/lib/rubocop/cli/command/lsp.rb +19 -0
  17. data/lib/rubocop/cli/command/show_cops.rb +1 -1
  18. data/lib/rubocop/cli/command/show_docs_url.rb +2 -2
  19. data/lib/rubocop/cli/command/suggest_extensions.rb +62 -17
  20. data/lib/rubocop/cli.rb +72 -12
  21. data/lib/rubocop/comment_config.rb +60 -1
  22. data/lib/rubocop/config.rb +84 -28
  23. data/lib/rubocop/config_finder.rb +78 -0
  24. data/lib/rubocop/config_loader.rb +48 -69
  25. data/lib/rubocop/config_loader_resolver.rb +8 -8
  26. data/lib/rubocop/config_obsoletion/changed_parameter.rb +5 -0
  27. data/lib/rubocop/config_obsoletion/extracted_cop.rb +3 -1
  28. data/lib/rubocop/config_obsoletion/parameter_rule.rb +13 -1
  29. data/lib/rubocop/config_obsoletion.rb +15 -7
  30. data/lib/rubocop/config_validator.rb +34 -10
  31. data/lib/rubocop/cop/autocorrect_logic.rb +44 -15
  32. data/lib/rubocop/cop/badge.rb +15 -4
  33. data/lib/rubocop/cop/base.rb +181 -98
  34. data/lib/rubocop/cop/bundler/duplicated_gem.rb +4 -7
  35. data/lib/rubocop/cop/bundler/duplicated_group.rb +127 -0
  36. data/lib/rubocop/cop/bundler/gem_comment.rb +5 -5
  37. data/lib/rubocop/cop/bundler/gem_filename.rb +5 -5
  38. data/lib/rubocop/cop/bundler/gem_version.rb +5 -7
  39. data/lib/rubocop/cop/bundler/ordered_gems.rb +11 -3
  40. data/lib/rubocop/cop/commissioner.rb +19 -6
  41. data/lib/rubocop/cop/cop.rb +54 -34
  42. data/lib/rubocop/cop/corrector.rb +33 -13
  43. data/lib/rubocop/cop/correctors/alignment_corrector.rb +4 -4
  44. data/lib/rubocop/cop/correctors/condition_corrector.rb +1 -1
  45. data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +5 -9
  46. data/lib/rubocop/cop/correctors/empty_line_corrector.rb +1 -1
  47. data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +10 -16
  48. data/lib/rubocop/cop/correctors/if_then_corrector.rb +1 -1
  49. data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +8 -5
  50. data/lib/rubocop/cop/correctors/line_break_corrector.rb +8 -2
  51. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -10
  52. data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +3 -8
  53. data/lib/rubocop/cop/correctors/parentheses_corrector.rb +59 -1
  54. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +3 -3
  55. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  56. data/lib/rubocop/cop/correctors/space_corrector.rb +1 -1
  57. data/lib/rubocop/cop/correctors/string_literal_corrector.rb +1 -1
  58. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +2 -2
  59. data/lib/rubocop/cop/documentation.rb +16 -6
  60. data/lib/rubocop/cop/exclude_limit.rb +1 -1
  61. data/lib/rubocop/cop/force.rb +12 -0
  62. data/lib/rubocop/cop/gemspec/dependency_version.rb +152 -0
  63. data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +92 -0
  64. data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
  65. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +5 -12
  66. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +10 -2
  67. data/lib/rubocop/cop/gemspec/require_mfa.rb +25 -24
  68. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +15 -4
  69. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +1 -1
  70. data/lib/rubocop/cop/generator/require_file_injector.rb +3 -3
  71. data/lib/rubocop/cop/generator.rb +12 -13
  72. data/lib/rubocop/cop/internal_affairs/cop_description.rb +122 -0
  73. data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
  74. data/lib/rubocop/cop/internal_affairs/empty_line_between_expect_offense_and_correction.rb +1 -1
  75. data/lib/rubocop/cop/internal_affairs/example_description.rb +46 -24
  76. data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
  77. data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +1 -1
  78. data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
  79. data/lib/rubocop/cop/internal_affairs/location_expression.rb +37 -0
  80. data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +4 -2
  81. data/lib/rubocop/cop/internal_affairs/method_name_end_with.rb +82 -0
  82. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +19 -20
  83. data/lib/rubocop/cop/internal_affairs/node_first_or_last_argument.rb +53 -0
  84. data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +128 -38
  85. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -1
  86. data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
  87. data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
  88. data/lib/rubocop/cop/internal_affairs/redundant_context_config_parameter.rb +46 -0
  89. data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +1 -1
  90. data/lib/rubocop/cop/internal_affairs/redundant_expect_offense_arguments.rb +34 -0
  91. data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +12 -4
  92. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -1
  93. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -1
  94. data/lib/rubocop/cop/internal_affairs/redundant_method_dispatch_node.rb +11 -2
  95. data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +66 -0
  96. data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +62 -0
  97. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -0
  98. data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
  99. data/lib/rubocop/cop/internal_affairs.rb +14 -0
  100. data/lib/rubocop/cop/layout/argument_alignment.rb +57 -9
  101. data/lib/rubocop/cop/layout/array_alignment.rb +1 -1
  102. data/lib/rubocop/cop/layout/assignment_indentation.rb +1 -1
  103. data/lib/rubocop/cop/layout/begin_end_alignment.rb +1 -1
  104. data/lib/rubocop/cop/layout/block_alignment.rb +17 -13
  105. data/lib/rubocop/cop/layout/block_end_newline.rb +32 -10
  106. data/lib/rubocop/cop/layout/case_indentation.rb +17 -1
  107. data/lib/rubocop/cop/layout/class_structure.rb +44 -27
  108. data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +2 -3
  109. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +3 -7
  110. data/lib/rubocop/cop/layout/comment_indentation.rb +6 -4
  111. data/lib/rubocop/cop/layout/condition_position.rb +1 -1
  112. data/lib/rubocop/cop/layout/def_end_alignment.rb +1 -1
  113. data/lib/rubocop/cop/layout/dot_position.rb +2 -6
  114. data/lib/rubocop/cop/layout/else_alignment.rb +1 -1
  115. data/lib/rubocop/cop/layout/empty_comment.rb +7 -5
  116. data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +42 -9
  117. data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +14 -7
  118. data/lib/rubocop/cop/layout/empty_line_after_multiline_condition.rb +1 -1
  119. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +29 -6
  120. data/lib/rubocop/cop/layout/empty_lines.rb +4 -2
  121. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +7 -2
  122. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +1 -1
  123. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +25 -4
  124. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +1 -1
  125. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +7 -5
  126. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +10 -10
  127. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +8 -2
  128. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +1 -1
  129. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +10 -10
  130. data/lib/rubocop/cop/layout/end_alignment.rb +24 -4
  131. data/lib/rubocop/cop/layout/end_of_line.rb +5 -5
  132. data/lib/rubocop/cop/layout/extra_spacing.rb +13 -10
  133. data/lib/rubocop/cop/layout/first_argument_indentation.rb +43 -32
  134. data/lib/rubocop/cop/layout/first_array_element_indentation.rb +45 -21
  135. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +36 -9
  136. data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +52 -13
  137. data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +37 -2
  138. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +58 -9
  139. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +53 -20
  140. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +2 -2
  141. data/lib/rubocop/cop/layout/hash_alignment.rb +8 -1
  142. data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +13 -7
  143. data/lib/rubocop/cop/layout/heredoc_indentation.rb +13 -13
  144. data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -1
  145. data/lib/rubocop/cop/layout/indentation_style.rb +9 -4
  146. data/lib/rubocop/cop/layout/indentation_width.rb +20 -14
  147. data/lib/rubocop/cop/layout/initial_indentation.rb +3 -3
  148. data/lib/rubocop/cop/layout/leading_comment_space.rb +3 -3
  149. data/lib/rubocop/cop/layout/leading_empty_lines.rb +1 -1
  150. data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +144 -0
  151. data/lib/rubocop/cop/layout/line_continuation_spacing.rb +140 -0
  152. data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +4 -2
  153. data/lib/rubocop/cop/layout/line_length.rb +13 -6
  154. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +1 -1
  155. data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +32 -2
  156. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +2 -2
  157. data/lib/rubocop/cop/layout/multiline_block_layout.rb +5 -3
  158. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +1 -1
  159. data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +30 -2
  160. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +40 -3
  161. data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +1 -1
  162. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +40 -8
  163. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +1 -1
  164. data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +77 -0
  165. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +9 -10
  166. data/lib/rubocop/cop/layout/redundant_line_break.rb +39 -18
  167. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +8 -8
  168. data/lib/rubocop/cop/layout/single_line_block_chain.rb +6 -1
  169. data/lib/rubocop/cop/layout/space_after_comma.rb +9 -1
  170. data/lib/rubocop/cop/layout/space_after_not.rb +2 -2
  171. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +3 -3
  172. data/lib/rubocop/cop/layout/space_around_keyword.rb +3 -3
  173. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +2 -2
  174. data/lib/rubocop/cop/layout/space_around_operators.rb +54 -22
  175. data/lib/rubocop/cop/layout/space_before_block_braces.rb +24 -13
  176. data/lib/rubocop/cop/layout/space_before_brackets.rb +7 -0
  177. data/lib/rubocop/cop/layout/space_before_comment.rb +1 -1
  178. data/lib/rubocop/cop/layout/space_before_first_arg.rb +2 -2
  179. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +3 -3
  180. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +32 -30
  181. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -0
  182. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +35 -15
  183. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +31 -4
  184. data/lib/rubocop/cop/layout/space_inside_parens.rb +3 -3
  185. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
  186. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +1 -1
  187. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +11 -7
  188. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +7 -7
  189. data/lib/rubocop/cop/layout/trailing_empty_lines.rb +15 -10
  190. data/lib/rubocop/cop/layout/trailing_whitespace.rb +15 -8
  191. data/lib/rubocop/cop/legacy/corrections_proxy.rb +1 -1
  192. data/lib/rubocop/cop/legacy/corrector.rb +1 -1
  193. data/lib/rubocop/cop/lint/ambiguous_assignment.rb +1 -1
  194. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +41 -8
  195. data/lib/rubocop/cop/lint/ambiguous_operator.rb +11 -7
  196. data/lib/rubocop/cop/lint/ambiguous_operator_precedence.rb +1 -1
  197. data/lib/rubocop/cop/lint/ambiguous_range.rb +5 -5
  198. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +6 -2
  199. data/lib/rubocop/cop/lint/assignment_in_condition.rb +18 -8
  200. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +3 -3
  201. data/lib/rubocop/cop/lint/boolean_symbol.rb +1 -1
  202. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  203. data/lib/rubocop/cop/lint/constant_overwritten_in_rescue.rb +51 -0
  204. data/lib/rubocop/cop/lint/constant_resolution.rb +5 -1
  205. data/lib/rubocop/cop/lint/debugger.rb +70 -35
  206. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +67 -111
  207. data/lib/rubocop/cop/lint/deprecated_constants.rb +9 -2
  208. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +1 -1
  209. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +1 -1
  210. data/lib/rubocop/cop/lint/duplicate_branch.rb +1 -3
  211. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  212. data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +1 -1
  213. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +3 -2
  214. data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
  215. data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
  216. data/lib/rubocop/cop/lint/duplicate_methods.rb +50 -20
  217. data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +56 -12
  218. data/lib/rubocop/cop/lint/duplicate_require.rb +11 -2
  219. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +1 -1
  220. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  221. data/lib/rubocop/cop/lint/else_layout.rb +6 -10
  222. data/lib/rubocop/cop/lint/empty_block.rb +5 -9
  223. data/lib/rubocop/cop/lint/empty_class.rb +4 -2
  224. data/lib/rubocop/cop/lint/empty_conditional_body.rb +114 -4
  225. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
  226. data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
  227. data/lib/rubocop/cop/lint/empty_file.rb +1 -1
  228. data/lib/rubocop/cop/lint/empty_in_pattern.rb +4 -2
  229. data/lib/rubocop/cop/lint/empty_interpolation.rb +2 -2
  230. data/lib/rubocop/cop/lint/empty_when.rb +4 -2
  231. data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
  232. data/lib/rubocop/cop/lint/erb_new_arguments.rb +37 -31
  233. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  234. data/lib/rubocop/cop/lint/float_comparison.rb +11 -1
  235. data/lib/rubocop/cop/lint/float_out_of_range.rb +1 -1
  236. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +14 -7
  237. data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +2 -1
  238. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +17 -19
  239. data/lib/rubocop/cop/lint/identity_comparison.rb +0 -1
  240. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +2 -2
  241. data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +20 -10
  242. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +2 -2
  243. data/lib/rubocop/cop/lint/inherit_exception.rb +28 -28
  244. data/lib/rubocop/cop/lint/interpolation_check.rb +6 -5
  245. data/lib/rubocop/cop/lint/it_without_arguments_in_block.rb +56 -0
  246. data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +11 -4
  247. data/lib/rubocop/cop/lint/literal_as_condition.rb +6 -1
  248. data/lib/rubocop/cop/lint/literal_assignment_in_condition.rb +85 -0
  249. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +50 -4
  250. data/lib/rubocop/cop/lint/loop.rb +2 -2
  251. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +19 -4
  252. data/lib/rubocop/cop/lint/missing_super.rb +64 -6
  253. data/lib/rubocop/cop/lint/mixed_case_range.rb +116 -0
  254. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -0
  255. data/lib/rubocop/cop/lint/nested_method_definition.rb +54 -10
  256. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  257. data/lib/rubocop/cop/lint/next_without_accumulator.rb +11 -7
  258. data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +165 -0
  259. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +20 -10
  260. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +1 -1
  261. data/lib/rubocop/cop/lint/number_conversion.rb +46 -14
  262. data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +3 -3
  263. data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +4 -3
  264. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +4 -6
  265. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +17 -2
  266. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +10 -4
  267. data/lib/rubocop/cop/lint/percent_string_array.rb +2 -2
  268. data/lib/rubocop/cop/lint/percent_symbol_array.rb +2 -2
  269. data/lib/rubocop/cop/lint/raise_exception.rb +2 -2
  270. data/lib/rubocop/cop/lint/rand_one.rb +1 -1
  271. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +55 -15
  272. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +8 -8
  273. data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +12 -0
  274. data/lib/rubocop/cop/lint/redundant_regexp_quantifiers.rb +130 -0
  275. data/lib/rubocop/cop/lint/redundant_require_statement.rb +57 -7
  276. data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +88 -11
  277. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +2 -2
  278. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +35 -15
  279. data/lib/rubocop/cop/lint/redundant_with_index.rb +19 -12
  280. data/lib/rubocop/cop/lint/redundant_with_object.rb +14 -13
  281. data/lib/rubocop/cop/lint/refinement_import_methods.rb +52 -0
  282. data/lib/rubocop/cop/lint/regexp_as_condition.rb +9 -3
  283. data/lib/rubocop/cop/lint/require_parentheses.rb +4 -2
  284. data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
  285. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  286. data/lib/rubocop/cop/lint/rescue_type.rb +2 -4
  287. data/lib/rubocop/cop/lint/return_in_void_context.rb +6 -18
  288. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +54 -12
  289. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +2 -2
  290. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +1 -1
  291. data/lib/rubocop/cop/lint/script_permission.rb +4 -4
  292. data/lib/rubocop/cop/lint/self_assignment.rb +39 -1
  293. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +6 -6
  294. data/lib/rubocop/cop/lint/shadowed_argument.rb +2 -1
  295. data/lib/rubocop/cop/lint/shadowed_exception.rb +22 -23
  296. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +42 -1
  297. data/lib/rubocop/cop/lint/struct_new_override.rb +15 -15
  298. data/lib/rubocop/cop/lint/suppressed_exception.rb +4 -4
  299. data/lib/rubocop/cop/lint/symbol_conversion.rb +12 -6
  300. data/lib/rubocop/cop/lint/syntax.rb +12 -6
  301. data/lib/rubocop/cop/lint/to_enum_arguments.rb +24 -7
  302. data/lib/rubocop/cop/lint/to_json.rb +1 -1
  303. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +24 -10
  304. data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +3 -3
  305. data/lib/rubocop/cop/lint/triple_quotes.rb +1 -1
  306. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
  307. data/lib/rubocop/cop/lint/unexpected_block_arity.rb +1 -1
  308. data/lib/rubocop/cop/lint/unified_integer.rb +3 -1
  309. data/lib/rubocop/cop/lint/unmodified_reduce_accumulator.rb +2 -2
  310. data/lib/rubocop/cop/lint/unreachable_code.rb +5 -3
  311. data/lib/rubocop/cop/lint/unreachable_loop.rb +23 -11
  312. data/lib/rubocop/cop/lint/unused_block_argument.rb +1 -1
  313. data/lib/rubocop/cop/lint/unused_method_argument.rb +8 -3
  314. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  315. data/lib/rubocop/cop/lint/uri_regexp.rb +1 -1
  316. data/lib/rubocop/cop/lint/useless_access_modifier.rb +20 -15
  317. data/lib/rubocop/cop/lint/useless_assignment.rb +95 -11
  318. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +2 -3
  319. data/lib/rubocop/cop/lint/useless_method_definition.rb +13 -5
  320. data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
  321. data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +16 -6
  322. data/lib/rubocop/cop/lint/useless_setter_call.rb +2 -2
  323. data/lib/rubocop/cop/lint/useless_times.rb +17 -13
  324. data/lib/rubocop/cop/lint/void.rb +126 -25
  325. data/lib/rubocop/cop/metrics/abc_size.rb +8 -6
  326. data/lib/rubocop/cop/metrics/block_length.rb +18 -13
  327. data/lib/rubocop/cop/metrics/block_nesting.rb +3 -3
  328. data/lib/rubocop/cop/metrics/class_length.rb +17 -6
  329. data/lib/rubocop/cop/metrics/collection_literal_length.rb +76 -0
  330. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -2
  331. data/lib/rubocop/cop/metrics/method_length.rb +19 -13
  332. data/lib/rubocop/cop/metrics/module_length.rb +10 -5
  333. data/lib/rubocop/cop/metrics/parameter_lists.rb +28 -1
  334. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -2
  335. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +6 -11
  336. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +62 -12
  337. data/lib/rubocop/cop/migration/department_name.rb +3 -3
  338. data/lib/rubocop/cop/mixin/alignment.rb +2 -2
  339. data/lib/rubocop/cop/mixin/allowed_identifiers.rb +2 -2
  340. data/lib/rubocop/cop/mixin/allowed_methods.rb +23 -2
  341. data/lib/rubocop/cop/mixin/allowed_pattern.rb +56 -0
  342. data/lib/rubocop/cop/mixin/allowed_receivers.rb +34 -0
  343. data/lib/rubocop/cop/mixin/annotation_comment.rb +14 -7
  344. data/lib/rubocop/cop/mixin/check_line_breakable.rb +5 -1
  345. data/lib/rubocop/cop/mixin/code_length.rb +12 -1
  346. data/lib/rubocop/cop/mixin/comments_help.rb +51 -3
  347. data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +21 -9
  348. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -0
  349. data/lib/rubocop/cop/mixin/def_node.rb +3 -8
  350. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  351. data/lib/rubocop/cop/mixin/duplication.rb +1 -1
  352. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +1 -1
  353. data/lib/rubocop/cop/mixin/enforce_superclass.rb +2 -1
  354. data/lib/rubocop/cop/mixin/first_element_line_break.rb +11 -7
  355. data/lib/rubocop/cop/mixin/frozen_string_literal.rb +4 -0
  356. data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +1 -1
  357. data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +189 -9
  358. data/lib/rubocop/cop/mixin/hash_transform_method.rb +13 -9
  359. data/lib/rubocop/cop/mixin/heredoc.rb +6 -2
  360. data/lib/rubocop/cop/mixin/line_length_help.rb +28 -8
  361. data/lib/rubocop/cop/mixin/method_complexity.rb +28 -22
  362. data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
  363. data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +34 -12
  364. data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +5 -6
  365. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +7 -5
  366. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +1 -1
  367. data/lib/rubocop/cop/mixin/percent_array.rb +58 -1
  368. data/lib/rubocop/cop/mixin/percent_literal.rb +1 -1
  369. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +7 -9
  370. data/lib/rubocop/cop/mixin/preferred_delimiters.rb +2 -2
  371. data/lib/rubocop/cop/mixin/range_help.rb +28 -7
  372. data/lib/rubocop/cop/mixin/require_library.rb +2 -0
  373. data/lib/rubocop/cop/mixin/rescue_node.rb +5 -3
  374. data/lib/rubocop/cop/mixin/safe_assignment.rb +1 -1
  375. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +1 -1
  376. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +1 -1
  377. data/lib/rubocop/cop/mixin/statement_modifier.rb +19 -4
  378. data/lib/rubocop/cop/mixin/string_help.rb +5 -3
  379. data/lib/rubocop/cop/mixin/surrounding_space.rb +17 -13
  380. data/lib/rubocop/cop/mixin/trailing_comma.rb +4 -4
  381. data/lib/rubocop/cop/mixin/visibility_help.rb +40 -5
  382. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  383. data/lib/rubocop/cop/naming/ascii_identifiers.rb +2 -2
  384. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
  385. data/lib/rubocop/cop/naming/block_forwarding.rb +61 -16
  386. data/lib/rubocop/cop/naming/block_parameter_name.rb +2 -2
  387. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +4 -2
  388. data/lib/rubocop/cop/naming/constant_name.rb +5 -6
  389. data/lib/rubocop/cop/naming/file_name.rb +5 -5
  390. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +2 -2
  391. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +4 -2
  392. data/lib/rubocop/cop/naming/inclusive_language.rb +32 -10
  393. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +27 -12
  394. data/lib/rubocop/cop/naming/method_name.rb +9 -9
  395. data/lib/rubocop/cop/naming/method_parameter_name.rb +2 -2
  396. data/lib/rubocop/cop/naming/predicate_name.rb +31 -2
  397. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +13 -5
  398. data/lib/rubocop/cop/naming/variable_name.rb +15 -1
  399. data/lib/rubocop/cop/naming/variable_number.rb +28 -18
  400. data/lib/rubocop/cop/offense.rb +1 -1
  401. data/lib/rubocop/cop/registry.rb +74 -46
  402. data/lib/rubocop/cop/security/compound_hash.rb +106 -0
  403. data/lib/rubocop/cop/security/eval.rb +1 -1
  404. data/lib/rubocop/cop/security/json_load.rb +1 -1
  405. data/lib/rubocop/cop/security/marshal_load.rb +1 -1
  406. data/lib/rubocop/cop/security/open.rb +3 -3
  407. data/lib/rubocop/cop/security/yaml_load.rb +11 -5
  408. data/lib/rubocop/cop/style/access_modifier_declarations.rb +142 -3
  409. data/lib/rubocop/cop/style/accessor_grouping.rb +53 -23
  410. data/lib/rubocop/cop/style/alias.rb +23 -13
  411. data/lib/rubocop/cop/style/and_or.rb +12 -12
  412. data/lib/rubocop/cop/style/arguments_forwarding.rb +414 -62
  413. data/lib/rubocop/cop/style/array_coercion.rb +1 -1
  414. data/lib/rubocop/cop/style/array_first_last.rb +64 -0
  415. data/lib/rubocop/cop/style/array_intersect.rb +119 -0
  416. data/lib/rubocop/cop/style/array_join.rb +1 -1
  417. data/lib/rubocop/cop/style/ascii_comments.rb +2 -2
  418. data/lib/rubocop/cop/style/attr.rb +12 -2
  419. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +22 -15
  420. data/lib/rubocop/cop/style/bare_percent_literals.rb +1 -1
  421. data/lib/rubocop/cop/style/begin_block.rb +1 -2
  422. data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +1 -1
  423. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +4 -4
  424. data/lib/rubocop/cop/style/block_comments.rb +4 -4
  425. data/lib/rubocop/cop/style/block_delimiters.rb +57 -15
  426. data/lib/rubocop/cop/style/case_equality.rb +41 -11
  427. data/lib/rubocop/cop/style/case_like_if.rb +27 -10
  428. data/lib/rubocop/cop/style/character_literal.rb +2 -2
  429. data/lib/rubocop/cop/style/class_and_module_children.rb +10 -17
  430. data/lib/rubocop/cop/style/class_check.rb +2 -1
  431. data/lib/rubocop/cop/style/class_equality_comparison.rb +80 -13
  432. data/lib/rubocop/cop/style/class_methods.rb +1 -1
  433. data/lib/rubocop/cop/style/class_methods_definitions.rb +3 -2
  434. data/lib/rubocop/cop/style/class_vars.rb +4 -4
  435. data/lib/rubocop/cop/style/collection_compact.rb +48 -16
  436. data/lib/rubocop/cop/style/collection_methods.rb +5 -1
  437. data/lib/rubocop/cop/style/colon_method_call.rb +2 -2
  438. data/lib/rubocop/cop/style/colon_method_definition.rb +1 -1
  439. data/lib/rubocop/cop/style/combinable_loops.rb +39 -9
  440. data/lib/rubocop/cop/style/command_literal.rb +2 -2
  441. data/lib/rubocop/cop/style/comment_annotation.rb +2 -2
  442. data/lib/rubocop/cop/style/commented_keyword.rb +10 -7
  443. data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
  444. data/lib/rubocop/cop/style/concat_array_literals.rb +95 -0
  445. data/lib/rubocop/cop/style/conditional_assignment.rb +17 -21
  446. data/lib/rubocop/cop/style/constant_visibility.rb +1 -1
  447. data/lib/rubocop/cop/style/copyright.rb +37 -24
  448. data/lib/rubocop/cop/style/data_inheritance.rb +75 -0
  449. data/lib/rubocop/cop/style/date_time.rb +7 -6
  450. data/lib/rubocop/cop/style/def_with_parentheses.rb +17 -12
  451. data/lib/rubocop/cop/style/dir.rb +4 -1
  452. data/lib/rubocop/cop/style/dir_empty.rb +54 -0
  453. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +2 -2
  454. data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +3 -3
  455. data/lib/rubocop/cop/style/documentation.rb +47 -35
  456. data/lib/rubocop/cop/style/documentation_method.rb +31 -5
  457. data/lib/rubocop/cop/style/double_negation.rb +62 -3
  458. data/lib/rubocop/cop/style/each_for_simple_loop.rb +46 -11
  459. data/lib/rubocop/cop/style/each_with_object.rb +41 -10
  460. data/lib/rubocop/cop/style/empty_block_parameter.rb +3 -3
  461. data/lib/rubocop/cop/style/empty_case_condition.rb +9 -5
  462. data/lib/rubocop/cop/style/empty_else.rb +40 -3
  463. data/lib/rubocop/cop/style/empty_heredoc.rb +73 -0
  464. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +3 -3
  465. data/lib/rubocop/cop/style/empty_literal.rb +3 -3
  466. data/lib/rubocop/cop/style/empty_method.rb +18 -3
  467. data/lib/rubocop/cop/style/encoding.rb +2 -2
  468. data/lib/rubocop/cop/style/end_block.rb +1 -1
  469. data/lib/rubocop/cop/style/endless_method.rb +2 -2
  470. data/lib/rubocop/cop/style/env_home.rb +56 -0
  471. data/lib/rubocop/cop/style/eval_with_location.rb +15 -24
  472. data/lib/rubocop/cop/style/even_odd.rb +1 -1
  473. data/lib/rubocop/cop/style/exact_regexp_match.rb +70 -0
  474. data/lib/rubocop/cop/style/expand_path_arguments.rb +1 -1
  475. data/lib/rubocop/cop/style/explicit_block_argument.rb +9 -5
  476. data/lib/rubocop/cop/style/exponential_notation.rb +1 -1
  477. data/lib/rubocop/cop/style/fetch_env_var.rb +132 -0
  478. data/lib/rubocop/cop/style/file_empty.rb +71 -0
  479. data/lib/rubocop/cop/style/file_read.rb +3 -3
  480. data/lib/rubocop/cop/style/file_write.rb +13 -1
  481. data/lib/rubocop/cop/style/float_division.rb +1 -1
  482. data/lib/rubocop/cop/style/for.rb +10 -2
  483. data/lib/rubocop/cop/style/format_string.rb +34 -13
  484. data/lib/rubocop/cop/style/format_string_token.rb +73 -23
  485. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +10 -5
  486. data/lib/rubocop/cop/style/global_std_stream.rb +1 -1
  487. data/lib/rubocop/cop/style/global_vars.rb +1 -1
  488. data/lib/rubocop/cop/style/guard_clause.rb +187 -25
  489. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +2 -1
  490. data/lib/rubocop/cop/style/hash_conversion.rb +11 -1
  491. data/lib/rubocop/cop/style/hash_each_methods.rb +132 -23
  492. data/lib/rubocop/cop/style/hash_except.rb +102 -10
  493. data/lib/rubocop/cop/style/hash_like_case.rb +4 -10
  494. data/lib/rubocop/cop/style/hash_syntax.rb +66 -6
  495. data/lib/rubocop/cop/style/hash_transform_keys.rb +7 -2
  496. data/lib/rubocop/cop/style/hash_transform_values.rb +5 -2
  497. data/lib/rubocop/cop/style/identical_conditional_branches.rb +51 -7
  498. data/lib/rubocop/cop/style/if_inside_else.rb +6 -0
  499. data/lib/rubocop/cop/style/if_unless_modifier.rb +117 -20
  500. data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +37 -8
  501. data/lib/rubocop/cop/style/if_with_semicolon.rb +6 -6
  502. data/lib/rubocop/cop/style/implicit_runtime_error.rb +3 -3
  503. data/lib/rubocop/cop/style/in_pattern_then.rb +1 -1
  504. data/lib/rubocop/cop/style/infinite_loop.rb +2 -5
  505. data/lib/rubocop/cop/style/inline_comment.rb +1 -1
  506. data/lib/rubocop/cop/style/inverse_methods.rb +23 -18
  507. data/lib/rubocop/cop/style/invertible_unless_condition.rb +160 -0
  508. data/lib/rubocop/cop/style/ip_addresses.rb +1 -1
  509. data/lib/rubocop/cop/style/keyword_parameters_order.rb +2 -2
  510. data/lib/rubocop/cop/style/lambda.rb +4 -4
  511. data/lib/rubocop/cop/style/lambda_call.rb +18 -21
  512. data/lib/rubocop/cop/style/line_end_concatenation.rb +6 -3
  513. data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
  514. data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +134 -0
  515. data/lib/rubocop/cop/style/map_into_array.rb +175 -0
  516. data/lib/rubocop/cop/style/map_to_hash.rb +23 -10
  517. data/lib/rubocop/cop/style/map_to_set.rb +64 -0
  518. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +68 -30
  519. data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +6 -2
  520. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +54 -49
  521. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +42 -3
  522. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +5 -2
  523. data/lib/rubocop/cop/style/method_def_parentheses.rb +13 -6
  524. data/lib/rubocop/cop/style/min_max.rb +4 -4
  525. data/lib/rubocop/cop/style/min_max_comparison.rb +83 -0
  526. data/lib/rubocop/cop/style/missing_else.rb +37 -25
  527. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +3 -3
  528. data/lib/rubocop/cop/style/mixin_grouping.rb +7 -7
  529. data/lib/rubocop/cop/style/mixin_usage.rb +1 -1
  530. data/lib/rubocop/cop/style/module_function.rb +30 -8
  531. data/lib/rubocop/cop/style/multiline_block_chain.rb +5 -3
  532. data/lib/rubocop/cop/style/multiline_if_modifier.rb +2 -6
  533. data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
  534. data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +3 -5
  535. data/lib/rubocop/cop/style/multiline_memoization.rb +3 -3
  536. data/lib/rubocop/cop/style/multiline_method_signature.rb +19 -7
  537. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +54 -11
  538. data/lib/rubocop/cop/style/multiline_when_then.rb +2 -4
  539. data/lib/rubocop/cop/style/multiple_comparison.rb +15 -1
  540. data/lib/rubocop/cop/style/mutable_constant.rb +1 -1
  541. data/lib/rubocop/cop/style/negated_if_else_condition.rb +18 -11
  542. data/lib/rubocop/cop/style/nested_file_dirname.rb +66 -0
  543. data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
  544. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +11 -2
  545. data/lib/rubocop/cop/style/nested_ternary_operator.rb +19 -15
  546. data/lib/rubocop/cop/style/next.rb +5 -7
  547. data/lib/rubocop/cop/style/nil_comparison.rb +3 -1
  548. data/lib/rubocop/cop/style/nil_lambda.rb +5 -5
  549. data/lib/rubocop/cop/style/non_nil_check.rb +1 -1
  550. data/lib/rubocop/cop/style/not.rb +2 -2
  551. data/lib/rubocop/cop/style/numbered_parameters.rb +1 -1
  552. data/lib/rubocop/cop/style/numbered_parameters_limit.rb +12 -4
  553. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +2 -2
  554. data/lib/rubocop/cop/style/numeric_literals.rb +16 -1
  555. data/lib/rubocop/cop/style/numeric_predicate.rb +63 -13
  556. data/lib/rubocop/cop/style/object_then.rb +76 -0
  557. data/lib/rubocop/cop/style/one_line_conditional.rb +5 -8
  558. data/lib/rubocop/cop/style/open_struct_use.rb +2 -2
  559. data/lib/rubocop/cop/style/operator_method_call.rb +73 -0
  560. data/lib/rubocop/cop/style/option_hash.rb +1 -1
  561. data/lib/rubocop/cop/style/optional_arguments.rb +2 -2
  562. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +5 -4
  563. data/lib/rubocop/cop/style/or_assignment.rb +1 -1
  564. data/lib/rubocop/cop/style/parallel_assignment.rb +32 -24
  565. data/lib/rubocop/cop/style/parentheses_around_condition.rb +9 -1
  566. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +3 -4
  567. data/lib/rubocop/cop/style/percent_q_literals.rb +2 -2
  568. data/lib/rubocop/cop/style/perl_backrefs.rb +23 -2
  569. data/lib/rubocop/cop/style/preferred_hash_methods.rb +2 -2
  570. data/lib/rubocop/cop/style/proc.rb +5 -2
  571. data/lib/rubocop/cop/style/quoted_symbols.rb +2 -2
  572. data/lib/rubocop/cop/style/raise_args.rb +14 -5
  573. data/lib/rubocop/cop/style/random_with_offset.rb +1 -1
  574. data/lib/rubocop/cop/style/redundant_argument.rb +38 -6
  575. data/lib/rubocop/cop/style/redundant_array_constructor.rb +77 -0
  576. data/lib/rubocop/cop/style/redundant_assignment.rb +11 -3
  577. data/lib/rubocop/cop/style/redundant_begin.rb +32 -14
  578. data/lib/rubocop/cop/style/redundant_capital_w.rb +2 -3
  579. data/lib/rubocop/cop/style/redundant_condition.rb +148 -14
  580. data/lib/rubocop/cop/style/redundant_conditional.rb +3 -15
  581. data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
  582. data/lib/rubocop/cop/style/redundant_current_directory_in_path.rb +39 -0
  583. data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +133 -0
  584. data/lib/rubocop/cop/style/redundant_each.rb +119 -0
  585. data/lib/rubocop/cop/style/redundant_exception.rb +33 -13
  586. data/lib/rubocop/cop/style/redundant_fetch_block.rb +10 -8
  587. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +1 -1
  588. data/lib/rubocop/cop/style/redundant_filter_chain.rb +118 -0
  589. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  590. data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
  591. data/lib/rubocop/cop/style/redundant_initialize.rb +156 -0
  592. data/lib/rubocop/cop/style/redundant_interpolation.rb +24 -3
  593. data/lib/rubocop/cop/style/redundant_line_continuation.rb +200 -0
  594. data/lib/rubocop/cop/style/redundant_parentheses.rb +92 -45
  595. data/lib/rubocop/cop/style/redundant_percent_q.rb +3 -3
  596. data/lib/rubocop/cop/style/redundant_regexp_argument.rb +100 -0
  597. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +15 -4
  598. data/lib/rubocop/cop/style/redundant_regexp_constructor.rb +46 -0
  599. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +24 -6
  600. data/lib/rubocop/cop/style/redundant_return.rb +22 -4
  601. data/lib/rubocop/cop/style/redundant_self.rb +20 -3
  602. data/lib/rubocop/cop/style/redundant_self_assignment.rb +3 -4
  603. data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +9 -2
  604. data/lib/rubocop/cop/style/redundant_sort.rb +34 -18
  605. data/lib/rubocop/cop/style/redundant_sort_by.rb +25 -9
  606. data/lib/rubocop/cop/style/redundant_string_escape.rb +185 -0
  607. data/lib/rubocop/cop/style/regexp_literal.rb +11 -2
  608. data/lib/rubocop/cop/style/require_order.rb +139 -0
  609. data/lib/rubocop/cop/style/rescue_modifier.rb +2 -4
  610. data/lib/rubocop/cop/style/rescue_standard_error.rb +15 -15
  611. data/lib/rubocop/cop/style/return_nil.rb +6 -2
  612. data/lib/rubocop/cop/style/return_nil_in_predicate_method_definition.rb +95 -0
  613. data/lib/rubocop/cop/style/safe_navigation.rb +58 -19
  614. data/lib/rubocop/cop/style/sample.rb +9 -8
  615. data/lib/rubocop/cop/style/select_by_regexp.rb +37 -13
  616. data/lib/rubocop/cop/style/self_assignment.rb +4 -4
  617. data/lib/rubocop/cop/style/semicolon.rb +72 -9
  618. data/lib/rubocop/cop/style/send.rb +5 -5
  619. data/lib/rubocop/cop/style/send_with_literal_method_name.rb +90 -0
  620. data/lib/rubocop/cop/style/signal_exception.rb +10 -8
  621. data/lib/rubocop/cop/style/single_argument_dig.rb +11 -2
  622. data/lib/rubocop/cop/style/single_line_block_params.rb +2 -2
  623. data/lib/rubocop/cop/style/single_line_do_end_block.rb +67 -0
  624. data/lib/rubocop/cop/style/single_line_methods.rb +3 -3
  625. data/lib/rubocop/cop/style/slicing_with_range.rb +77 -11
  626. data/lib/rubocop/cop/style/sole_nested_conditional.rb +103 -33
  627. data/lib/rubocop/cop/style/special_global_vars.rb +66 -10
  628. data/lib/rubocop/cop/style/static_class.rb +33 -2
  629. data/lib/rubocop/cop/style/stderr_puts.rb +2 -2
  630. data/lib/rubocop/cop/style/string_chars.rb +2 -1
  631. data/lib/rubocop/cop/style/string_concatenation.rb +13 -8
  632. data/lib/rubocop/cop/style/string_hash_keys.rb +5 -2
  633. data/lib/rubocop/cop/style/string_literals.rb +1 -5
  634. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +30 -5
  635. data/lib/rubocop/cop/style/string_methods.rb +1 -1
  636. data/lib/rubocop/cop/style/strip.rb +8 -5
  637. data/lib/rubocop/cop/style/struct_inheritance.rb +5 -5
  638. data/lib/rubocop/cop/style/super_arguments.rb +156 -0
  639. data/lib/rubocop/cop/style/super_with_args_parentheses.rb +35 -0
  640. data/lib/rubocop/cop/style/swap_values.rb +4 -2
  641. data/lib/rubocop/cop/style/symbol_array.rb +46 -21
  642. data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
  643. data/lib/rubocop/cop/style/symbol_proc.rb +135 -16
  644. data/lib/rubocop/cop/style/ternary_parentheses.rb +19 -18
  645. data/lib/rubocop/cop/style/top_level_method_definition.rb +3 -1
  646. data/lib/rubocop/cop/style/trailing_body_on_class.rb +2 -1
  647. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +1 -1
  648. data/lib/rubocop/cop/style/trailing_body_on_module.rb +1 -1
  649. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +5 -5
  650. data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +2 -2
  651. data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +2 -2
  652. data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +2 -2
  653. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +2 -5
  654. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +2 -2
  655. data/lib/rubocop/cop/style/trivial_accessors.rb +12 -10
  656. data/lib/rubocop/cop/style/unless_else.rb +5 -1
  657. data/lib/rubocop/cop/style/unless_logical_operators.rb +2 -1
  658. data/lib/rubocop/cop/style/unpack_first.rb +15 -15
  659. data/lib/rubocop/cop/style/variable_interpolation.rb +1 -1
  660. data/lib/rubocop/cop/style/when_then.rb +1 -1
  661. data/lib/rubocop/cop/style/word_array.rb +60 -6
  662. data/lib/rubocop/cop/style/yaml_file_read.rb +66 -0
  663. data/lib/rubocop/cop/style/yoda_condition.rb +18 -9
  664. data/lib/rubocop/cop/style/yoda_expression.rb +91 -0
  665. data/lib/rubocop/cop/style/zero_length_predicate.rb +41 -20
  666. data/lib/rubocop/cop/team.rb +70 -58
  667. data/lib/rubocop/cop/util.rb +45 -9
  668. data/lib/rubocop/cop/utils/regexp_ranges.rb +113 -0
  669. data/lib/rubocop/cop/variable_force/assignment.rb +45 -4
  670. data/lib/rubocop/cop/variable_force/branch.rb +1 -1
  671. data/lib/rubocop/cop/variable_force/scope.rb +3 -3
  672. data/lib/rubocop/cop/variable_force/variable.rb +5 -3
  673. data/lib/rubocop/cop/variable_force/variable_table.rb +6 -4
  674. data/lib/rubocop/cop/variable_force.rb +20 -35
  675. data/lib/rubocop/cops_documentation_generator.rb +81 -22
  676. data/lib/rubocop/directive_comment.rb +14 -12
  677. data/lib/rubocop/ext/comment.rb +18 -0
  678. data/lib/rubocop/ext/processed_source.rb +2 -0
  679. data/lib/rubocop/ext/range.rb +15 -0
  680. data/lib/rubocop/ext/regexp_node.rb +10 -5
  681. data/lib/rubocop/ext/regexp_parser.rb +5 -2
  682. data/lib/rubocop/feature_loader.rb +94 -0
  683. data/lib/rubocop/file_finder.rb +4 -7
  684. data/lib/rubocop/file_patterns.rb +43 -0
  685. data/lib/rubocop/formatter/clang_style_formatter.rb +4 -8
  686. data/lib/rubocop/formatter/disabled_config_formatter.rb +66 -17
  687. data/lib/rubocop/formatter/formatter_set.rb +27 -19
  688. data/lib/rubocop/formatter/{git_hub_actions_formatter.rb → github_actions_formatter.rb} +15 -2
  689. data/lib/rubocop/formatter/html_formatter.rb +39 -26
  690. data/lib/rubocop/formatter/json_formatter.rb +0 -1
  691. data/lib/rubocop/formatter/junit_formatter.rb +4 -1
  692. data/lib/rubocop/formatter/markdown_formatter.rb +78 -0
  693. data/lib/rubocop/formatter/offense_count_formatter.rb +25 -6
  694. data/lib/rubocop/formatter/simple_text_formatter.rb +9 -8
  695. data/lib/rubocop/formatter/tap_formatter.rb +4 -8
  696. data/lib/rubocop/formatter/worst_offenders_formatter.rb +6 -4
  697. data/lib/rubocop/formatter.rb +34 -0
  698. data/lib/rubocop/lockfile.rb +56 -7
  699. data/lib/rubocop/lsp/logger.rb +22 -0
  700. data/lib/rubocop/lsp/routes.rb +243 -0
  701. data/lib/rubocop/lsp/runtime.rb +99 -0
  702. data/lib/rubocop/lsp/server.rb +73 -0
  703. data/lib/rubocop/lsp/severity.rb +27 -0
  704. data/lib/rubocop/lsp.rb +36 -0
  705. data/lib/rubocop/magic_comment.rb +43 -15
  706. data/lib/rubocop/options.rb +183 -59
  707. data/lib/rubocop/path_util.rb +54 -22
  708. data/lib/rubocop/rake_task.rb +35 -10
  709. data/lib/rubocop/result_cache.rb +31 -17
  710. data/lib/rubocop/rspec/cop_helper.rb +33 -4
  711. data/lib/rubocop/rspec/expect_offense.rb +21 -11
  712. data/lib/rubocop/rspec/parallel_formatter.rb +1 -1
  713. data/lib/rubocop/rspec/shared_contexts.rb +100 -23
  714. data/lib/rubocop/rspec/support.rb +19 -2
  715. data/lib/rubocop/runner.rb +125 -31
  716. data/lib/rubocop/server/cache.rb +155 -0
  717. data/lib/rubocop/server/cli.rb +147 -0
  718. data/lib/rubocop/server/client_command/base.rb +44 -0
  719. data/lib/rubocop/server/client_command/exec.rb +64 -0
  720. data/lib/rubocop/server/client_command/restart.rb +25 -0
  721. data/lib/rubocop/server/client_command/start.rb +48 -0
  722. data/lib/rubocop/server/client_command/status.rb +28 -0
  723. data/lib/rubocop/server/client_command/stop.rb +31 -0
  724. data/lib/rubocop/server/client_command.rb +26 -0
  725. data/lib/rubocop/server/core.rb +111 -0
  726. data/lib/rubocop/server/errors.rb +23 -0
  727. data/lib/rubocop/server/helper.rb +34 -0
  728. data/lib/rubocop/server/server_command/base.rb +50 -0
  729. data/lib/rubocop/server/server_command/exec.rb +33 -0
  730. data/lib/rubocop/server/server_command/stop.rb +24 -0
  731. data/lib/rubocop/server/server_command.rb +21 -0
  732. data/lib/rubocop/server/socket_reader.rb +69 -0
  733. data/lib/rubocop/server.rb +53 -0
  734. data/lib/rubocop/string_interpreter.rb +7 -7
  735. data/lib/rubocop/target_finder.rb +92 -82
  736. data/lib/rubocop/target_ruby.rb +92 -78
  737. data/lib/rubocop/version.rb +44 -12
  738. data/lib/rubocop.rb +83 -35
  739. metadata +170 -45
  740. data/lib/rubocop/cop/gemspec/date_assignment.rb +0 -49
  741. data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -52
  742. data/lib/rubocop/cop/mixin/ignored_pattern.rb +0 -29
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Style
6
- # This cop checks for redundant `begin` blocks.
6
+ # Checks for redundant `begin` blocks.
7
7
  #
8
8
  # Currently it checks for code like this:
9
9
  #
@@ -36,6 +36,7 @@ module RuboCop
36
36
  # do_something
37
37
  #
38
38
  # # bad
39
+ # # When using Ruby 2.5 or later.
39
40
  # do_something do
40
41
  # begin
41
42
  # something
@@ -67,14 +68,21 @@ module RuboCop
67
68
 
68
69
  MSG = 'Redundant `begin` block detected.'
69
70
 
71
+ # @!method offensive_kwbegins(node)
72
+ def_node_search :offensive_kwbegins, <<~PATTERN
73
+ [(kwbegin ...) !#allowable_kwbegin?]
74
+ PATTERN
75
+
70
76
  def on_def(node)
71
77
  return unless node.body&.kwbegin_type?
78
+ return if node.endless? && !node.body.children.one?
72
79
 
73
80
  register_offense(node.body)
74
81
  end
75
82
  alias on_defs on_def
76
83
 
77
84
  def on_block(node)
85
+ return if target_ruby_version < 2.5
78
86
  return if node.send_node.lambda_literal?
79
87
  return if node.braces?
80
88
  return unless node.body&.kwbegin_type?
@@ -82,25 +90,31 @@ module RuboCop
82
90
  register_offense(node.body)
83
91
  end
84
92
 
93
+ alias on_numblock on_block
94
+
85
95
  def on_kwbegin(node)
86
- return if empty_begin?(node) ||
87
- begin_block_has_multiline_statements?(node) ||
88
- contain_rescue_or_ensure?(node) ||
89
- valid_context_using_only_begin?(node)
96
+ return unless (target_node = offensive_kwbegins(node).to_a.last)
90
97
 
91
- register_offense(node)
98
+ register_offense(target_node)
92
99
  end
93
100
 
94
101
  private
95
102
 
103
+ def allowable_kwbegin?(node)
104
+ empty_begin?(node) ||
105
+ begin_block_has_multiline_statements?(node) ||
106
+ contain_rescue_or_ensure?(node) ||
107
+ valid_context_using_only_begin?(node)
108
+ end
109
+
96
110
  def register_offense(node)
97
111
  offense_range = node.loc.begin
98
112
 
99
113
  add_offense(offense_range) do |corrector|
100
- if any_ancestor_assignment_node?(node)
114
+ if node.parent&.assignment?
101
115
  replace_begin_with_statement(corrector, offense_range, node)
102
116
  else
103
- corrector.remove(offense_range)
117
+ remove_begin(corrector, offense_range, node)
104
118
  end
105
119
 
106
120
  if use_modifier_form_after_multiline_begin_block?(node)
@@ -122,6 +136,14 @@ module RuboCop
122
136
  restore_removed_comments(corrector, offense_range, node, first_child)
123
137
  end
124
138
 
139
+ def remove_begin(corrector, offense_range, node)
140
+ if node.parent.respond_to?(:endless?) && node.parent.endless?
141
+ offense_range = range_with_surrounding_space(offense_range, newlines: true)
142
+ end
143
+
144
+ corrector.remove(offense_range)
145
+ end
146
+
125
147
  # Restore comments that occur between "begin" and "first_child".
126
148
  # These comments will be moved to above the assignment line.
127
149
  def restore_removed_comments(corrector, offense_range, node, first_child)
@@ -132,7 +154,7 @@ module RuboCop
132
154
  end
133
155
 
134
156
  def use_modifier_form_after_multiline_begin_block?(node)
135
- return unless (parent = node.parent)
157
+ return false unless (parent = node.parent)
136
158
 
137
159
  node.multiline? && parent.if_type? && parent.modifier_form?
138
160
  end
@@ -170,11 +192,7 @@ module RuboCop
170
192
  end
171
193
 
172
194
  def valid_begin_assignment?(node)
173
- any_ancestor_assignment_node?(node) && !node.children.one?
174
- end
175
-
176
- def any_ancestor_assignment_node?(node)
177
- node.each_ancestor.any?(&:assignment?)
195
+ node.parent&.assignment? && !node.children.one?
178
196
  end
179
197
  end
180
198
  end
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Style
6
- # This cop checks for usage of the %W() syntax when %w() would do.
6
+ # Checks for usage of the %W() syntax when %w() would do.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -37,8 +37,7 @@ module RuboCop
37
37
 
38
38
  def requires_interpolation?(node)
39
39
  node.child_nodes.any? do |string|
40
- string.dstr_type? ||
41
- double_quotes_required?(string.source)
40
+ string.dstr_type? || double_quotes_required?(string.source)
42
41
  end
43
42
  end
44
43
  end
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Style
6
- # This cop checks for unnecessary conditional expressions.
6
+ # Checks for unnecessary conditional expressions.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -36,6 +36,9 @@ module RuboCop
36
36
 
37
37
  MSG = 'Use double pipes `||` instead.'
38
38
  REDUNDANT_CONDITION = 'This condition is not needed.'
39
+ ARGUMENT_WITH_OPERATOR_TYPES = %i[
40
+ splat block_pass forwarded_restarg forwarded_kwrestarg forwarded_args
41
+ ].freeze
39
42
 
40
43
  def on_if(node)
41
44
  return if node.elsif_conditional?
@@ -44,9 +47,9 @@ module RuboCop
44
47
  message = message(node)
45
48
 
46
49
  add_offense(range_of_offense(node), message: message) do |corrector|
47
- if node.ternary?
50
+ if node.ternary? && !branches_have_method?(node)
48
51
  correct_ternary(corrector, node)
49
- elsif node.modifier_form? || !node.else_branch
52
+ elsif redundant_condition?(node)
50
53
  corrector.replace(node, node.if_branch.source)
51
54
  else
52
55
  corrected = make_ternary_form(node)
@@ -59,7 +62,7 @@ module RuboCop
59
62
  private
60
63
 
61
64
  def message(node)
62
- if node.modifier_form? || !node.else_branch
65
+ if redundant_condition?(node)
63
66
  REDUNDANT_CONDITION
64
67
  else
65
68
  MSG
@@ -67,19 +70,23 @@ module RuboCop
67
70
  end
68
71
 
69
72
  def range_of_offense(node)
70
- return node.loc.expression unless node.ternary?
73
+ return node.source_range unless node.ternary?
74
+ return node.source_range if node.ternary? && branches_have_method?(node)
71
75
 
72
76
  range_between(node.loc.question.begin_pos, node.loc.colon.end_pos)
73
77
  end
74
78
 
75
79
  def offense?(node)
76
- condition, if_branch, else_branch = *node
80
+ _condition, _if_branch, else_branch = *node
77
81
 
78
82
  return false if use_if_branch?(else_branch) || use_hash_key_assignment?(else_branch)
79
83
 
80
- condition == if_branch && !node.elsif? && (
81
- node.ternary? || !else_branch.instance_of?(AST::Node) || else_branch.single_line?
82
- )
84
+ synonymous_condition_and_branch?(node) && !node.elsif? &&
85
+ (node.ternary? || !else_branch.instance_of?(AST::Node) || else_branch.single_line?)
86
+ end
87
+
88
+ def redundant_condition?(node)
89
+ node.modifier_form? || !node.else_branch
83
90
  end
84
91
 
85
92
  def use_if_branch?(else_branch)
@@ -90,19 +97,138 @@ module RuboCop
90
97
  else_branch&.send_type? && else_branch&.method?(:[]=)
91
98
  end
92
99
 
93
- def else_source(else_branch)
94
- if require_parentheses?(else_branch)
100
+ def use_hash_key_access?(node)
101
+ node.send_type? && node.method?(:[])
102
+ end
103
+
104
+ def synonymous_condition_and_branch?(node)
105
+ condition, if_branch, _else_branch = *node
106
+ # e.g.
107
+ # if var
108
+ # var
109
+ # else
110
+ # 'foo'
111
+ # end
112
+ return true if condition == if_branch
113
+
114
+ # e.g.
115
+ # if foo
116
+ # @value = foo
117
+ # else
118
+ # @value = another_value?
119
+ # end
120
+ return true if branches_have_assignment?(node) && condition == if_branch.expression
121
+
122
+ # e.g.
123
+ # if foo
124
+ # test.value = foo
125
+ # else
126
+ # test.value = another_value?
127
+ # end
128
+ branches_have_method?(node) && condition == if_branch.first_argument &&
129
+ !use_hash_key_access?(if_branch)
130
+ end
131
+
132
+ def branches_have_assignment?(node)
133
+ _condition, if_branch, else_branch = *node
134
+
135
+ return false unless if_branch && else_branch
136
+
137
+ asgn_type?(if_branch) && (if_branch_variable_name = if_branch.name) &&
138
+ asgn_type?(else_branch) && (else_branch_variable_name = else_branch.name) &&
139
+ if_branch_variable_name == else_branch_variable_name
140
+ end
141
+
142
+ def asgn_type?(node)
143
+ node.lvasgn_type? || node.ivasgn_type? || node.cvasgn_type? || node.gvasgn_type?
144
+ end
145
+
146
+ def branches_have_method?(node)
147
+ _condition, if_branch, else_branch = *node
148
+
149
+ return false unless if_branch && else_branch
150
+
151
+ single_argument_method?(if_branch) && single_argument_method?(else_branch) &&
152
+ same_method?(if_branch, else_branch)
153
+ end
154
+
155
+ def single_argument_method?(node)
156
+ return false if !node.send_type? || node.method?(:[]) || !node.arguments.one?
157
+
158
+ !argument_with_operator?(node.first_argument)
159
+ end
160
+
161
+ def same_method?(if_branch, else_branch)
162
+ if_branch.method?(else_branch.method_name) && if_branch.receiver == else_branch.receiver
163
+ end
164
+
165
+ # If the argument is using an operator, it is an invalid syntax.
166
+ # e.g. `foo || *bar`, `foo || **bar`, and `foo || &bar`.
167
+ def argument_with_operator?(argument)
168
+ return true if ARGUMENT_WITH_OPERATOR_TYPES.include?(argument.type)
169
+ return false unless argument.hash_type?
170
+ return false unless (node = argument.children.first)
171
+
172
+ node.kwsplat_type? || node.forwarded_kwrestarg_type?
173
+ end
174
+
175
+ def if_source(if_branch, arithmetic_operation)
176
+ if branches_have_method?(if_branch.parent) && if_branch.parenthesized?
177
+ if_branch.source.delete_suffix(')')
178
+ elsif arithmetic_operation
179
+ argument_source = if_branch.first_argument.source
180
+
181
+ "#{if_branch.receiver.source} #{if_branch.method_name} (#{argument_source}"
182
+ else
183
+ if_branch.source
184
+ end
185
+ end
186
+
187
+ def else_source(else_branch, arithmetic_operation) # rubocop:disable Metrics/AbcSize
188
+ if arithmetic_operation
189
+ "#{else_branch.first_argument.source})"
190
+ elsif branches_have_method?(else_branch.parent)
191
+ else_source_if_has_method(else_branch)
192
+ elsif require_parentheses?(else_branch)
95
193
  "(#{else_branch.source})"
96
194
  elsif without_argument_parentheses_method?(else_branch)
97
195
  "#{else_branch.method_name}(#{else_branch.arguments.map(&:source).join(', ')})"
196
+ elsif branches_have_assignment?(else_branch.parent)
197
+ else_source_if_has_assignment(else_branch)
98
198
  else
99
199
  else_branch.source
100
200
  end
101
201
  end
102
202
 
203
+ def else_source_if_has_method(else_branch)
204
+ if require_parentheses?(else_branch.first_argument)
205
+ "(#{else_branch.first_argument.source})"
206
+ elsif require_braces?(else_branch.first_argument)
207
+ "{ #{else_branch.first_argument.source} }"
208
+ else
209
+ else_branch.first_argument.source
210
+ end
211
+ end
212
+
213
+ def else_source_if_has_assignment(else_branch)
214
+ if require_parentheses?(else_branch.expression)
215
+ "(#{else_branch.expression.source})"
216
+ elsif require_braces?(else_branch.expression)
217
+ "{ #{else_branch.expression.source} }"
218
+ else
219
+ else_branch.expression.source
220
+ end
221
+ end
222
+
103
223
  def make_ternary_form(node)
104
224
  _condition, if_branch, else_branch = *node
105
- ternary_form = [if_branch.source, else_source(else_branch)].join(' || ')
225
+ arithmetic_operation = use_arithmetic_operation?(if_branch)
226
+
227
+ ternary_form = [
228
+ if_source(if_branch, arithmetic_operation),
229
+ else_source(else_branch, arithmetic_operation)
230
+ ].join(' || ')
231
+ ternary_form += ')' if branches_have_method?(node) && if_branch.parenthesized?
106
232
 
107
233
  if node.parent&.send_type?
108
234
  "(#{ternary_form})"
@@ -126,9 +252,17 @@ module RuboCop
126
252
  (node.respond_to?(:semantic_operator?) && node.semantic_operator?)
127
253
  end
128
254
 
255
+ def require_braces?(node)
256
+ node.hash_type? && !node.braces?
257
+ end
258
+
259
+ def use_arithmetic_operation?(node)
260
+ node.respond_to?(:arithmetic_operation?) && node.arithmetic_operation?
261
+ end
262
+
129
263
  def without_argument_parentheses_method?(node)
130
- node.send_type? &&
131
- !node.arguments.empty? && !node.parenthesized? && !node.operator_method?
264
+ node.send_type? && !node.arguments.empty? &&
265
+ !node.parenthesized? && !node.operator_method? && !node.assignment_method?
132
266
  end
133
267
  end
134
268
  end
@@ -3,7 +3,7 @@
3
3
  module RuboCop
4
4
  module Cop
5
5
  module Style
6
- # This cop checks for redundant returning of true/false in conditionals.
6
+ # Checks for redundant returning of true/false in conditionals.
7
7
  #
8
8
  # @example
9
9
  # # bad
@@ -63,33 +63,21 @@ module RuboCop
63
63
  RUBY
64
64
 
65
65
  def offense?(node)
66
- return if node.modifier_form?
66
+ return false if node.modifier_form?
67
67
 
68
68
  redundant_condition?(node) || redundant_condition_inverted?(node)
69
69
  end
70
70
 
71
71
  def replacement_condition(node)
72
72
  condition = node.condition.source
73
- expression = invert_expression?(node) ? "!(#{condition})" : condition
73
+ expression = redundant_condition_inverted?(node) ? "!(#{condition})" : condition
74
74
 
75
75
  node.elsif? ? indented_else_node(expression, node) : expression
76
76
  end
77
77
 
78
- def invert_expression?(node)
79
- (
80
- (node.if? || node.elsif? || node.ternary?) && redundant_condition_inverted?(node)
81
- ) || (
82
- node.unless? && redundant_condition?(node)
83
- )
84
- end
85
-
86
78
  def indented_else_node(expression, node)
87
79
  "else\n#{indentation(node)}#{expression}"
88
80
  end
89
-
90
- def configured_indentation_width
91
- super || 2
92
- end
93
81
  end
94
82
  end
95
83
  end
@@ -0,0 +1,85 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # Avoid redundant `::` prefix on constant.
7
+ #
8
+ # How Ruby searches constant is a bit complicated, and it can often be difficult to
9
+ # understand from the code whether the `::` is intended or not. Where `Module.nesting`
10
+ # is empty, there is no need to prepend `::`, so it would be nice to consistently
11
+ # avoid such meaningless `::` prefix to avoid confusion.
12
+ #
13
+ # NOTE: This cop is disabled if `Lint/ConstantResolution` cop is enabled to prevent
14
+ # conflicting rules. Because it respects user configurations that want to enable
15
+ # `Lint/ConstantResolution` cop which is disabled by default.
16
+ #
17
+ # @example
18
+ # # bad
19
+ # ::Const
20
+ #
21
+ # # good
22
+ # Const
23
+ #
24
+ # # bad
25
+ # class << self
26
+ # ::Const
27
+ # end
28
+ #
29
+ # # good
30
+ # class << self
31
+ # Const
32
+ # end
33
+ #
34
+ # # good
35
+ # class A
36
+ # ::Const
37
+ # end
38
+ #
39
+ # # good
40
+ # module A
41
+ # ::Const
42
+ # end
43
+ class RedundantConstantBase < Base
44
+ extend AutoCorrector
45
+
46
+ MSG = 'Remove redundant `::`.'
47
+
48
+ def on_cbase(node)
49
+ return if lint_constant_resolution_cop_enabled?
50
+ return unless bad?(node)
51
+
52
+ add_offense(node) do |corrector|
53
+ corrector.remove(node)
54
+ end
55
+ end
56
+
57
+ private
58
+
59
+ def lint_constant_resolution_cop_enabled?
60
+ lint_constant_resolution_config.fetch('Enabled', false)
61
+ end
62
+
63
+ def lint_constant_resolution_config
64
+ config.for_cop('Lint/ConstantResolution')
65
+ end
66
+
67
+ def bad?(node)
68
+ module_nesting_ancestors_of(node).none?
69
+ end
70
+
71
+ def module_nesting_ancestors_of(node)
72
+ node.each_ancestor(:class, :module).reject do |ancestor|
73
+ ancestor.class_type? && used_in_super_class_part?(node, class_node: ancestor)
74
+ end
75
+ end
76
+
77
+ def used_in_super_class_part?(node, class_node:)
78
+ class_node.parent_class&.each_descendant(:cbase)&.any? do |descendant|
79
+ descendant.equal?(node)
80
+ end
81
+ end
82
+ end
83
+ end
84
+ end
85
+ end
@@ -0,0 +1,39 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # Checks for uses a redundant current directory in path.
7
+ #
8
+ # @example
9
+ #
10
+ # # bad
11
+ # require_relative './path/to/feature'
12
+ #
13
+ # # good
14
+ # require_relative 'path/to/feature'
15
+ #
16
+ class RedundantCurrentDirectoryInPath < Base
17
+ include RangeHelp
18
+ extend AutoCorrector
19
+
20
+ MSG = 'Remove the redundant current directory path.'
21
+ RESTRICT_ON_SEND = %i[require_relative].freeze
22
+ CURRENT_DIRECTORY_PATH = './'
23
+
24
+ def on_send(node)
25
+ return unless (first_argument = node.first_argument)
26
+ return unless first_argument.str_content&.start_with?(CURRENT_DIRECTORY_PATH)
27
+ return unless (index = first_argument.source.index(CURRENT_DIRECTORY_PATH))
28
+
29
+ begin_pos = first_argument.source_range.begin.begin_pos + index
30
+ range = range_between(begin_pos, begin_pos + 2)
31
+
32
+ add_offense(range) do |corrector|
33
+ corrector.remove(range)
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,133 @@
1
+ # frozen_string_literal: true
2
+
3
+ module RuboCop
4
+ module Cop
5
+ module Style
6
+ # Checks for redundant uses of double splat hash braces.
7
+ #
8
+ # @example
9
+ #
10
+ # # bad
11
+ # do_something(**{foo: bar, baz: qux})
12
+ #
13
+ # # good
14
+ # do_something(foo: bar, baz: qux)
15
+ #
16
+ # # bad
17
+ # do_something(**{foo: bar, baz: qux}.merge(options))
18
+ #
19
+ # # good
20
+ # do_something(foo: bar, baz: qux, **options)
21
+ #
22
+ class RedundantDoubleSplatHashBraces < Base
23
+ extend AutoCorrector
24
+
25
+ MSG = 'Remove the redundant double splat and braces, use keyword arguments directly.'
26
+ MERGE_METHODS = %i[merge merge!].freeze
27
+
28
+ # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
29
+ def on_hash(node)
30
+ return if node.pairs.empty? || node.pairs.any?(&:hash_rocket?)
31
+ return unless (parent = node.parent)
32
+ return unless parent.call_type? || parent.kwsplat_type?
33
+ return unless mergeable?(parent)
34
+ return unless (kwsplat = node.each_ancestor(:kwsplat).first)
35
+ return if !node.braces? || allowed_double_splat_receiver?(kwsplat)
36
+
37
+ add_offense(kwsplat) do |corrector|
38
+ autocorrect(corrector, node, kwsplat)
39
+ end
40
+ end
41
+ # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
42
+
43
+ private
44
+
45
+ def allowed_double_splat_receiver?(kwsplat)
46
+ first_child = kwsplat.children.first
47
+ return true if first_child.block_type? || first_child.numblock_type?
48
+ return false unless first_child.call_type?
49
+
50
+ root_receiver = root_receiver(first_child)
51
+
52
+ !root_receiver&.hash_type?
53
+ end
54
+
55
+ def autocorrect(corrector, node, kwsplat)
56
+ corrector.remove(kwsplat.loc.operator)
57
+ corrector.remove(opening_brace(node))
58
+ corrector.remove(closing_brace(node))
59
+
60
+ merge_methods = select_merge_method_nodes(kwsplat)
61
+ return if merge_methods.empty?
62
+
63
+ autocorrect_merge_methods(corrector, merge_methods, kwsplat)
64
+ end
65
+
66
+ def root_receiver(node)
67
+ receiver = node.receiver
68
+ if receiver&.receiver
69
+ root_receiver(receiver)
70
+ else
71
+ receiver
72
+ end
73
+ end
74
+
75
+ def select_merge_method_nodes(kwsplat)
76
+ extract_send_methods(kwsplat).select do |node|
77
+ mergeable?(node)
78
+ end
79
+ end
80
+
81
+ def opening_brace(node)
82
+ node.loc.begin.join(node.children.first.source_range.begin)
83
+ end
84
+
85
+ def closing_brace(node)
86
+ node.children.last.source_range.end.join(node.loc.end)
87
+ end
88
+
89
+ def autocorrect_merge_methods(corrector, merge_methods, kwsplat)
90
+ range = range_of_merge_methods(merge_methods)
91
+
92
+ new_kwsplat_arguments = extract_send_methods(kwsplat).map do |descendant|
93
+ convert_to_new_arguments(descendant)
94
+ end
95
+ new_source = new_kwsplat_arguments.compact.reverse.unshift('').join(', ')
96
+
97
+ corrector.replace(range, new_source)
98
+ end
99
+
100
+ def range_of_merge_methods(merge_methods)
101
+ begin_merge_method = merge_methods.last
102
+ end_merge_method = merge_methods.first
103
+
104
+ begin_merge_method.loc.dot.begin.join(end_merge_method.source_range.end)
105
+ end
106
+
107
+ def extract_send_methods(kwsplat)
108
+ kwsplat.each_descendant(:send, :csend)
109
+ end
110
+
111
+ def convert_to_new_arguments(node)
112
+ return unless mergeable?(node)
113
+
114
+ node.arguments.map do |arg|
115
+ if arg.hash_type?
116
+ arg.source
117
+ else
118
+ "**#{arg.source}"
119
+ end
120
+ end
121
+ end
122
+
123
+ def mergeable?(node)
124
+ return true unless node.call_type?
125
+ return false unless MERGE_METHODS.include?(node.method_name)
126
+ return true unless (parent = node.parent)
127
+
128
+ mergeable?(parent)
129
+ end
130
+ end
131
+ end
132
+ end
133
+ end