rubocop 0.49.1 → 0.52.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 (506) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +6 -9
  3. data/bin/rubocop +1 -1
  4. data/config/default.yml +264 -118
  5. data/config/disabled.yml +13 -9
  6. data/config/enabled.yml +1156 -918
  7. data/lib/rubocop.rb +555 -489
  8. data/lib/rubocop/ast/builder.rb +6 -1
  9. data/lib/rubocop/ast/node.rb +68 -52
  10. data/lib/rubocop/ast/node/args_node.rb +15 -10
  11. data/lib/rubocop/ast/node/array_node.rb +10 -1
  12. data/lib/rubocop/ast/node/block_node.rb +9 -0
  13. data/lib/rubocop/ast/node/def_node.rb +71 -0
  14. data/lib/rubocop/ast/node/for_node.rb +8 -0
  15. data/lib/rubocop/ast/node/if_node.rb +10 -2
  16. data/lib/rubocop/ast/node/mixin/basic_literal_node.rb +16 -0
  17. data/lib/rubocop/ast/node/mixin/collection_node.rb +15 -0
  18. data/lib/rubocop/ast/node/mixin/method_dispatch_node.rb +174 -0
  19. data/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb +89 -0
  20. data/lib/rubocop/ast/node/mixin/parameterized_node.rb +18 -31
  21. data/lib/rubocop/ast/node/regexp_node.rb +35 -0
  22. data/lib/rubocop/ast/node/send_node.rb +21 -150
  23. data/lib/rubocop/ast/node/str_node.rb +14 -0
  24. data/lib/rubocop/ast/node/super_node.rb +3 -24
  25. data/lib/rubocop/ast/node/symbol_node.rb +20 -0
  26. data/lib/rubocop/ast/node/yield_node.rb +21 -0
  27. data/lib/rubocop/ast/traversal.rb +7 -7
  28. data/lib/rubocop/cached_data.rb +1 -6
  29. data/lib/rubocop/cli.rb +59 -13
  30. data/lib/rubocop/comment_config.rb +2 -5
  31. data/lib/rubocop/config.rb +136 -29
  32. data/lib/rubocop/config_loader.rb +61 -104
  33. data/lib/rubocop/config_loader_resolver.rb +102 -4
  34. data/lib/rubocop/cop/autocorrect_logic.rb +1 -1
  35. data/lib/rubocop/cop/bundler/duplicated_gem.rb +13 -11
  36. data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +67 -0
  37. data/lib/rubocop/cop/bundler/ordered_gems.rb +7 -58
  38. data/lib/rubocop/cop/commissioner.rb +6 -3
  39. data/lib/rubocop/cop/cop.rb +11 -6
  40. data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +102 -0
  41. data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +97 -0
  42. data/lib/rubocop/cop/gemspec/required_ruby_version.rb +87 -0
  43. data/lib/rubocop/cop/generator.rb +122 -25
  44. data/lib/rubocop/cop/internal_affairs.rb +6 -2
  45. data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +46 -0
  46. data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +16 -5
  47. data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +54 -0
  48. data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +59 -0
  49. data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +71 -0
  50. data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +3 -3
  51. data/lib/rubocop/cop/layout/access_modifier_indentation.rb +6 -10
  52. data/lib/rubocop/cop/layout/align_array.rb +2 -2
  53. data/lib/rubocop/cop/layout/align_hash.rb +18 -18
  54. data/lib/rubocop/cop/layout/align_parameters.rb +11 -23
  55. data/lib/rubocop/cop/layout/block_end_newline.rb +20 -6
  56. data/lib/rubocop/cop/layout/case_indentation.rb +15 -18
  57. data/lib/rubocop/cop/layout/class_structure.rb +306 -0
  58. data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +7 -6
  59. data/lib/rubocop/cop/layout/comment_indentation.rb +42 -3
  60. data/lib/rubocop/cop/layout/dot_position.rb +31 -13
  61. data/lib/rubocop/cop/layout/else_alignment.rb +37 -17
  62. data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +1 -1
  63. data/lib/rubocop/cop/layout/empty_line_between_defs.rb +22 -18
  64. data/lib/rubocop/cop/layout/empty_lines.rb +16 -2
  65. data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +23 -6
  66. data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +89 -0
  67. data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +2 -2
  68. data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +4 -8
  69. data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +30 -5
  70. data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +10 -6
  71. data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +5 -5
  72. data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +22 -7
  73. data/lib/rubocop/cop/layout/end_of_line.rb +2 -2
  74. data/lib/rubocop/cop/layout/extra_spacing.rb +23 -26
  75. data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +3 -3
  76. data/lib/rubocop/cop/layout/first_parameter_indentation.rb +9 -3
  77. data/lib/rubocop/cop/layout/indent_array.rb +68 -21
  78. data/lib/rubocop/cop/layout/indent_hash.rb +71 -26
  79. data/lib/rubocop/cop/layout/indent_heredoc.rb +70 -35
  80. data/lib/rubocop/cop/layout/indentation_consistency.rb +1 -2
  81. data/lib/rubocop/cop/layout/indentation_width.rb +40 -27
  82. data/lib/rubocop/cop/layout/initial_indentation.rb +10 -7
  83. data/lib/rubocop/cop/layout/leading_comment_space.rb +32 -17
  84. data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +47 -14
  85. data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +12 -11
  86. data/lib/rubocop/cop/layout/multiline_block_layout.rb +19 -16
  87. data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +46 -13
  88. data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +29 -27
  89. data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +7 -3
  90. data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +6 -0
  91. data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +12 -4
  92. data/lib/rubocop/cop/layout/space_after_colon.rb +13 -6
  93. data/lib/rubocop/cop/layout/space_after_comma.rb +11 -1
  94. data/lib/rubocop/cop/layout/space_after_method_name.rb +8 -6
  95. data/lib/rubocop/cop/layout/space_after_not.rb +1 -1
  96. data/lib/rubocop/cop/layout/space_after_semicolon.rb +8 -1
  97. data/lib/rubocop/cop/layout/space_around_block_parameters.rb +32 -25
  98. data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +28 -17
  99. data/lib/rubocop/cop/layout/space_around_keyword.rb +22 -16
  100. data/lib/rubocop/cop/layout/space_around_operators.rb +27 -14
  101. data/lib/rubocop/cop/layout/space_before_block_braces.rb +61 -12
  102. data/lib/rubocop/cop/layout/space_before_comma.rb +12 -1
  103. data/lib/rubocop/cop/layout/space_before_comment.rb +10 -5
  104. data/lib/rubocop/cop/layout/space_before_first_arg.rb +5 -4
  105. data/lib/rubocop/cop/layout/space_before_semicolon.rb +8 -1
  106. data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +12 -14
  107. data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +235 -0
  108. data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +4 -4
  109. data/lib/rubocop/cop/layout/space_inside_block_braces.rb +89 -18
  110. data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +62 -36
  111. data/lib/rubocop/cop/layout/space_inside_parens.rb +40 -3
  112. data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +1 -1
  113. data/lib/rubocop/cop/layout/space_inside_range_literal.rb +15 -15
  114. data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +81 -0
  115. data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +32 -17
  116. data/lib/rubocop/cop/layout/tab.rb +7 -4
  117. data/lib/rubocop/cop/layout/trailing_blank_lines.rb +11 -9
  118. data/lib/rubocop/cop/layout/trailing_whitespace.rb +1 -1
  119. data/lib/rubocop/cop/lint/ambiguous_block_association.rb +12 -19
  120. data/lib/rubocop/cop/lint/assignment_in_condition.rb +16 -2
  121. data/lib/rubocop/cop/lint/block_alignment.rb +42 -30
  122. data/lib/rubocop/cop/lint/boolean_symbol.rb +38 -0
  123. data/lib/rubocop/cop/lint/circular_argument_reference.rb +3 -14
  124. data/lib/rubocop/cop/lint/condition_position.rb +5 -1
  125. data/lib/rubocop/cop/lint/debugger.rb +18 -11
  126. data/lib/rubocop/cop/lint/def_end_alignment.rb +9 -14
  127. data/lib/rubocop/cop/lint/deprecated_class_methods.rb +4 -4
  128. data/lib/rubocop/cop/lint/duplicate_case_condition.rb +3 -3
  129. data/lib/rubocop/cop/lint/duplicate_methods.rb +75 -5
  130. data/lib/rubocop/cop/lint/duplicated_key.rb +1 -1
  131. data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -1
  132. data/lib/rubocop/cop/lint/else_layout.rb +3 -3
  133. data/lib/rubocop/cop/lint/empty_ensure.rb +1 -1
  134. data/lib/rubocop/cop/lint/empty_expression.rb +1 -1
  135. data/lib/rubocop/cop/lint/empty_interpolation.rb +1 -1
  136. data/lib/rubocop/cop/lint/empty_when.rb +1 -1
  137. data/lib/rubocop/cop/lint/end_alignment.rb +13 -14
  138. data/lib/rubocop/cop/lint/end_in_method.rb +1 -1
  139. data/lib/rubocop/cop/lint/ensure_return.rb +1 -1
  140. data/lib/rubocop/cop/lint/float_out_of_range.rb +5 -5
  141. data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +36 -41
  142. data/lib/rubocop/cop/lint/handle_exceptions.rb +1 -1
  143. data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +1 -1
  144. data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +25 -20
  145. data/lib/rubocop/cop/lint/inherit_exception.rb +16 -19
  146. data/lib/rubocop/cop/lint/interpolation_check.rb +37 -0
  147. data/lib/rubocop/cop/lint/{literal_in_condition.rb → literal_as_condition.rb} +21 -7
  148. data/lib/rubocop/cop/lint/literal_in_interpolation.rb +1 -1
  149. data/lib/rubocop/cop/lint/loop.rb +1 -1
  150. data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +81 -0
  151. data/lib/rubocop/cop/lint/multiple_compare.rb +1 -1
  152. data/lib/rubocop/cop/lint/nested_method_definition.rb +6 -8
  153. data/lib/rubocop/cop/lint/nested_percent_literal.rb +58 -0
  154. data/lib/rubocop/cop/lint/next_without_accumulator.rb +1 -1
  155. data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +4 -4
  156. data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +4 -3
  157. data/lib/rubocop/cop/lint/percent_string_array.rb +13 -22
  158. data/lib/rubocop/cop/lint/percent_symbol_array.rb +12 -12
  159. data/lib/rubocop/cop/lint/rand_one.rb +8 -2
  160. data/lib/rubocop/cop/lint/redundant_with_index.rb +80 -0
  161. data/lib/rubocop/cop/lint/redundant_with_object.rb +81 -0
  162. data/lib/rubocop/cop/lint/regexp_as_condition.rb +29 -0
  163. data/lib/rubocop/cop/lint/require_parentheses.rb +5 -3
  164. data/lib/rubocop/cop/lint/rescue_exception.rb +1 -1
  165. data/lib/rubocop/cop/lint/rescue_type.rb +18 -9
  166. data/lib/rubocop/cop/lint/return_in_void_context.rb +74 -0
  167. data/lib/rubocop/cop/lint/safe_navigation_chain.rb +1 -1
  168. data/lib/rubocop/cop/lint/script_permission.rb +8 -1
  169. data/lib/rubocop/cop/lint/shadowed_argument.rb +146 -0
  170. data/lib/rubocop/cop/lint/shadowed_exception.rb +37 -10
  171. data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +1 -1
  172. data/lib/rubocop/cop/lint/string_conversion_in_interpolation.rb +7 -7
  173. data/lib/rubocop/cop/lint/syntax.rb +23 -20
  174. data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +1 -1
  175. data/lib/rubocop/cop/lint/unified_integer.rb +5 -4
  176. data/lib/rubocop/cop/lint/unneeded_disable.rb +41 -16
  177. data/lib/rubocop/cop/lint/unneeded_require_statement.rb +51 -0
  178. data/lib/rubocop/cop/lint/unneeded_splat_expansion.rb +45 -19
  179. data/lib/rubocop/cop/lint/unreachable_code.rb +53 -8
  180. data/lib/rubocop/cop/lint/unused_method_argument.rb +2 -1
  181. data/lib/rubocop/cop/lint/uri_escape_unescape.rb +74 -0
  182. data/lib/rubocop/cop/lint/uri_regexp.rb +73 -0
  183. data/lib/rubocop/cop/lint/useless_access_modifier.rb +12 -16
  184. data/lib/rubocop/cop/lint/useless_assignment.rb +1 -1
  185. data/lib/rubocop/cop/lint/useless_comparison.rb +1 -1
  186. data/lib/rubocop/cop/lint/useless_setter_call.rb +15 -12
  187. data/lib/rubocop/cop/lint/void.rb +38 -27
  188. data/lib/rubocop/cop/message_annotator.rb +4 -2
  189. data/lib/rubocop/cop/metrics/abc_size.rb +2 -2
  190. data/lib/rubocop/cop/metrics/block_nesting.rb +1 -1
  191. data/lib/rubocop/cop/metrics/class_length.rb +3 -1
  192. data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +2 -1
  193. data/lib/rubocop/cop/metrics/line_length.rb +8 -5
  194. data/lib/rubocop/cop/metrics/method_length.rb +8 -3
  195. data/lib/rubocop/cop/metrics/module_length.rb +3 -1
  196. data/lib/rubocop/cop/metrics/parameter_lists.rb +14 -5
  197. data/lib/rubocop/cop/metrics/perceived_complexity.rb +2 -1
  198. data/lib/rubocop/cop/mixin/array_hash_indentation.rb +3 -2
  199. data/lib/rubocop/cop/mixin/autocorrect_alignment.rb +2 -2
  200. data/lib/rubocop/cop/mixin/code_length.rb +1 -1
  201. data/lib/rubocop/cop/mixin/configurable_formatting.rb +1 -1
  202. data/lib/rubocop/cop/mixin/def_node.rb +1 -1
  203. data/lib/rubocop/cop/mixin/documentation_comment.rb +1 -1
  204. data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +14 -7
  205. data/lib/rubocop/cop/mixin/empty_parameter.rb +23 -0
  206. data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +8 -4
  207. data/lib/rubocop/cop/mixin/enforce_superclass.rb +3 -3
  208. data/lib/rubocop/cop/mixin/first_element_line_break.rb +12 -3
  209. data/lib/rubocop/cop/mixin/heredoc.rb +28 -0
  210. data/lib/rubocop/cop/mixin/method_complexity.rb +33 -7
  211. data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +74 -33
  212. data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +34 -8
  213. data/lib/rubocop/cop/mixin/negative_conditional.rb +4 -1
  214. data/lib/rubocop/cop/mixin/ordered_gem_node.rb +67 -0
  215. data/lib/rubocop/cop/mixin/parentheses.rb +12 -0
  216. data/lib/rubocop/cop/mixin/parser_diagnostic.rb +4 -1
  217. data/lib/rubocop/cop/mixin/percent_array.rb +52 -0
  218. data/lib/rubocop/cop/mixin/space_after_punctuation.rb +9 -8
  219. data/lib/rubocop/cop/mixin/space_before_punctuation.rb +11 -10
  220. data/lib/rubocop/cop/mixin/statement_modifier.rb +7 -17
  221. data/lib/rubocop/cop/mixin/string_help.rb +1 -1
  222. data/lib/rubocop/cop/mixin/string_literals_help.rb +1 -1
  223. data/lib/rubocop/cop/mixin/surrounding_space.rb +95 -8
  224. data/lib/rubocop/cop/mixin/too_many_lines.rb +2 -2
  225. data/lib/rubocop/cop/mixin/trailing_comma.rb +25 -17
  226. data/lib/rubocop/cop/mixin/unused_argument.rb +6 -2
  227. data/lib/rubocop/cop/naming/accessor_method_name.rb +55 -0
  228. data/lib/rubocop/cop/{style → naming}/ascii_identifiers.rb +35 -2
  229. data/lib/rubocop/cop/{style/op_method.rb → naming/binary_operator_parameter_name.rb} +7 -6
  230. data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +33 -0
  231. data/lib/rubocop/cop/naming/constant_name.rb +58 -0
  232. data/lib/rubocop/cop/{style → naming}/file_name.rb +28 -13
  233. data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +62 -0
  234. data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +59 -0
  235. data/lib/rubocop/cop/naming/method_name.rb +40 -0
  236. data/lib/rubocop/cop/naming/predicate_name.rb +101 -0
  237. data/lib/rubocop/cop/naming/variable_name.rb +50 -0
  238. data/lib/rubocop/cop/{style → naming}/variable_number.rb +11 -28
  239. data/lib/rubocop/cop/offense.rb +6 -1
  240. data/lib/rubocop/cop/performance/caller.rb +39 -11
  241. data/lib/rubocop/cop/performance/case_when_splat.rb +3 -7
  242. data/lib/rubocop/cop/performance/casecmp.rb +9 -8
  243. data/lib/rubocop/cop/performance/compare_with_block.rb +23 -13
  244. data/lib/rubocop/cop/performance/count.rb +7 -4
  245. data/lib/rubocop/cop/performance/detect.rb +9 -6
  246. data/lib/rubocop/cop/performance/double_start_end_with.rb +12 -20
  247. data/lib/rubocop/cop/performance/end_with.rb +6 -6
  248. data/lib/rubocop/cop/performance/fixed_size.rb +1 -1
  249. data/lib/rubocop/cop/performance/flat_map.rb +5 -2
  250. data/lib/rubocop/cop/performance/hash_each_methods.rb +85 -40
  251. data/lib/rubocop/cop/performance/lstrip_rstrip.rb +9 -6
  252. data/lib/rubocop/cop/performance/range_include.rb +3 -3
  253. data/lib/rubocop/cop/performance/redundant_block_call.rb +28 -28
  254. data/lib/rubocop/cop/performance/redundant_match.rb +13 -12
  255. data/lib/rubocop/cop/performance/redundant_merge.rb +44 -26
  256. data/lib/rubocop/cop/performance/redundant_sort_by.rb +9 -6
  257. data/lib/rubocop/cop/performance/regexp_match.rb +19 -10
  258. data/lib/rubocop/cop/performance/reverse_each.rb +1 -1
  259. data/lib/rubocop/cop/performance/sample.rb +1 -1
  260. data/lib/rubocop/cop/performance/size.rb +3 -3
  261. data/lib/rubocop/cop/performance/start_with.rb +6 -6
  262. data/lib/rubocop/cop/performance/string_replacement.rb +6 -6
  263. data/lib/rubocop/cop/performance/times_map.rb +32 -22
  264. data/lib/rubocop/cop/performance/unfreeze_string.rb +50 -0
  265. data/lib/rubocop/cop/performance/uri_default_parser.rb +47 -0
  266. data/lib/rubocop/cop/rails/action_filter.rb +23 -1
  267. data/lib/rubocop/cop/rails/active_support_aliases.rb +4 -5
  268. data/lib/rubocop/cop/rails/application_job.rb +5 -3
  269. data/lib/rubocop/cop/rails/application_record.rb +5 -3
  270. data/lib/rubocop/cop/rails/blank.rb +20 -17
  271. data/lib/rubocop/cop/rails/create_table_with_timestamps.rb +82 -0
  272. data/lib/rubocop/cop/rails/date.rb +7 -6
  273. data/lib/rubocop/cop/rails/delegate.rb +53 -29
  274. data/lib/rubocop/cop/rails/delegate_allow_blank.rb +4 -4
  275. data/lib/rubocop/cop/rails/dynamic_find_by.rb +2 -2
  276. data/lib/rubocop/cop/rails/enum_uniqueness.rb +4 -4
  277. data/lib/rubocop/cop/rails/environment_comparison.rb +66 -0
  278. data/lib/rubocop/cop/rails/exit.rb +8 -1
  279. data/lib/rubocop/cop/rails/file_path.rb +8 -11
  280. data/lib/rubocop/cop/rails/find_by.rb +2 -1
  281. data/lib/rubocop/cop/rails/find_each.rb +1 -1
  282. data/lib/rubocop/cop/rails/has_and_belongs_to_many.rb +8 -1
  283. data/lib/rubocop/cop/rails/has_many_or_has_one_dependent.rb +76 -0
  284. data/lib/rubocop/cop/rails/http_positional_arguments.rb +40 -44
  285. data/lib/rubocop/cop/rails/inverse_of.rb +96 -0
  286. data/lib/rubocop/cop/rails/lexically_scoped_action_filter.rb +112 -0
  287. data/lib/rubocop/cop/rails/not_null_column.rb +6 -6
  288. data/lib/rubocop/cop/rails/output.rb +11 -2
  289. data/lib/rubocop/cop/rails/output_safety.rb +16 -21
  290. data/lib/rubocop/cop/rails/pluralization_grammar.rb +10 -10
  291. data/lib/rubocop/cop/rails/presence.rb +105 -0
  292. data/lib/rubocop/cop/rails/present.rb +14 -17
  293. data/lib/rubocop/cop/rails/read_write_attribute.rb +13 -13
  294. data/lib/rubocop/cop/rails/redundant_receiver_in_with_options.rb +91 -0
  295. data/lib/rubocop/cop/rails/relative_date_constant.rb +11 -11
  296. data/lib/rubocop/cop/rails/request_referer.rb +3 -3
  297. data/lib/rubocop/cop/rails/reversible_migration.rb +36 -35
  298. data/lib/rubocop/cop/rails/safe_navigation.rb +7 -8
  299. data/lib/rubocop/cop/rails/save_bang.rb +19 -17
  300. data/lib/rubocop/cop/rails/scope_args.rb +2 -2
  301. data/lib/rubocop/cop/rails/skips_model_validations.rb +2 -2
  302. data/lib/rubocop/cop/rails/time_zone.rb +3 -2
  303. data/lib/rubocop/cop/rails/uniq_before_pluck.rb +4 -2
  304. data/lib/rubocop/cop/rails/unknown_env.rb +63 -0
  305. data/lib/rubocop/cop/rails/validation.rb +8 -8
  306. data/lib/rubocop/cop/registry.rb +2 -1
  307. data/lib/rubocop/cop/security/eval.rb +4 -4
  308. data/lib/rubocop/cop/security/json_load.rb +7 -5
  309. data/lib/rubocop/cop/security/marshal_load.rb +8 -6
  310. data/lib/rubocop/cop/security/yaml_load.rb +4 -4
  311. data/lib/rubocop/cop/style/alias.rb +49 -27
  312. data/lib/rubocop/cop/style/and_or.rb +65 -45
  313. data/lib/rubocop/cop/style/array_join.rb +10 -1
  314. data/lib/rubocop/cop/style/ascii_comments.rb +24 -4
  315. data/lib/rubocop/cop/style/attr.rb +15 -5
  316. data/lib/rubocop/cop/style/auto_resource_cleanup.rb +7 -5
  317. data/lib/rubocop/cop/style/bare_percent_literals.rb +31 -10
  318. data/lib/rubocop/cop/style/begin_block.rb +1 -1
  319. data/lib/rubocop/cop/style/block_comments.rb +17 -3
  320. data/lib/rubocop/cop/style/block_delimiters.rb +82 -16
  321. data/lib/rubocop/cop/style/braces_around_hash_parameters.rb +68 -32
  322. data/lib/rubocop/cop/style/case_equality.rb +13 -1
  323. data/lib/rubocop/cop/style/character_literal.rb +10 -0
  324. data/lib/rubocop/cop/style/class_and_module_children.rb +8 -4
  325. data/lib/rubocop/cop/style/class_check.rb +29 -10
  326. data/lib/rubocop/cop/style/class_methods.rb +10 -9
  327. data/lib/rubocop/cop/style/class_vars.rb +5 -4
  328. data/lib/rubocop/cop/style/collection_methods.rb +5 -3
  329. data/lib/rubocop/cop/style/colon_method_call.rb +18 -2
  330. data/lib/rubocop/cop/style/colon_method_definition.rb +36 -0
  331. data/lib/rubocop/cop/style/command_literal.rb +90 -30
  332. data/lib/rubocop/cop/style/comment_annotation.rb +39 -11
  333. data/lib/rubocop/cop/style/commented_keyword.rb +84 -0
  334. data/lib/rubocop/cop/style/conditional_assignment.rb +41 -41
  335. data/lib/rubocop/cop/style/copyright.rb +27 -28
  336. data/lib/rubocop/cop/style/date_time.rb +44 -0
  337. data/lib/rubocop/cop/style/def_with_parentheses.rb +31 -5
  338. data/lib/rubocop/cop/style/dir.rb +48 -0
  339. data/lib/rubocop/cop/style/documentation.rb +17 -2
  340. data/lib/rubocop/cop/style/documentation_method.rb +2 -6
  341. data/lib/rubocop/cop/style/double_negation.rb +1 -1
  342. data/lib/rubocop/cop/style/each_for_simple_loop.rb +8 -8
  343. data/lib/rubocop/cop/style/each_with_object.rb +6 -5
  344. data/lib/rubocop/cop/style/empty_block_parameter.rb +47 -0
  345. data/lib/rubocop/cop/style/empty_case_condition.rb +3 -3
  346. data/lib/rubocop/cop/style/empty_else.rb +55 -24
  347. data/lib/rubocop/cop/style/empty_lambda_parameter.rb +43 -0
  348. data/lib/rubocop/cop/style/empty_literal.rb +25 -14
  349. data/lib/rubocop/cop/style/empty_method.rb +29 -25
  350. data/lib/rubocop/cop/style/encoding.rb +8 -51
  351. data/lib/rubocop/cop/style/end_block.rb +1 -1
  352. data/lib/rubocop/cop/style/eval_with_location.rb +146 -0
  353. data/lib/rubocop/cop/style/even_odd.rb +4 -2
  354. data/lib/rubocop/cop/style/extend_self.rb +92 -0
  355. data/lib/rubocop/cop/style/flip_flop.rb +13 -2
  356. data/lib/rubocop/cop/style/for.rb +6 -2
  357. data/lib/rubocop/cop/style/format_string.rb +33 -5
  358. data/lib/rubocop/cop/style/format_string_token.rb +17 -15
  359. data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +7 -6
  360. data/lib/rubocop/cop/style/global_vars.rb +12 -2
  361. data/lib/rubocop/cop/style/guard_clause.rb +6 -4
  362. data/lib/rubocop/cop/style/hash_syntax.rb +56 -56
  363. data/lib/rubocop/cop/style/identical_conditional_branches.rb +12 -8
  364. data/lib/rubocop/cop/style/if_inside_else.rb +11 -11
  365. data/lib/rubocop/cop/style/if_unless_modifier.rb +8 -7
  366. data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +3 -2
  367. data/lib/rubocop/cop/style/if_with_semicolon.rb +10 -1
  368. data/lib/rubocop/cop/style/implicit_runtime_error.rb +7 -6
  369. data/lib/rubocop/cop/style/infinite_loop.rb +4 -4
  370. data/lib/rubocop/cop/style/inline_comment.rb +1 -1
  371. data/lib/rubocop/cop/style/inverse_methods.rb +24 -14
  372. data/lib/rubocop/cop/style/lambda.rb +45 -43
  373. data/lib/rubocop/cop/style/lambda_call.rb +37 -10
  374. data/lib/rubocop/cop/style/line_end_concatenation.rb +5 -5
  375. data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +3 -19
  376. data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +6 -4
  377. data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +1 -1
  378. data/lib/rubocop/cop/style/method_def_parentheses.rb +20 -25
  379. data/lib/rubocop/cop/style/method_missing.rb +13 -26
  380. data/lib/rubocop/cop/style/min_max.rb +68 -0
  381. data/lib/rubocop/cop/style/missing_else.rb +20 -6
  382. data/lib/rubocop/cop/style/mixin_grouping.rb +31 -21
  383. data/lib/rubocop/cop/style/mixin_usage.rb +71 -0
  384. data/lib/rubocop/cop/style/module_function.rb +27 -11
  385. data/lib/rubocop/cop/style/multiline_block_chain.rb +1 -1
  386. data/lib/rubocop/cop/style/multiline_if_modifier.rb +8 -4
  387. data/lib/rubocop/cop/style/multiline_if_then.rb +15 -13
  388. data/lib/rubocop/cop/style/multiline_memoization.rb +33 -17
  389. data/lib/rubocop/cop/style/multiline_ternary_operator.rb +1 -1
  390. data/lib/rubocop/cop/style/multiple_comparison.rb +1 -1
  391. data/lib/rubocop/cop/style/mutable_constant.rb +11 -15
  392. data/lib/rubocop/cop/style/negated_if.rb +27 -31
  393. data/lib/rubocop/cop/style/negated_while.rb +1 -5
  394. data/lib/rubocop/cop/style/nested_modifier.rb +1 -1
  395. data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +26 -23
  396. data/lib/rubocop/cop/style/nested_ternary_operator.rb +1 -1
  397. data/lib/rubocop/cop/style/next.rb +41 -12
  398. data/lib/rubocop/cop/style/nil_comparison.rb +8 -8
  399. data/lib/rubocop/cop/style/non_nil_check.rb +41 -38
  400. data/lib/rubocop/cop/style/not.rb +15 -5
  401. data/lib/rubocop/cop/style/numeric_literal_prefix.rb +8 -4
  402. data/lib/rubocop/cop/style/numeric_literals.rb +9 -9
  403. data/lib/rubocop/cop/style/numeric_predicate.rb +21 -21
  404. data/lib/rubocop/cop/style/one_line_conditional.rb +9 -4
  405. data/lib/rubocop/cop/style/option_hash.rb +11 -25
  406. data/lib/rubocop/cop/style/optional_arguments.rb +1 -2
  407. data/lib/rubocop/cop/style/or_assignment.rb +88 -0
  408. data/lib/rubocop/cop/style/parallel_assignment.rb +16 -16
  409. data/lib/rubocop/cop/style/parentheses_around_condition.rb +30 -13
  410. data/lib/rubocop/cop/style/percent_literal_delimiters.rb +25 -4
  411. data/lib/rubocop/cop/style/percent_q_literals.rb +29 -8
  412. data/lib/rubocop/cop/style/perl_backrefs.rb +8 -1
  413. data/lib/rubocop/cop/style/preferred_hash_methods.rb +7 -11
  414. data/lib/rubocop/cop/style/proc.rb +10 -2
  415. data/lib/rubocop/cop/style/raise_args.rb +22 -29
  416. data/lib/rubocop/cop/style/random_with_offset.rb +160 -0
  417. data/lib/rubocop/cop/style/redundant_begin.rb +16 -5
  418. data/lib/rubocop/cop/style/redundant_conditional.rb +96 -0
  419. data/lib/rubocop/cop/style/redundant_exception.rb +4 -4
  420. data/lib/rubocop/cop/style/redundant_freeze.rb +1 -1
  421. data/lib/rubocop/cop/style/redundant_parentheses.rb +14 -12
  422. data/lib/rubocop/cop/style/redundant_return.rb +28 -15
  423. data/lib/rubocop/cop/style/redundant_self.rb +35 -27
  424. data/lib/rubocop/cop/style/regexp_literal.rb +88 -27
  425. data/lib/rubocop/cop/style/rescue_modifier.rb +12 -1
  426. data/lib/rubocop/cop/style/rescue_standard_error.rb +122 -0
  427. data/lib/rubocop/cop/style/return_nil.rb +89 -0
  428. data/lib/rubocop/cop/style/safe_navigation.rb +100 -48
  429. data/lib/rubocop/cop/style/self_assignment.rb +13 -13
  430. data/lib/rubocop/cop/style/semicolon.rb +19 -9
  431. data/lib/rubocop/cop/style/send.rb +10 -1
  432. data/lib/rubocop/cop/style/signal_exception.rb +104 -3
  433. data/lib/rubocop/cop/style/single_line_block_params.rb +16 -15
  434. data/lib/rubocop/cop/style/single_line_methods.rb +26 -18
  435. data/lib/rubocop/cop/style/special_global_vars.rb +19 -14
  436. data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +23 -50
  437. data/lib/rubocop/cop/style/stderr_puts.rb +54 -0
  438. data/lib/rubocop/cop/style/string_hash_keys.rb +36 -0
  439. data/lib/rubocop/cop/style/string_literals.rb +26 -3
  440. data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +16 -1
  441. data/lib/rubocop/cop/style/string_methods.rb +19 -8
  442. data/lib/rubocop/cop/style/struct_inheritance.rb +3 -3
  443. data/lib/rubocop/cop/style/symbol_array.rb +7 -35
  444. data/lib/rubocop/cop/style/symbol_literal.rb +1 -1
  445. data/lib/rubocop/cop/style/symbol_proc.rb +11 -25
  446. data/lib/rubocop/cop/style/ternary_parentheses.rb +46 -51
  447. data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +101 -0
  448. data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +20 -6
  449. data/lib/rubocop/cop/style/trailing_comma_in_literal.rb +22 -7
  450. data/lib/rubocop/cop/style/trailing_method_end_statement.rb +95 -0
  451. data/lib/rubocop/cop/style/trailing_underscore_variable.rb +70 -24
  452. data/lib/rubocop/cop/style/trivial_accessors.rb +72 -65
  453. data/lib/rubocop/cop/style/unless_else.rb +16 -1
  454. data/lib/rubocop/cop/style/unneeded_capital_w.rb +18 -8
  455. data/lib/rubocop/cop/style/unneeded_interpolation.rb +15 -19
  456. data/lib/rubocop/cop/style/unneeded_percent_q.rb +14 -13
  457. data/lib/rubocop/cop/style/variable_interpolation.rb +23 -9
  458. data/lib/rubocop/cop/style/when_then.rb +14 -1
  459. data/lib/rubocop/cop/style/while_until_do.rb +27 -4
  460. data/lib/rubocop/cop/style/while_until_modifier.rb +26 -6
  461. data/lib/rubocop/cop/style/word_array.rb +9 -30
  462. data/lib/rubocop/cop/style/yoda_condition.rb +51 -22
  463. data/lib/rubocop/cop/style/zero_length_predicate.rb +44 -29
  464. data/lib/rubocop/cop/team.rb +16 -8
  465. data/lib/rubocop/cop/util.rb +43 -34
  466. data/lib/rubocop/cop/variable_force.rb +1 -1
  467. data/lib/rubocop/cop/variable_force/assignment.rb +4 -2
  468. data/lib/rubocop/cop/variable_force/scope.rb +1 -5
  469. data/lib/rubocop/cop/variable_force/variable.rb +1 -1
  470. data/lib/rubocop/formatter/disabled_config_formatter.rb +3 -4
  471. data/lib/rubocop/formatter/formatter_set.rb +3 -1
  472. data/lib/rubocop/formatter/html_formatter.rb +1 -1
  473. data/lib/rubocop/formatter/json_formatter.rb +9 -3
  474. data/lib/rubocop/formatter/offense_count_formatter.rb +2 -0
  475. data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
  476. data/lib/rubocop/formatter/simple_text_formatter.rb +3 -3
  477. data/lib/rubocop/formatter/tap_formatter.rb +71 -0
  478. data/lib/rubocop/formatter/worst_offenders_formatter.rb +2 -0
  479. data/lib/rubocop/node_pattern.rb +46 -29
  480. data/lib/rubocop/options.rb +13 -8
  481. data/lib/rubocop/path_util.rb +15 -3
  482. data/lib/rubocop/processed_source.rb +8 -9
  483. data/lib/rubocop/rake_task.rb +16 -23
  484. data/lib/rubocop/remote_config.rb +13 -1
  485. data/lib/rubocop/result_cache.rb +1 -0
  486. data/lib/rubocop/rspec/cop_helper.rb +10 -10
  487. data/lib/rubocop/rspec/expect_offense.rb +6 -8
  488. data/lib/rubocop/rspec/shared_contexts.rb +4 -8
  489. data/lib/rubocop/rspec/shared_examples.rb +8 -8
  490. data/lib/rubocop/rspec/support.rb +5 -5
  491. data/lib/rubocop/runner.rb +1 -1
  492. data/lib/rubocop/string_util.rb +2 -0
  493. data/lib/rubocop/token.rb +74 -0
  494. data/lib/rubocop/version.rb +1 -1
  495. metadata +118 -48
  496. data/lib/rubocop/cop/layout/space_inside_brackets.rb +0 -20
  497. data/lib/rubocop/cop/lint/invalid_character_literal.rb +0 -41
  498. data/lib/rubocop/cop/mixin/access_modifier_node.rb +0 -41
  499. data/lib/rubocop/cop/mixin/on_method_def.rb +0 -44
  500. data/lib/rubocop/cop/mixin/space_inside.rb +0 -76
  501. data/lib/rubocop/cop/style/accessor_method_name.rb +0 -45
  502. data/lib/rubocop/cop/style/class_and_module_camel_case.rb +0 -29
  503. data/lib/rubocop/cop/style/constant_name.rb +0 -29
  504. data/lib/rubocop/cop/style/method_name.rb +0 -34
  505. data/lib/rubocop/cop/style/predicate_name.rb +0 -67
  506. data/lib/rubocop/cop/style/variable_name.rb +0 -39
