rubocop 0.85.1 → 0.89.0

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 (357) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +16 -4
  3. data/bin/rubocop-profile +32 -0
  4. data/config/default.yml +227 -26
  5. data/lib/rubocop.rb +33 -5
  6. data/lib/rubocop/cli.rb +2 -4
  7. data/lib/rubocop/cli/command/auto_genenerate_config.rb +42 -7
  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/init_dotfile.rb +1 -1
  11. data/lib/rubocop/cli/command/show_cops.rb +2 -2
  12. data/lib/rubocop/cli/command/version.rb +2 -2
  13. data/lib/rubocop/comment_config.rb +2 -2
  14. data/lib/rubocop/config.rb +20 -3
  15. data/lib/rubocop/config_loader.rb +40 -68
  16. data/lib/rubocop/config_loader_resolver.rb +4 -4
  17. data/lib/rubocop/config_obsoletion.rb +6 -2
  18. data/lib/rubocop/config_store.rb +4 -0
  19. data/lib/rubocop/config_validator.rb +1 -3
  20. data/lib/rubocop/cop/autocorrect_logic.rb +14 -24
  21. data/lib/rubocop/cop/badge.rb +1 -1
  22. data/lib/rubocop/cop/base.rb +407 -0
  23. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +10 -20
  24. data/lib/rubocop/cop/commissioner.rb +47 -50
  25. data/lib/rubocop/cop/cop.rb +85 -236
  26. data/lib/rubocop/cop/corrector.rb +38 -115
  27. data/lib/rubocop/cop/correctors/line_break_corrector.rb +3 -3
  28. data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -0
  29. data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +1 -1
  30. data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
  31. data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +15 -18
  32. data/lib/rubocop/cop/force.rb +1 -0
  33. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +39 -13
  34. data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +1 -1
  35. data/lib/rubocop/cop/generator.rb +1 -1
  36. data/lib/rubocop/cop/generator/configuration_injector.rb +3 -3
  37. data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +4 -12
  38. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +1 -1
  39. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +11 -14
  40. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +8 -8
  41. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +10 -7
  42. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +7 -8
  43. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +2 -2
  44. data/lib/rubocop/cop/layout/block_alignment.rb +1 -1
  45. data/lib/rubocop/cop/layout/case_indentation.rb +18 -19
  46. data/lib/rubocop/cop/layout/class_structure.rb +2 -37
  47. data/lib/rubocop/cop/layout/comment_indentation.rb +3 -3
  48. data/lib/rubocop/cop/layout/empty_comment.rb +1 -1
  49. data/lib/rubocop/cop/layout/empty_lines.rb +0 -2
  50. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +1 -0
  51. data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +3 -8
  52. data/lib/rubocop/cop/layout/end_alignment.rb +3 -2
  53. data/lib/rubocop/cop/layout/end_of_line.rb +1 -1
  54. data/lib/rubocop/cop/layout/extra_spacing.rb +9 -16
  55. data/lib/rubocop/cop/layout/first_argument_indentation.rb +5 -1
  56. data/lib/rubocop/cop/layout/first_array_element_line_break.rb +1 -1
  57. data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +1 -1
  58. data/lib/rubocop/cop/layout/hash_alignment.rb +2 -3
  59. data/lib/rubocop/cop/layout/heredoc_indentation.rb +2 -2
  60. data/lib/rubocop/cop/layout/indentation_style.rb +0 -2
  61. data/lib/rubocop/cop/layout/multiline_block_layout.rb +17 -7
  62. data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +1 -1
  63. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +0 -2
  64. data/lib/rubocop/cop/layout/space_after_colon.rb +1 -1
  65. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +22 -27
  66. data/lib/rubocop/cop/layout/space_around_keyword.rb +2 -2
  67. data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +33 -66
  68. data/lib/rubocop/cop/layout/space_around_operators.rb +1 -1
  69. data/lib/rubocop/cop/layout/space_before_block_braces.rb +14 -0
  70. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +4 -3
  71. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +1 -1
  72. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +2 -2
  73. data/lib/rubocop/cop/legacy/corrections_proxy.rb +49 -0
  74. data/lib/rubocop/cop/legacy/corrector.rb +29 -0
  75. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +7 -4
  76. data/lib/rubocop/cop/lint/ambiguous_operator.rb +15 -10
  77. data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +11 -13
  78. data/lib/rubocop/cop/lint/assignment_in_condition.rb +2 -2
  79. data/lib/rubocop/cop/lint/big_decimal_new.rb +10 -10
  80. data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +49 -0
  81. data/lib/rubocop/cop/lint/boolean_symbol.rb +16 -11
  82. data/lib/rubocop/cop/lint/circular_argument_reference.rb +1 -1
  83. data/lib/rubocop/cop/lint/constant_resolution.rb +89 -0
  84. data/lib/rubocop/cop/lint/debugger.rb +7 -1
  85. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +9 -10
  86. data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +21 -17
  87. data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +8 -2
  88. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +1 -1
  89. data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +39 -0
  90. data/lib/rubocop/cop/lint/duplicate_hash_key.rb +1 -1
  91. data/lib/rubocop/cop/lint/duplicate_methods.rb +9 -6
  92. data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +60 -0
  93. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  94. data/lib/rubocop/cop/lint/else_layout.rb +1 -1
  95. data/lib/rubocop/cop/lint/empty_conditional_body.rb +67 -0
  96. data/lib/rubocop/cop/lint/empty_ensure.rb +5 -5
  97. data/lib/rubocop/cop/lint/empty_expression.rb +2 -2
  98. data/lib/rubocop/cop/lint/empty_interpolation.rb +5 -6
  99. data/lib/rubocop/cop/lint/empty_when.rb +2 -2
  100. data/lib/rubocop/cop/lint/ensure_return.rb +27 -29
  101. data/lib/rubocop/cop/lint/erb_new_arguments.rb +11 -10
  102. data/lib/rubocop/cop/lint/flip_flop.rb +1 -1
  103. data/lib/rubocop/cop/lint/float_comparison.rb +93 -0
  104. data/lib/rubocop/cop/lint/float_out_of_range.rb +2 -2
  105. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +11 -5
  106. data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +13 -14
  107. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +5 -4
  108. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +8 -8
  109. data/lib/rubocop/cop/lint/inherit_exception.rb +12 -7
  110. data/lib/rubocop/cop/lint/interpolation_check.rb +21 -5
  111. data/lib/rubocop/cop/lint/literal_as_condition.rb +14 -2
  112. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +7 -7
  113. data/lib/rubocop/cop/lint/loop.rb +23 -2
  114. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +6 -5
  115. data/lib/rubocop/cop/lint/missing_super.rb +99 -0
  116. data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +1 -1
  117. data/lib/rubocop/cop/lint/multiple_comparison.rb +6 -9
  118. data/lib/rubocop/cop/lint/nested_method_definition.rb +15 -21
  119. data/lib/rubocop/cop/lint/nested_percent_literal.rb +1 -1
  120. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
  121. data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +84 -13
  122. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +2 -2
  123. data/lib/rubocop/cop/lint/number_conversion.rb +6 -9
  124. data/lib/rubocop/cop/lint/ordered_magic_comments.rb +11 -13
  125. data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +61 -0
  126. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +12 -13
  127. data/lib/rubocop/cop/lint/percent_string_array.rb +14 -13
  128. data/lib/rubocop/cop/lint/percent_symbol_array.rb +14 -13
  129. data/lib/rubocop/cop/lint/raise_exception.rb +15 -5
  130. data/lib/rubocop/cop/lint/rand_one.rb +3 -3
  131. data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +31 -25
  132. data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +7 -11
  133. data/lib/rubocop/cop/lint/redundant_require_statement.rb +4 -7
  134. data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +15 -11
  135. data/lib/rubocop/cop/lint/redundant_string_coercion.rb +6 -13
  136. data/lib/rubocop/cop/lint/redundant_with_index.rb +11 -14
  137. data/lib/rubocop/cop/lint/redundant_with_object.rb +11 -14
  138. data/lib/rubocop/cop/lint/regexp_as_condition.rb +6 -2
  139. data/lib/rubocop/cop/lint/require_parentheses.rb +2 -2
  140. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  141. data/lib/rubocop/cop/lint/rescue_type.rb +8 -8
  142. data/lib/rubocop/cop/lint/return_in_void_context.rb +2 -4
  143. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +3 -6
  144. data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +14 -10
  145. data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +10 -2
  146. data/lib/rubocop/cop/lint/script_permission.rb +10 -7
  147. data/lib/rubocop/cop/lint/self_assignment.rb +78 -0
  148. data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +5 -11
  149. data/lib/rubocop/cop/lint/shadowed_argument.rb +3 -3
  150. data/lib/rubocop/cop/lint/shadowed_exception.rb +2 -2
  151. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +3 -3
  152. data/lib/rubocop/cop/lint/struct_new_override.rb +1 -1
  153. data/lib/rubocop/cop/lint/suppressed_exception.rb +4 -7
  154. data/lib/rubocop/cop/lint/syntax.rb +11 -26
  155. data/lib/rubocop/cop/lint/to_json.rb +4 -6
  156. data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +34 -0
  157. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +4 -4
  158. data/lib/rubocop/cop/lint/unified_integer.rb +4 -6
  159. data/lib/rubocop/cop/lint/unreachable_code.rb +1 -1
  160. data/lib/rubocop/cop/lint/unreachable_loop.rb +174 -0
  161. data/lib/rubocop/cop/lint/unused_block_argument.rb +8 -3
  162. data/lib/rubocop/cop/lint/unused_method_argument.rb +9 -4
  163. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +1 -1
  164. data/lib/rubocop/cop/lint/uri_regexp.rb +11 -31
  165. data/lib/rubocop/cop/lint/useless_access_modifier.rb +26 -16
  166. data/lib/rubocop/cop/lint/useless_assignment.rb +4 -4
  167. data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +6 -15
  168. data/lib/rubocop/cop/lint/useless_setter_call.rb +4 -6
  169. data/lib/rubocop/cop/lint/void.rb +3 -7
  170. data/lib/rubocop/cop/metrics/abc_size.rb +1 -1
  171. data/lib/rubocop/cop/metrics/block_length.rb +24 -2
  172. data/lib/rubocop/cop/metrics/block_nesting.rb +2 -2
  173. data/lib/rubocop/cop/metrics/class_length.rb +26 -3
  174. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +37 -4
  175. data/lib/rubocop/cop/metrics/method_length.rb +25 -2
  176. data/lib/rubocop/cop/metrics/module_length.rb +26 -3
  177. data/lib/rubocop/cop/metrics/parameter_lists.rb +2 -6
  178. data/lib/rubocop/cop/metrics/perceived_complexity.rb +7 -8
  179. data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +47 -4
  180. data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +157 -0
  181. data/lib/rubocop/cop/metrics/utils/iterating_block.rb +61 -0
  182. data/lib/rubocop/cop/metrics/utils/repeated_csend_discount.rb +37 -0
  183. data/lib/rubocop/cop/migration/department_name.rb +13 -15
  184. data/lib/rubocop/cop/mixin/allowed_methods.rb +19 -0
  185. data/lib/rubocop/cop/mixin/array_min_size.rb +1 -1
  186. data/lib/rubocop/cop/mixin/auto_corrector.rb +12 -0
  187. data/lib/rubocop/cop/mixin/check_line_breakable.rb +1 -1
  188. data/lib/rubocop/cop/mixin/code_length.rb +26 -5
  189. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -1
  190. data/lib/rubocop/cop/mixin/configurable_naming.rb +1 -1
  191. data/lib/rubocop/cop/mixin/documentation_comment.rb +2 -2
  192. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +1 -1
  193. data/lib/rubocop/cop/mixin/enforce_superclass.rb +5 -1
  194. data/lib/rubocop/cop/mixin/first_element_line_break.rb +1 -1
  195. data/lib/rubocop/cop/mixin/method_complexity.rb +10 -2
  196. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +1 -1
  197. data/lib/rubocop/cop/mixin/nil_methods.rb +3 -5
  198. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +6 -1
  199. data/lib/rubocop/cop/mixin/parentheses.rb +1 -2
  200. data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +1 -1
  201. data/lib/rubocop/cop/mixin/range_help.rb +1 -1
  202. data/lib/rubocop/cop/mixin/regexp_literal_help.rb +27 -0
  203. data/lib/rubocop/cop/mixin/statement_modifier.rb +38 -9
  204. data/lib/rubocop/cop/mixin/string_literals_help.rb +1 -1
  205. data/lib/rubocop/cop/mixin/surrounding_space.rb +7 -27
  206. data/lib/rubocop/cop/mixin/trailing_comma.rb +1 -1
  207. data/lib/rubocop/cop/mixin/uncommunicative_name.rb +12 -17
  208. data/lib/rubocop/cop/mixin/unused_argument.rb +4 -6
  209. data/lib/rubocop/cop/mixin/visibility_help.rb +50 -0
  210. data/lib/rubocop/cop/naming/accessor_method_name.rb +4 -2
  211. data/lib/rubocop/cop/naming/ascii_identifiers.rb +29 -6
  212. data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +4 -4
  213. data/lib/rubocop/cop/naming/block_parameter_name.rb +1 -1
  214. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +2 -2
  215. data/lib/rubocop/cop/naming/constant_name.rb +2 -2
  216. data/lib/rubocop/cop/naming/file_name.rb +4 -6
  217. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +2 -2
  218. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +3 -3
  219. data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +2 -2
  220. data/lib/rubocop/cop/naming/method_name.rb +1 -1
  221. data/lib/rubocop/cop/naming/method_parameter_name.rb +2 -2
  222. data/lib/rubocop/cop/naming/predicate_name.rb +6 -10
  223. data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +12 -11
  224. data/lib/rubocop/cop/naming/variable_name.rb +1 -1
  225. data/lib/rubocop/cop/naming/variable_number.rb +1 -1
  226. data/lib/rubocop/cop/offense.rb +16 -2
  227. data/lib/rubocop/cop/registry.rb +3 -3
  228. data/lib/rubocop/cop/security/eval.rb +2 -2
  229. data/lib/rubocop/cop/security/json_load.rb +6 -8
  230. data/lib/rubocop/cop/security/marshal_load.rb +2 -4
  231. data/lib/rubocop/cop/security/open.rb +2 -2
  232. data/lib/rubocop/cop/security/yaml_load.rb +6 -6
  233. data/lib/rubocop/cop/style/access_modifier_declarations.rb +11 -1
  234. data/lib/rubocop/cop/style/accessor_grouping.rb +149 -0
  235. data/lib/rubocop/cop/style/alias.rb +7 -3
  236. data/lib/rubocop/cop/style/array_coercion.rb +63 -0
  237. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +3 -2
  238. data/lib/rubocop/cop/style/bare_percent_literals.rb +1 -1
  239. data/lib/rubocop/cop/style/bisected_attr_accessor.rb +144 -0
  240. data/lib/rubocop/cop/style/block_delimiters.rb +2 -4
  241. data/lib/rubocop/cop/style/case_equality.rb +22 -3
  242. data/lib/rubocop/cop/style/case_like_if.rb +217 -0
  243. data/lib/rubocop/cop/style/class_and_module_children.rb +1 -1
  244. data/lib/rubocop/cop/style/class_vars.rb +21 -0
  245. data/lib/rubocop/cop/style/colon_method_call.rb +3 -3
  246. data/lib/rubocop/cop/style/command_literal.rb +1 -1
  247. data/lib/rubocop/cop/style/commented_keyword.rb +5 -2
  248. data/lib/rubocop/cop/style/conditional_assignment.rb +11 -2
  249. data/lib/rubocop/cop/style/copyright.rb +3 -3
  250. data/lib/rubocop/cop/style/date_time.rb +1 -1
  251. data/lib/rubocop/cop/style/dir.rb +2 -2
  252. data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +1 -1
  253. data/lib/rubocop/cop/style/documentation.rb +6 -6
  254. data/lib/rubocop/cop/style/each_with_object.rb +0 -2
  255. data/lib/rubocop/cop/style/empty_case_condition.rb +8 -6
  256. data/lib/rubocop/cop/style/empty_literal.rb +5 -5
  257. data/lib/rubocop/cop/style/empty_method.rb +5 -5
  258. data/lib/rubocop/cop/style/encoding.rb +1 -1
  259. data/lib/rubocop/cop/style/eval_with_location.rb +4 -0
  260. data/lib/rubocop/cop/style/expand_path_arguments.rb +6 -2
  261. data/lib/rubocop/cop/style/explicit_block_argument.rb +102 -0
  262. data/lib/rubocop/cop/style/exponential_notation.rb +8 -10
  263. data/lib/rubocop/cop/style/float_division.rb +7 -10
  264. data/lib/rubocop/cop/style/format_string.rb +4 -0
  265. data/lib/rubocop/cop/style/format_string_token.rb +6 -5
  266. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +1 -1
  267. data/lib/rubocop/cop/style/global_std_stream.rb +65 -0
  268. data/lib/rubocop/cop/style/guard_clause.rb +2 -2
  269. data/lib/rubocop/cop/style/hash_as_last_array_item.rb +69 -0
  270. data/lib/rubocop/cop/style/hash_like_case.rb +76 -0
  271. data/lib/rubocop/cop/style/hash_syntax.rb +6 -3
  272. data/lib/rubocop/cop/style/identical_conditional_branches.rb +1 -1
  273. data/lib/rubocop/cop/style/if_unless_modifier.rb +8 -28
  274. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +12 -0
  275. data/lib/rubocop/cop/style/infinite_loop.rb +1 -1
  276. data/lib/rubocop/cop/style/inverse_methods.rb +3 -4
  277. data/lib/rubocop/cop/style/ip_addresses.rb +1 -1
  278. data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +5 -0
  279. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +1 -1
  280. data/lib/rubocop/cop/style/missing_else.rb +1 -11
  281. data/lib/rubocop/cop/style/missing_respond_to_missing.rb +9 -2
  282. data/lib/rubocop/cop/style/multiline_block_chain.rb +10 -1
  283. data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
  284. data/lib/rubocop/cop/style/multiline_memoization.rb +2 -2
  285. data/lib/rubocop/cop/style/multiline_method_signature.rb +1 -1
  286. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +17 -6
  287. data/lib/rubocop/cop/style/mutable_constant.rb +4 -4
  288. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +2 -5
  289. data/lib/rubocop/cop/style/nested_ternary_operator.rb +27 -0
  290. data/lib/rubocop/cop/style/next.rb +2 -2
  291. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +2 -2
  292. data/lib/rubocop/cop/style/numeric_predicate.rb +7 -4
  293. data/lib/rubocop/cop/style/optional_boolean_parameter.rb +42 -0
  294. data/lib/rubocop/cop/style/parallel_assignment.rb +5 -5
  295. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +2 -2
  296. data/lib/rubocop/cop/style/proc.rb +1 -1
  297. data/lib/rubocop/cop/style/random_with_offset.rb +5 -10
  298. data/lib/rubocop/cop/style/redundant_assignment.rb +117 -0
  299. data/lib/rubocop/cop/style/redundant_condition.rb +15 -3
  300. data/lib/rubocop/cop/style/redundant_exception.rb +18 -10
  301. data/lib/rubocop/cop/style/redundant_fetch_block.rb +122 -0
  302. data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +50 -0
  303. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  304. data/lib/rubocop/cop/style/redundant_parentheses.rb +8 -2
  305. data/lib/rubocop/cop/style/redundant_percent_q.rb +2 -2
  306. data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +4 -3
  307. data/lib/rubocop/cop/style/redundant_regexp_escape.rb +23 -32
  308. data/lib/rubocop/cop/style/redundant_self.rb +6 -9
  309. data/lib/rubocop/cop/style/redundant_sort.rb +28 -12
  310. data/lib/rubocop/cop/style/rescue_standard_error.rb +1 -1
  311. data/lib/rubocop/cop/style/sample.rb +1 -1
  312. data/lib/rubocop/cop/style/semicolon.rb +1 -1
  313. data/lib/rubocop/cop/style/signal_exception.rb +3 -1
  314. data/lib/rubocop/cop/style/single_argument_dig.rb +54 -0
  315. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +3 -2
  316. data/lib/rubocop/cop/style/stderr_puts.rb +1 -1
  317. data/lib/rubocop/cop/style/string_concatenation.rb +92 -0
  318. data/lib/rubocop/cop/style/struct_inheritance.rb +23 -2
  319. data/lib/rubocop/cop/style/symbol_array.rb +6 -6
  320. data/lib/rubocop/cop/style/symbol_proc.rb +2 -2
  321. data/lib/rubocop/cop/style/ternary_parentheses.rb +1 -1
  322. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +9 -32
  323. data/lib/rubocop/cop/style/trivial_accessors.rb +8 -7
  324. data/lib/rubocop/cop/style/word_array.rb +1 -1
  325. data/lib/rubocop/cop/style/yoda_condition.rb +18 -1
  326. data/lib/rubocop/cop/style/zero_length_predicate.rb +12 -8
  327. data/lib/rubocop/cop/team.rb +98 -82
  328. data/lib/rubocop/cop/tokens_util.rb +84 -0
  329. data/lib/rubocop/cop/util.rb +3 -15
  330. data/lib/rubocop/cop/utils/format_string.rb +2 -3
  331. data/lib/rubocop/cop/variable_force.rb +0 -2
  332. data/lib/rubocop/cop/variable_force/branch.rb +1 -0
  333. data/lib/rubocop/cop/variable_force/variable.rb +7 -5
  334. data/lib/rubocop/cops_documentation_generator.rb +282 -0
  335. data/lib/rubocop/error.rb +1 -0
  336. data/lib/rubocop/file_finder.rb +12 -12
  337. data/lib/rubocop/formatter/disabled_config_formatter.rb +2 -2
  338. data/lib/rubocop/formatter/formatter_set.rb +2 -1
  339. data/lib/rubocop/name_similarity.rb +7 -3
  340. data/lib/rubocop/options.rb +15 -8
  341. data/lib/rubocop/path_util.rb +19 -19
  342. data/lib/rubocop/platform.rb +1 -1
  343. data/lib/rubocop/rake_task.rb +7 -9
  344. data/lib/rubocop/result_cache.rb +12 -8
  345. data/lib/rubocop/rspec/cop_helper.rb +4 -4
  346. data/lib/rubocop/rspec/expect_offense.rb +63 -22
  347. data/lib/rubocop/rspec/shared_contexts.rb +19 -16
  348. data/lib/rubocop/runner.rb +34 -33
  349. data/lib/rubocop/target_finder.rb +14 -11
  350. data/lib/rubocop/target_ruby.rb +2 -2
  351. data/lib/rubocop/version.rb +2 -2
  352. metadata +49 -11
  353. data/lib/rubocop/cop/lint/useless_comparison.rb +0 -28
  354. data/lib/rubocop/cop/mixin/classish_length.rb +0 -37
  355. data/lib/rubocop/cop/mixin/parser_diagnostic.rb +0 -37
  356. data/lib/rubocop/cop/mixin/too_many_lines.rb +0 -35
  357. data/lib/rubocop/cop/style/method_missing_super.rb +0 -34