@@ -5,10 +5,14 @@ module RuboCop
5
5
  module PathUtil
6
6
  module_function
7
7
 
8
- def relative_path(path, base_dir = Dir.pwd)
8
+ def relative_path(path, base_dir = PathUtil.pwd)
9
9
  # Optimization for the common case where path begins with the base
10
10
  # dir. Just cut off the first part.
11
- return path[(base_dir.length + 1)..-1] if path.start_with?(base_dir)
11
+ if path.start_with?(base_dir)
12
+ base_dir_length = base_dir.length
13
+ result_length = path.length - base_dir_length - 1
14
+ return path[base_dir_length + 1, result_length]
15
+ end
12
16
 
13
17
  path_name = Pathname.new(File.expand_path(path))
14
18
  path_name.relative_path_from(Pathname.new(base_dir)).to_s
@@ -16,7 +20,7 @@ module RuboCop
16
20
 
17
21
  def smart_path(path)
18
22
  # Ideally, we calculate this relative to the project root.
19
- base_dir = Dir.pwd
23
+ base_dir = PathUtil.pwd
20
24
 
21
25
  if path.start_with? base_dir
22
26
  relative_path(path, base_dir)
@@ -43,5 +47,13 @@ module RuboCop
43
47
  def absolute?(path)
44
48
  path =~ %r{\A([A-Z]:)?/}
45
49
  end
50
+
51
+ def self.pwd
52
+ @pwd ||= Dir.pwd
53
+ end
54
+
55
+ def self.reset_pwd
56
+ @pwd = nil
57
+ end
46
58
  end
47
59
  end
@@ -54,7 +54,7 @@ module RuboCop
54
54
  def lines
55
55
  @lines ||= begin
56
56
  all_lines = @buffer.source_lines
57
- last_token_line = tokens.any? ? tokens.last.pos.line : all_lines.size
57
+ last_token_line = tokens.any? ? tokens.last.line : all_lines.size
58
58
  result = []
59
59
  all_lines.each_with_index do |line, ix|
60
60
  break if ix >= last_token_line && line == '__END__'
@@ -107,14 +107,9 @@ module RuboCop
107
107
  [ast, comments, tokens]
108
108
  end
109
109
 
110
- def parser_class(ruby_version) # rubocop:disable Metrics/MethodLength
110
+ # rubocop:disable Metrics/MethodLength
111
+ def parser_class(ruby_version)
111
112
  case ruby_version
112
- when 1.9
113
- require 'parser/ruby19'
114
- Parser::Ruby19
115
- when 2.0
116
- require 'parser/ruby20'
117
- Parser::Ruby20
118
113
  when 2.1