@@ -5,6 +5,7 @@ module RuboCop
5
5
  # This module contains a collection of useful utility methods.
6
6
  module Util
7
7
  include PathUtil
8
+ include TokensUtil
8
9
 
9
10
  # Match literal regex characters, not including anchors, character
10
11
  # classes, alternatives, groups, repetitions, references, etc
@@ -14,7 +15,7 @@ module RuboCop
14
15
  module_function
15
16
 
16
17
  def comment_line?(line_source)
17
- line_source =~ /^\s*#/
18
+ /^\s*#/.match?(line_source)
18
19
  end
19
20
 
20
21
  def comment_lines?(node)
@@ -88,7 +89,7 @@ module RuboCop
88
89
 
89
90
  # Regex matches IF there is a ' or there is a \\ in the string that is
90
91
  # not preceded/followed by another \\ (e.g. "\\x34") but not "\\\\".
91
- string =~ /'|(?<! \\) \\{2}* \\ (?![\\"])/x
92
+ /'|(?<! \\) \\{2}* \\ (?![\\"])/x.match?(string)
92
93
  end
93
94
 
94
95
  def needs_escaping?(string)
@@ -127,19 +128,6 @@ module RuboCop
127
128
  .sub('Style', 'Styles')
128
129
  end
129
130
 