119
114
  require 'parser/ruby21'
120
115
  Parser::Ruby21
@@ -127,16 +122,20 @@ module RuboCop
127
122
  when 2.4
128
123
  require 'parser/ruby24'
129
124
  Parser::Ruby24
125
+ when 2.5
126
+ require 'parser/ruby25'
127
+ Parser::Ruby25
130
128
  else
131
129
  raise ArgumentError, "Unknown Ruby version: #{ruby_version.inspect}"
132
130
  end
133
131
  end
132
+ # rubocop:enable Metrics/MethodLength
134
133
 
135
134
  def create_parser(ruby_version)
136
135
  builder = RuboCop::AST::Builder.new
137
136
 
138
137
  parser_class(ruby_version).new(builder).tap do |parser|
139
- # On JRuby and Rubinius, there's a risk that we hang in tokenize() if we
138
+ # On JRuby there's a risk that we hang in tokenize() if we
140
139
  # don't set the all errors as fatal flag. The problem is caused by a bug
141
140
  # in Racc that is discussed in issue #93 of the whitequark/parser
142
141
  # project on GitHub.
@@ -17,25 +17,21 @@ module RuboCop
17
17
  attr_accessor :requires
18
18
  attr_accessor :options
19
19
 
20
- def initialize(*args, &task_block)
21
- setup_ivars(args)
20
+ def initialize(name = :rubocop, *args, &task_block)
21
+ setup_ivars(name)
22
22
 
23
23
  desc 'Run RuboCop' unless ::Rake.application.last_description
24
24
 
25
25
  task(name, *args) do |_, task_args|
26
- RakeFileUtils.send(:verbose, verbose) do
26
+ RakeFileUtils.verbose(verbose) do
27
27
  yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
28
- run_main_task(verbose)
28
+ run_cli(verbose, full_options)
29
29
  end
30
30
  end
31
31
 
32
32
  setup_subtasks(name, *args, &task_block)
33
33
  end
34
34
 
35
- def run_main_task(verbose)
36
- run_cli(verbose, full_options)
37
- end
38
-
39
35
  private
40
36
 
41
37
  def run_cli(verbose, options)
@@ -50,19 +46,14 @@ module RuboCop
50
46
  end
51
47
 
52
48
  def full_options
53
- [].tap do |result|
54
- result.concat(formatters.map { |f| ['--format', f] }.flatten)
55
- result.concat(requires.map { |r| ['--require', r] }.flatten)
56
- result.concat(options.flatten)
57
- result.concat(patterns)
58
- end
49
+ formatters.map { |f| ['--format', f] }.flatten
50
+ .concat(requires.map { |r| ['--require', r] }.flatten)
51
+ .concat(options.flatten)
52
+ .concat(patterns)
59
53
  end