130
- def tokens(node)
131
- @tokens ||= {}
132
- return @tokens[node.object_id] if @tokens[node.object_id]
133
-
134
- source_range = node.source_range
135
- begin_pos = source_range.begin_pos
136
- end_pos = source_range.end_pos
137
-
138
- @tokens[node.object_id] = processed_source.tokens.select do |token|
139
- token.end_pos <= end_pos && token.begin_pos >= begin_pos
140
- end
141
- end
142
-
143
131
  private
144
132
 
145
133
  def compatible_external_encoding_for?(src)
@@ -41,8 +41,7 @@ module RuboCop
41
41
  #
42
42
  # @see https://ruby-doc.org/core-2.6.3/Kernel.html#method-i-format
43
43
  class FormatSequence
44
- attr_reader :begin_pos, :end_pos
45
- attr_reader :flags, :width, :precision, :name, :type
44
+ attr_reader :begin_pos, :end_pos, :flags, :width, :precision, :name, :type
46
45
 
47
46
  def initialize(match)
48
47
  @source = match[0]
@@ -120,7 +119,7 @@ module RuboCop
120
119
  end
121
120
 
122
121
  def mixed_formats?
123
- formats = format_sequences.map do |seq|
122
+ formats = format_sequences.reject(&:percent?).map do |seq|
124
123
  if seq.name
125
124
  :named
126
125
  elsif seq.max_digit_dollar_num
@@ -197,7 +197,6 @@ module RuboCop
197
197
  regexp.named_captures.keys
198
198
  end
199
199
 
200
- # rubocop:disable Metrics/AbcSize
201
200
  def process_variable_operator_assignment(node)
202
201
  if LOGICAL_OPERATOR_ASSIGNMENT_TYPES.include?(node.type)
203
202
  asgn_node, rhs_node = *node
@@ -232,7 +231,6 @@ module RuboCop
232
231
 
233
232
  skip_children!
234
233
  end
235
- # rubocop:enable Metrics/AbcSize
236
234
 
237
235
  def process_variable_multiple_assignment(node)
238
236
  lhs_node, rhs_node = *node
@@ -49,6 +49,7 @@ module RuboCop
49
49
  end
50
50
 
51
51
  def self.inherited(subclass)
52
+ super
52
53
  classes << subclass
53
54
  end
54
55
 
@@ -38,14 +38,14 @@ module RuboCop
38
38
  !@references.empty?
39
39
  end
40
40
 
41
- # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity
41
+ # rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
42
42
  def reference!(node)
43
43
  reference = Reference.new(node, @scope)
44
44
  @references << reference
45
- consumed_branches = Set.new
45
+ consumed_branches = nil
46
46
 