60
54
 
61
- def setup_ivars(args)
62
- # More lazy-loading to keep load time down.
63
- require 'rubocop/options'
64
-
65
- @name = args.shift || :rubocop
55
+ def setup_ivars(name)
56
+ @name = name
66
57
  @verbose = true
67
58
  @fail_on_error = true
68
59
  @patterns = []
@@ -72,13 +63,15 @@ module RuboCop
72
63
  end
73
64
 
74
65
  def setup_subtasks(name, *args, &task_block)
75
- namespace name do
66
+ namespace(name) do
76
67
  desc 'Auto-correct RuboCop offenses'
77
68
 
78
69
  task(:auto_correct, *args) do |_, task_args|
79
- yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
80
- options = full_options.unshift('--auto-correct')
81
- run_cli(verbose, options)
70
+ RakeFileUtils.verbose(verbose) do
71
+ yield(*[self, task_args].slice(0, task_block.arity)) if block_given?
72
+ options = full_options.unshift('--auto-correct')
73
+ run_cli(verbose, options)
74
+ end
82
75
  end
83
76
  end
84
77
  end
@@ -6,6 +6,8 @@ require 'time'
6
6
  module RuboCop
7
7
  # Common methods and behaviors for dealing with remote config files.
8
8
  class RemoteConfig