47
47
  @assignments.reverse_each do |assignment|
48
- next if consumed_branches.include?(assignment.branch)
48
+ next if consumed_branches&.include?(assignment.branch)
49
49
 
50
50
  assignment.reference!(node) unless assignment.run_exclusively_with?(reference)
51
51
 
@@ -58,10 +58,12 @@ module RuboCop
58
58
 
59
59
  break if !assignment.branch || assignment.branch == reference.branch
60
60
 
61
- consumed_branches << assignment.branch unless assignment.branch.may_run_incompletely?
61
+ unless assignment.branch.may_run_incompletely?
62
+ (consumed_branches ||= Set.new) << assignment.branch
63
+ end
62
64
  end
63
65
  end
64
- # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity
66
+ # rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity
65
67
 
66
68
  def in_modifier_if?(assignment)
67
69
  parent = assignment.node.parent
@@ -0,0 +1,282 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Class for generating documentation of all cops departments
4
+ class CopsDocumentationGenerator # rubocop:disable Metrics/ClassLength
5
+ # This class will only generate documentation for cops that belong to one of
6
+ # the departments given in the `departments` array. E.g. if we only wanted
7
+ # documentation for Lint cops:
8
+ #
9
+ # CopsDocumentationGenerator.new(departments: ['Lint']).call
10
+ #
11
+ def initialize(departments: [])
12
+ @departments = departments.map(&:to_sym).sort!
13
+ @cops = RuboCop::Cop::Cop.registry
14
+ @config = RuboCop::ConfigLoader.default_configuration
15
+ end
16
+
17
+ def call
18
+ YARD::Registry.load!
19
+ departments.each do |department|
20
+ print_cops_of_department(department)
21
+ end
22
+
23
+ print_table_of_contents
24
+ ensure
25
+ RuboCop::ConfigLoader.default_configuration = nil
26
+ end
27
+
28
+ private
29
+
30
+ attr_reader :departments, :cops, :config
31
+
32
+ def cops_of_department(department)
33
+ cops.with_department(department).sort!
34
+ end
35
+
36
+ def cops_body(cop, description, examples_objects, pars)
37
+ content = h2(cop.cop_name)
38
+ content << required_ruby_version(cop)
39
+ content << properties(cop)
40
+ content << "#{description}\n"
41
+ content << examples(examples_objects) if examples_objects.count.positive?
42
+ content << configurations(pars)
43
+ content << references(cop)
44
+ content
45
+ end
46
+
47
+ def examples(examples_object)
48
+ examples_object.each_with_object(h3('Examples').dup) do |example, content|
49
+ content << "\n" unless content.end_with?("\n\n")
50
+ content << h4(example.name) unless example.name == ''
51
+ content << code_example(example)
52
+ end
53
+ end
54
+
55
+ def required_ruby_version(cop)
56
+ return '' unless cop.respond_to?(:required_minimum_ruby_version)
57
+
58
+ "NOTE: Required Ruby version: #{cop.required_minimum_ruby_version}\n\n"
59
+ end
60
+
61
+ # rubocop:disable Metrics/MethodLength
62
+ def properties(cop)
63
+ header = [
64
+ 'Enabled by default', 'Safe', 'Supports autocorrection', 'VersionAdded',
65
+ 'VersionChanged'
66
+ ]
67
+ autocorrect = if cop.support_autocorrect?
68
+ "Yes#{' (Unsafe)' unless cop.new(config).safe_autocorrect?}"
69
+ else
70
+ 'No'
71
+ end
72
+ cop_config = config.for_cop(cop)
73
+ content = [[
74
+ cop_status(cop_config.fetch('Enabled')),
75
+ cop_config.fetch('Safe', true) ? 'Yes' : 'No',
76
+ autocorrect,
77
+ cop_config.fetch('VersionAdded', '-'),
78
+ cop_config.fetch('VersionChanged', '-')
79
+ ]]
80
+ "#{to_table(header, content)}\n"
81
+ end
82
+ # rubocop:enable Metrics/MethodLength
83
+
84
+ def h2(title)
85
+ content = +"\n"
86
+ content << "== #{title}\n"
87
+ content << "\n"
88
+ content
89
+ end
90
+
91
+ def h3(title)
92
+ content = +"\n"
93
+ content << "=== #{title}\n"
94
+ content << "\n"
95
+ content
96
+ end
97
+
98
+ def h4(title)
99
+ content = +"==== #{title}\n"
100
+ content << "\n"
101
+ content
102
+ end
103
+
104
+ def code_example(ruby_code)
105
+ content = +"[source,ruby]\n----\n"
106
+ content << ruby_code.text.gsub('@good', '# good')
107
+ .gsub('@bad', '# bad').strip
108
+ content << "\n----\n"
109
+ content
110
+ end
111
+
112
+ def configurations(pars)
113
+ return '' if pars.empty?
114
+
115
+ header = ['Name', 'Default value', 'Configurable values']
116
+ configs = pars
117
+ .each_key
118
+ .reject { |key| key.start_with?('Supported') }
119
+ .reject { |key| key.start_with?('AllowMultipleStyles') }
120
+ content = configs.map do |name|
121
+ configurable = configurable_values(pars, name)
122
+ default = format_table_value(pars[name])
123
+ [name, default, configurable]
124
+ end
125
+
126
+ h3('Configurable attributes') + to_table(header, content)
127
+ end
128
+
129
+ # rubocop:disable Metrics/CyclomaticComplexity,Metrics/MethodLength
130
+ def configurable_values(pars, name)
131
+ case name
132
+ when /^Enforced/
133
+ supported_style_name = RuboCop::Cop::Util.to_supported_styles(name)
134
+ format_table_value(pars[supported_style_name])
135
+ when 'IndentationWidth'
136
+ 'Integer'
137
+ when 'Database'
138
+ format_table_value(pars['SupportedDatabases'])
139
+ else
140
+ case pars[name]
141
+ when String
142
+ 'String'
143
+ when Integer
144
+ 'Integer'
145
+ when Float
146
+ 'Float'
147
+ when true, false
148
+ 'Boolean'
149
+ when Array
150
+ 'Array'
151
+ else
152
+ ''
153
+ end
154
+ end
155
+ end
156
+ # rubocop:enable Metrics/CyclomaticComplexity,Metrics/MethodLength
157
+
158
+ def to_table(header, content)
159
+ table = [
160
+ '|===',
161
+ "| #{header.join(' | ')}\n\n"
162
+ ].join("\n")
163
+ marked_contents = content.map do |plain_content|
164
+ plain_content.map { |c| "| #{c}" }.join("\n")
165
+ end
166
+ table << marked_contents.join("\n\n")
167
+ table << "\n|===\n"
168
+ end
169
+
170
+ def format_table_value(val)
171
+ value =
172
+ case val
173
+ when Array
174
+ if val.empty?
175
+ '`[]`'
176
+ else
177
+ val.map { |config| format_table_value(config) }.join(', ')
178
+ end
179
+ else
180
+ wrap_backtick(val.nil? ? '<none>' : val)
181
+ end
182
+ value.gsub("#{Dir.pwd}/", '').rstrip
183
+ end
184
+
185
+ def wrap_backtick(value)
186
+ if value.is_a?(String)
187
+ # Use `+` to prevent text like `**/*.gemspec` from being bold.
188
+ value.start_with?('*') ? "`+#{value}+`" : "`#{value}`"
189
+ else
190
+ "`#{value}`"
191
+ end
192
+ end
193
+
194
+ def references(cop)
195
+ cop_config = config.for_cop(cop)
196
+ urls = RuboCop::Cop::MessageAnnotator.new(
197
+ config, cop.name, cop_config, {}
198
+ ).urls
199
+ return '' if urls.empty?
200
+
201
+ content = h3('References')
202
+ content << urls.map { |url| "* #{url}" }.join("\n")
203
+ content << "\n"
204
+ content
205
+ end
206
+
207
+ def print_cops_of_department(department)
208
+ selected_cops = cops_of_department(department)
209
+ content = +"= #{department}\n"
210
+ selected_cops.each do |cop|
211
+ content << print_cop_with_doc(cop)
212
+ end
213
+ file_name = "#{Dir.pwd}/docs/modules/ROOT/pages/cops_#{department.downcase}.adoc"
214
+ File.open(file_name, 'w') do |file|
215
+ puts "* generated #{file_name}"
216
+ file.write("#{content.strip}\n")
217
+ end
218
+ end
219
+
220
+ def print_cop_with_doc(cop)
221
+ cop_config = config.for_cop(cop)
222
+ non_display_keys = %w[
223
+ Description Enabled StyleGuide Reference Safe SafeAutoCorrect VersionAdded
224
+ VersionChanged
225
+ ]
226
+ pars = cop_config.reject { |k| non_display_keys.include? k }
227
+ description = 'No documentation'
228
+ examples_object = []
229
+ cop_code(cop) do |code_object|
230
+ description = code_object.docstring unless code_object.docstring.blank?
231
+ examples_object = code_object.tags('example')
232
+ end
233
+ cops_body(cop, description, examples_object, pars)
234
+ end
235
+
236
+ def cop_code(cop)
237
+ YARD::Registry.all(:class).detect do |code_object|
238
+ next unless RuboCop::Cop::Badge.for(code_object.to_s) == cop.badge
239
+
240
+ yield code_object
241
+ end
242
+ end
243
+
244
+ def table_of_content_for_department(department)
245
+ type_title = department[0].upcase + department[1..-1]
246
+ filename = "cops_#{department.downcase}.adoc"
247
+ content = +"=== Department xref:#{filename}[#{type_title}]\n\n"
248
+ cops_of_department(department).each do |cop|
249
+ anchor = cop.cop_name.sub('/', '').downcase
250
+ content << "* xref:#{filename}##{anchor}[#{cop.cop_name}]\n"
251
+ end
252
+
253
+ content
254
+ end
255
+
256
+ def print_table_of_contents
257
+ path = "#{Dir.pwd}/docs/modules/ROOT/pages/cops.adoc"
258
+ original = File.read(path)
259
+ content = +"// START_COP_LIST\n\n"
260
+
261
+ content << table_contents
262
+
263
+ content << "\n// END_COP_LIST"
264
+
265
+ content = original.sub(
266
+ %r{// START_COP_LIST.+// END_COP_LIST}m, content
267
+ )
268
+ File.write(path, content)
269
+ end
270
+
271
+ def table_contents
272
+ departments
273
+ .map { |department| table_of_content_for_department(department) }
274
+ .join("\n")
275
+ end
276
+
277
+ def cop_status(status)
278
+ return 'Disabled' unless status
279
+
280
+ status == 'pending' ? 'Pending' : 'Enabled'
281
+ end
282
+ end
@@ -12,6 +12,7 @@ module RuboCop
12
12
  # A wrapper to display errored location of analyzed file.
13
13
  class ErrorWithAnalyzedFileLocation < Error
14
14
  def initialize(cause:, node:, cop:)
15
+ super()
15
16
  @cause = cause
16
17
  @cop = cop
17
18
  @location = node.is_a?(RuboCop::AST::Node) ? node.loc : node
@@ -9,33 +9,33 @@ module RuboCop
9
9
  @root_level = level
10
10
  end
11
11
 
12
- def self.root_level?(path)
13
- @root_level == path.to_s
12
+ def self.root_level?(path, stop_dir)
13
+ (@root_level || stop_dir) == path.to_s
14
14
  end
15
15
 
16
- def find_file_upwards(filename, start_dir)
17
- traverse_files_upwards(filename, start_dir) do |file|
16
+ def find_file_upwards(filename, start_dir, stop_dir = nil)
17
+ traverse_files_upwards(filename, start_dir, stop_dir) do |file|
18
18
  # minimize iteration for performance
19
19
  return file if file
20
20
  end
21
21
  end
22
22
 
23
- def find_files_upwards(filename, start_dir)
24
- files = []
25
- traverse_files_upwards(filename, start_dir) do |file|
26
- files << file
23
+ def find_last_file_upwards(filename, start_dir, stop_dir = nil)
24
+ last_file = nil
25
+ traverse_files_upwards(filename, start_dir, stop_dir) do |file|
26
+ last_file = file
27
27
  end
28
- files
28
+ last_file
29
29
  end
30
30
 
31
31
  private
32
32
 
33
- def traverse_files_upwards(filename, start_dir)
33
+ def traverse_files_upwards(filename, start_dir, stop_dir)
34
34
  Pathname.new(start_dir).expand_path.ascend do |dir|
35
- break if FileFinder.root_level?(dir)
36
-
37
35
  file = dir + filename
38
36
  yield(file.to_s) if file.exist?
37
+
38
+ break if FileFinder.root_level?(dir, stop_dir)
39
39
  end
40
40
  end
41
41
  end