9
+ attr_reader :uri
10
+
9
11
  CACHE_LIFETIME = 24 * 60 * 60
10
12
 
11
13
  def initialize(url, base_dir)
@@ -17,6 +19,8 @@ module RuboCop
17
19
  return cache_path unless cache_path_expired?
18
20
 
19
21
  request do |response|
22
+ next if response.is_a?(Net::HTTPNotModified)
23
+ next if response.is_a?(SocketError)
20
24
  open cache_path, 'w' do |io|
21
25
  io.write response.body
22
26
  end
@@ -25,6 +29,12 @@ module RuboCop
25
29
  cache_path
26
30
  end
27
31
 
32
+ def inherit_from_remote(file, path)
33
+ new_uri = @uri.dup
34
+ new_uri.path.gsub!(%r{/[^/]*$}, "/#{file}")
35
+ RemoteConfig.new(new_uri.to_s, File.dirname(path))
36
+ end
37
+
28
38
  private
29
39
 
30
40
  def request(uri = @uri, limit = 10, &block)
@@ -39,11 +49,13 @@ module RuboCop
39
49
  end
40
50
 
41
51
  handle_response(http.request(request), limit, &block)
52
+ rescue SocketError => err
53
+ handle_response(err, limit, &block)
42
54
  end
43
55
 
44
56
  def handle_response(response, limit, &block)
45
57
  case response
46
- when Net::HTTPSuccess
58
+ when Net::HTTPSuccess, Net::HTTPNotModified, SocketError
47
59
  yield response
48
60
  when Net::HTTPRedirection
49
61
  request(URI.parse(response['location']), limit - 1, &block)
@@ -133,6 +133,7 @@ module RuboCop
133
133
 
134
134
  def file_checksum(file, config_store)
135
135
  Digest::MD5.hexdigest(Dir.pwd + file + IO.read(file) +
136
+ File.stat(file).mode.to_s +
136
137
  config_store.for(file).to_s)
137
138
  rescue Errno::ENOENT
138
139
  # Spurious files that come and go should not cause a crash, at least not
@@ -10,15 +10,15 @@ module CopHelper
10
10
  let(:enabled_rails) { false }
11
11
  let(:rails_version) { false }
12
12
 
13
- def inspect_source_file(cop, source)
14
- Tempfile.open('tmp') { |f| inspect_source(cop, source, f) }
13
+ def inspect_source_file(source)
14
+ Tempfile.open('tmp') { |f| inspect_source(source, f) }
15
15
  end
16
16
 
17
- def inspect_gemfile(cop, source)
18
- inspect_source(cop, source, 'Gemfile')
17
+ def inspect_gemfile(source)
18
+ inspect_source(source, 'Gemfile')
19
19
  end
20
20
 
21
- def inspect_source(cop, source, file = nil)
21
+ def inspect_source(source, file = nil)
22
22
  if source.is_a?(Array) && source.size == 1
23
23
  raise "Don't use an array for a single line of code: #{source}"
24
24
  end
@@ -41,11 +41,11 @@ module CopHelper
41
41
  RuboCop::ProcessedSource.new(source, ruby_version, file)
42
42
  end
43
43
 
44
- def autocorrect_source_file(cop, source)
45
- Tempfile.open('tmp') { |f| autocorrect_source(cop, source, f) }
44
+ def autocorrect_source_file(source)
45
+ Tempfile.open('tmp') { |f| autocorrect_source(source, f) }
46
46
  end
47
47
 
48
- def autocorrect_source(cop, source, file = nil)
48
+ def autocorrect_source(source, file = nil)
49
49
  cop.instance_variable_get(:@options)[:auto_correct] = true
50
50
  processed_source = parse_source(source, file)
51
51
  _investigate(cop, processed_source)
@@ -55,10 +55,10 @@ module CopHelper
55
55
  corrector.rewrite
56
56
  end
57
57
 
58
- def autocorrect_source_with_loop(cop, source, file = nil)
58
+ def autocorrect_source_with_loop(source, file = nil)
59
59
  loop do
60
60
  cop.instance_variable_set(:@corrections, [])
61
- new_source = autocorrect_source(cop, source, file)
61
+ new_source = autocorrect_source(source, file)
62
62
  return new_source if new_source == source
63
63
  source = new_source
64
64
  end
@@ -23,7 +23,7 @@ module RuboCop
23
23
  #
24
24
  # @example Equivalent assertion without `expect_offense`
25
25
  #
26
- # inspect_source(cop, <<-RUBY.strip_indent)
26
+ # inspect_source(<<-RUBY.strip_indent)
27
27
  # a do
28
28
  # b
29
29
  # end.c
@@ -44,23 +44,21 @@ module RuboCop
44
44
  # that there were no offenses. The `expect_offenses` method has
45
45
  # to do more work by parsing out lines that contain carets.
46
46
  module ExpectOffense
47
- DEFAULT_FILENAME = 'example.rb'.freeze
48
-
49
- def expect_offense(source, filename = DEFAULT_FILENAME)
47
+ def expect_offense(source, file = nil)
50
48
  expected_annotations = AnnotatedSource.parse(source)
51
49
 
52
50
  if expected_annotations.plain_source == source
53
51
  raise 'Use expect_no_offenses to assert that no offenses are found'
54
52
  end
55
53
 
56
- inspect_source(cop, expected_annotations.plain_source, filename)
54
+ inspect_source(expected_annotations.plain_source, file)
57
55
  actual_annotations =
58
56
  expected_annotations.with_offense_annotations(cop.offenses)
59
- expect(expected_annotations.to_s).to eq(actual_annotations.to_s)
57
+ expect(actual_annotations.to_s).to eq(expected_annotations.to_s)
60
58
  end
61
59
 
62
- def expect_no_offenses(source, filename = DEFAULT_FILENAME)
63
- inspect_source(cop, source, filename)
60
+ def expect_no_offenses(source, file = nil)
61
+ inspect_source(source, file)
64
62
 
65
63
  expect(cop.offenses).to be_empty
66
64
  end
@@ -57,14 +57,6 @@ shared_context 'config', :config do
57
57
  end
58
58
  end
59
59
 
60
- shared_context 'ruby 1.9', :ruby19 do
61
- let(:ruby_version) { 1.9 }
62
- end
63
-
64
- shared_context 'ruby 2.0', :ruby20 do
65
- let(:ruby_version) { 2.0 }
66
- end
67
-
68
60
  shared_context 'ruby 2.1', :ruby21 do
69
61
  let(:ruby_version) { 2.1 }
70
62
  end
@@ -81,6 +73,10 @@ shared_context 'ruby 2.4', :ruby24 do
81
73
  let(:ruby_version) { 2.4 }
82
74
  end
83
75
 
76
+ shared_context 'ruby 2.5', :ruby25 do
77
+ let(:ruby_version) { 2.5 }
78
+ end
79
+
84
80
  shared_context 'with Rails', :enabled_rails do
85
81
  let(:enabled_rails) { true }
86
82
  end
@@ -4,7 +4,7 @@
4
4
 
5
5
  shared_examples_for 'accepts' do
6
6
  it 'accepts' do
7
- inspect_source(cop, source)
7
+ inspect_source(source)
8
8
  expect(cop.offenses).to be_empty
9
9
  end
10
10
  end
@@ -12,7 +12,7 @@ end
12
12
  shared_examples_for 'mimics MRI 2.1' do |grep_mri_warning|
13
13
  if RUBY_ENGINE == 'ruby' && RUBY_VERSION.start_with?('2.1')
14
14
  it "mimics MRI #{RUBY_VERSION} built-in syntax checking" do
15
- inspect_source(cop, source)
15
+ inspect_source(source)
16
16
  offenses_by_mri = MRISyntaxChecker.offenses_for_source(
17
17
  source, cop.name, grep_mri_warning
18
18
  )
@@ -38,7 +38,7 @@ shared_examples_for 'misaligned' do |prefix, alignment_base, arg, end_kw, name|
38
38
  end_kw]
39
39
 
40
40
  it "registers an offense for mismatched #{name} ... end" do
41
- inspect_source(cop, source)
41
+ inspect_source(source)
42
42
  expect(cop.offenses.size).to eq(1)
43
43
  base_regexp = Regexp.escape(alignment_base)
44
44
  regexp = /`end` at 2, \d+ is not aligned with `#{base_regexp}` at 1,/
@@ -58,7 +58,7 @@ shared_examples_for 'misaligned' do |prefix, alignment_base, arg, end_kw, name|
58
58
  it "auto-corrects mismatched #{name} ... end" do
59
59
  aligned_source = ["#{prefix}#{alignment_base} #{arg}",
60
60
  "#{' ' * prefix.length}#{end_kw.strip}"].join("\n")
61
- corrected = autocorrect_source(cop, source)
61
+ corrected = autocorrect_source(source)
62
62
  expect(corrected).to eq(aligned_source)
63
63
  end
64
64
  end
@@ -67,15 +67,15 @@ shared_examples_for 'aligned' do |alignment_base, arg, end_kw, name|
67
67
  name ||= alignment_base
68
68
  name = name.gsub(/\n/, ' <newline>')
69
69
  it "accepts matching #{name} ... end" do
70
- inspect_source(cop, ["#{alignment_base} #{arg}",
71
- end_kw])
70
+ inspect_source(["#{alignment_base} #{arg}",
71
+ end_kw])
72
72
  expect(cop.offenses).to be_empty
73
73
  end
74
74
  end
75
75
 
76
76
  shared_examples_for 'debugger' do |name, src|
77
77
  it "reports an offense for a #{name} call" do
78
- inspect_source(cop, src)
78
+ inspect_source(src)
79
79
  src = [src] if src.is_a? String
80
80
  expect(cop.offenses.size).to eq(src.size)
81
81
  expect(cop.messages)
@@ -86,7 +86,7 @@ end
86
86
 
87
87
  shared_examples_for 'non-debugger' do |name, src|
88
88
  it "does not report an offense for #{name}" do
89
- inspect_source(cop, src)
89
+ inspect_source(src)
90
90
  expect(cop.offenses).to be_empty
91
91
  end
92
92
  end
@@ -2,8 +2,8 @@
2
2
 
3
3
  # Require this file to load code that supports testing using RSpec.
4
4
 
5
- require 'rubocop/rspec/cop_helper'
6
- require 'rubocop/rspec/host_environment_simulation_helper'
7
- require 'rubocop/rspec/shared_contexts'
8
- require 'rubocop/rspec/shared_examples'
9
- require 'rubocop/rspec/expect_offense'
5
+ require_relative 'cop_helper'
6
+ require_relative 'host_environment_simulation_helper'
7
+ require_relative 'shared_contexts'
8
+ require_relative 'shared_examples'
9
+ require_relative 'expect_offense'
@@ -47,7 +47,7 @@ module RuboCop
47
47
  private
48
48
 
49
49
  # Warms up the RuboCop cache by forking a suitable number of rubocop
50
- # instances that each inspects its alotted group of files.
50
+ # instances that each inspects its allotted group of files.
51
51
  def warm_cache(target_files)
52
52
  puts 'Running parallel inspection' if @options[:debug]
53
53
  Parallel.each(target_files, &method(:file_offenses))
@@ -46,6 +46,7 @@ module RuboCop
46
46
  compute_non_zero_distance(matched_count.to_f, transposition_count)
47
47
  end
48
48
 
49
+ # rubocop:disable Metrics/AbcSize
49
50
  def find_common_characters
50
51
  common_chars_of_shorter = Array.new(shorter.size)
51
52
  common_chars_of_longer = Array.new(longer.size)
@@ -68,6 +69,7 @@ module RuboCop
68
69
 
69
70
  [common_chars_of_shorter, common_chars_of_longer].map(&:compact)
70
71
  end
72
+ # rubocop:enable Metrics/AbcSize
71
73
 
72
74
  def count_transpositions(common_chars_a, common_chars_b)
73
75
  common_chars_a.size.times.count do |index|
@@ -18,8 +18,82 @@ module RuboCop
18
18
  @text = text.to_s
19
19
  end
20
20
 
21
+ def line
22
+ pos.line
23
+ end
24
+
25
+ def column
26
+ pos.column
27
+ end
28
+
29
+ def begin_pos
30
+ pos.begin_pos
31
+ end
32
+
33
+ def end_pos
34
+ pos.end_pos
35
+ end
36
+
37
+ def comment?
38
+ type == :tCOMMENT
39
+ end
40
+
41
+ def semicolon?
42
+ type == :tSEMI
43
+ end
44
+
45
+ def left_array_bracket?
46
+ type == :tLBRACK
47
+ end
48
+
49
+ def left_ref_bracket?
50
+ type == :tLBRACK2
51
+ end
52
+
53
+ def right_bracket?
54
+ type == :tRBRACK
55
+ end
56
+
57
+ def left_brace?
58
+ type == :tLBRACE
59
+ end
60
+
61
+ def left_curly_brace?
62
+ type == :tLCURLY
63
+ end
64
+
65
+ def right_curly_brace?
66
+ type == :tRCURLY
67
+ end
68
+
69
+ def left_parens?
70
+ %i[tLPAREN tLPAREN2].include?(type)
71
+ end
72
+
73
+ def right_parens?
74
+ type == :tRPAREN
75
+ end
76
+
77
+ def comma?
78
+ type == :tCOMMA
79
+ end
80
+
81
+ def equal_sign?
82
+ %i[tEQL tOP_ASGN].include?(type)
83
+ end
84
+
21
85
  def to_s
22
86
  "[[#{@pos.line}, #{@pos.column}], #{@type}, #{@text.inspect}]"
23
87
  end
88
+
89
+ # Checks if there is whitespace after token
90
+ def space_after?
91
+ pos.source_buffer.source.match(/\G\s/, end_pos)
92
+ end
93
+
94
+ # Checks if there is whitespace before token
95
+ def space_before?
96
+ pos.source_buffer.source.match(/\G\s/, begin_pos - 1)
97
+ end
24
98
  end
25
99
  end