rubocop 0.89.1 → 0.93.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.
- checksums.yaml +4 -4
- data/README.md +2 -2
- data/config/default.yml +160 -14
- data/lib/rubocop.rb +33 -5
- data/lib/rubocop/cached_data.rb +3 -1
- data/lib/rubocop/cli/command.rb +1 -0
- data/lib/rubocop/cli/command/auto_genenerate_config.rb +1 -0
- data/lib/rubocop/cli/command/base.rb +1 -0
- data/lib/rubocop/cli/command/execute_runner.rb +9 -0
- data/lib/rubocop/cli/command/init_dotfile.rb +1 -0
- data/lib/rubocop/cli/command/show_cops.rb +1 -0
- data/lib/rubocop/cli/command/version.rb +1 -0
- data/lib/rubocop/cli/environment.rb +1 -0
- data/lib/rubocop/comment_config.rb +14 -5
- data/lib/rubocop/config_loader.rb +20 -9
- data/lib/rubocop/config_loader_resolver.rb +1 -0
- data/lib/rubocop/config_obsoletion.rb +1 -0
- data/lib/rubocop/config_regeneration.rb +33 -0
- data/lib/rubocop/config_store.rb +3 -3
- data/lib/rubocop/config_validator.rb +3 -0
- data/lib/rubocop/cop/base.rb +23 -0
- data/lib/rubocop/cop/bundler/duplicated_gem.rb +5 -1
- data/lib/rubocop/cop/bundler/gem_comment.rb +8 -3
- data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +2 -0
- data/lib/rubocop/cop/commissioner.rb +47 -7
- data/lib/rubocop/cop/correctors/alignment_corrector.rb +4 -4
- data/lib/rubocop/cop/correctors/condition_corrector.rb +3 -5
- data/lib/rubocop/cop/correctors/empty_line_corrector.rb +9 -10
- data/lib/rubocop/cop/correctors/line_break_corrector.rb +4 -4
- data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +8 -3
- data/lib/rubocop/cop/correctors/parentheses_corrector.rb +5 -8
- data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +4 -9
- data/lib/rubocop/cop/correctors/punctuation_corrector.rb +8 -10
- data/lib/rubocop/cop/documentation.rb +22 -0
- data/lib/rubocop/cop/gemspec/required_ruby_version.rb +10 -10
- data/lib/rubocop/cop/generator.rb +2 -1
- data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +1 -0
- data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +1 -0
- data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +1 -0
- data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +1 -0
- data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +1 -0
- data/lib/rubocop/cop/layout/array_alignment.rb +1 -0
- data/lib/rubocop/cop/layout/begin_end_alignment.rb +77 -0
- data/lib/rubocop/cop/layout/block_alignment.rb +23 -19
- data/lib/rubocop/cop/layout/case_indentation.rb +4 -7
- data/lib/rubocop/cop/layout/class_structure.rb +11 -10
- data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +4 -6
- data/lib/rubocop/cop/layout/condition_position.rb +13 -15
- data/lib/rubocop/cop/layout/def_end_alignment.rb +8 -5
- data/lib/rubocop/cop/layout/dot_position.rb +21 -20
- data/lib/rubocop/cop/layout/empty_comment.rb +30 -23
- data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +21 -18
- data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +13 -13
- data/lib/rubocop/cop/layout/empty_line_after_multiline_condition.rb +136 -0
- data/lib/rubocop/cop/layout/empty_line_between_defs.rb +21 -23
- data/lib/rubocop/cop/layout/empty_lines.rb +6 -7
- data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +17 -14
- data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +7 -8
- data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +5 -8
- data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +2 -5
- data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +2 -5
- data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +2 -5
- data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +3 -7
- data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +2 -5
- data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +2 -5
- data/lib/rubocop/cop/layout/end_alignment.rb +11 -17
- data/lib/rubocop/cop/layout/first_array_element_line_break.rb +2 -5
- data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +2 -5
- data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +4 -8
- data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +2 -5
- data/lib/rubocop/cop/layout/hash_alignment.rb +17 -20
- data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +15 -14
- data/lib/rubocop/cop/layout/heredoc_indentation.rb +14 -11
- data/lib/rubocop/cop/layout/initial_indentation.rb +6 -7
- data/lib/rubocop/cop/layout/leading_comment_space.rb +11 -9
- data/lib/rubocop/cop/layout/leading_empty_lines.rb +6 -11
- data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +2 -5
- data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +2 -5
- data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +10 -14
- data/lib/rubocop/cop/layout/multiline_block_layout.rb +21 -19
- data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +2 -5
- data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +2 -5
- data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +5 -9
- data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +2 -5
- data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +2 -5
- data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +41 -22
- data/lib/rubocop/cop/layout/space_after_colon.rb +11 -7
- data/lib/rubocop/cop/layout/space_after_comma.rb +2 -5
- data/lib/rubocop/cop/layout/space_after_method_name.rb +5 -6
- data/lib/rubocop/cop/layout/space_after_not.rb +9 -11
- data/lib/rubocop/cop/layout/space_after_semicolon.rb +2 -5
- data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +17 -21
- data/lib/rubocop/cop/layout/space_around_keyword.rb +17 -18
- data/lib/rubocop/cop/layout/space_around_operators.rb +17 -16
- data/lib/rubocop/cop/layout/space_before_block_braces.rb +23 -22
- data/lib/rubocop/cop/layout/space_before_comma.rb +3 -5
- data/lib/rubocop/cop/layout/space_before_comment.rb +10 -7
- data/lib/rubocop/cop/layout/space_before_first_arg.rb +7 -7
- data/lib/rubocop/cop/layout/space_before_semicolon.rb +2 -5
- data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +9 -17
- data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +20 -23
- data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +3 -8
- data/lib/rubocop/cop/layout/space_inside_block_braces.rb +13 -16
- data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +19 -37
- data/lib/rubocop/cop/layout/space_inside_parens.rb +9 -14
- data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +5 -10
- data/lib/rubocop/cop/layout/space_inside_range_literal.rb +8 -17
- data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +16 -24
- data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +12 -13
- data/lib/rubocop/cop/layout/trailing_empty_lines.rb +10 -15
- data/lib/rubocop/cop/layout/trailing_whitespace.rb +11 -11
- data/lib/rubocop/cop/lint/ambiguous_block_association.rb +2 -0
- data/lib/rubocop/cop/lint/ambiguous_operator.rb +2 -0
- data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +15 -1
- data/lib/rubocop/cop/lint/big_decimal_new.rb +1 -2
- data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +1 -1
- data/lib/rubocop/cop/lint/boolean_symbol.rb +3 -0
- data/lib/rubocop/cop/lint/constant_definition_in_block.rb +74 -0
- data/lib/rubocop/cop/lint/constant_resolution.rb +1 -1
- data/lib/rubocop/cop/lint/debugger.rb +2 -3
- data/lib/rubocop/cop/lint/deprecated_class_methods.rb +1 -3
- data/lib/rubocop/cop/lint/duplicate_methods.rb +2 -4
- data/lib/rubocop/cop/lint/duplicate_require.rb +46 -0
- data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +2 -15
- data/lib/rubocop/cop/lint/each_with_object_argument.rb +1 -0
- data/lib/rubocop/cop/lint/empty_file.rb +50 -0
- data/lib/rubocop/cop/lint/erb_new_arguments.rb +2 -0
- data/lib/rubocop/cop/lint/float_comparison.rb +2 -2
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +2 -2
- data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +37 -0
- data/lib/rubocop/cop/lint/identity_comparison.rb +51 -0
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +2 -5
- data/lib/rubocop/cop/lint/inherit_exception.rb +2 -2
- data/lib/rubocop/cop/lint/missing_super.rb +2 -2
- data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +3 -35
- data/lib/rubocop/cop/lint/multiple_comparison.rb +3 -1
- data/lib/rubocop/cop/lint/number_conversion.rb +1 -0
- data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +9 -20
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +1 -1
- data/lib/rubocop/cop/lint/percent_string_array.rb +8 -12
- data/lib/rubocop/cop/lint/raise_exception.rb +1 -0
- data/lib/rubocop/cop/lint/rand_one.rb +2 -1
- data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +22 -12
- data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +14 -4
- data/lib/rubocop/cop/lint/redundant_require_statement.rb +1 -0
- data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +45 -0
- data/lib/rubocop/cop/lint/rescue_type.rb +0 -1
- data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +3 -1
- data/lib/rubocop/cop/lint/shadowed_exception.rb +6 -6
- data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +4 -4
- data/lib/rubocop/cop/lint/struct_new_override.rb +1 -0
- data/lib/rubocop/cop/lint/to_json.rb +16 -5
- data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +1 -1
- data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +57 -0
- data/lib/rubocop/cop/lint/unreachable_loop.rb +3 -6
- data/lib/rubocop/cop/lint/uri_escape_unescape.rb +3 -1
- data/lib/rubocop/cop/lint/uri_regexp.rb +2 -1
- data/lib/rubocop/cop/lint/useless_access_modifier.rb +3 -9
- data/lib/rubocop/cop/lint/useless_method_definition.rb +70 -0
- data/lib/rubocop/cop/lint/useless_times.rb +106 -0
- data/lib/rubocop/cop/metrics/block_length.rb +3 -1
- data/lib/rubocop/cop/metrics/class_length.rb +8 -6
- data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +27 -16
- data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +1 -0
- data/lib/rubocop/cop/mixin/alignment.rb +3 -0
- data/lib/rubocop/cop/mixin/allowed_methods.rb +2 -0
- data/lib/rubocop/cop/mixin/annotation_comment.rb +5 -0
- data/lib/rubocop/cop/mixin/check_line_breakable.rb +16 -7
- data/lib/rubocop/cop/mixin/comments_help.rb +48 -0
- data/lib/rubocop/cop/mixin/configurable_naming.rb +2 -2
- data/lib/rubocop/cop/mixin/configurable_numbering.rb +3 -3
- data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +8 -7
- data/lib/rubocop/cop/mixin/empty_parameter.rb +3 -1
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +12 -1
- data/lib/rubocop/cop/mixin/first_element_line_break.rb +3 -1
- data/lib/rubocop/cop/mixin/hash_transform_method.rb +27 -2
- data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +3 -1
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +12 -10
- data/lib/rubocop/cop/mixin/negative_conditional.rb +2 -2
- data/lib/rubocop/cop/mixin/percent_array.rb +14 -3
- data/lib/rubocop/cop/mixin/rescue_node.rb +11 -1
- data/lib/rubocop/cop/mixin/space_after_punctuation.rb +4 -3
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +4 -3
- data/lib/rubocop/cop/mixin/statement_modifier.rb +9 -3
- data/lib/rubocop/cop/mixin/surrounding_space.rb +8 -4
- data/lib/rubocop/cop/mixin/trailing_comma.rb +7 -7
- data/lib/rubocop/cop/mixin/visibility_help.rb +4 -16
- data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +1 -1
- data/lib/rubocop/cop/naming/file_name.rb +1 -1
- data/lib/rubocop/cop/offense.rb +16 -2
- data/lib/rubocop/cop/security/eval.rb +1 -0
- data/lib/rubocop/cop/security/json_load.rb +1 -0
- data/lib/rubocop/cop/security/marshal_load.rb +1 -0
- data/lib/rubocop/cop/security/open.rb +1 -0
- data/lib/rubocop/cop/security/yaml_load.rb +1 -0
- data/lib/rubocop/cop/severity.rb +0 -8
- data/lib/rubocop/cop/style/access_modifier_declarations.rb +7 -11
- data/lib/rubocop/cop/style/accessor_grouping.rb +3 -0
- data/lib/rubocop/cop/style/alias.rb +2 -0
- data/lib/rubocop/cop/style/array_coercion.rb +4 -0
- data/lib/rubocop/cop/style/array_join.rb +1 -0
- data/lib/rubocop/cop/style/attr.rb +1 -0
- data/lib/rubocop/cop/style/auto_resource_cleanup.rb +2 -0
- data/lib/rubocop/cop/style/case_equality.rb +11 -3
- data/lib/rubocop/cop/style/case_like_if.rb +40 -8
- data/lib/rubocop/cop/style/class_and_module_children.rb +2 -0
- data/lib/rubocop/cop/style/class_check.rb +6 -9
- data/lib/rubocop/cop/style/class_equality_comparison.rb +49 -0
- data/lib/rubocop/cop/style/class_methods_definitions.rb +157 -0
- data/lib/rubocop/cop/style/class_vars.rb +1 -2
- data/lib/rubocop/cop/style/combinable_loops.rb +91 -0
- data/lib/rubocop/cop/style/comment_annotation.rb +6 -0
- data/lib/rubocop/cop/style/commented_keyword.rb +7 -8
- data/lib/rubocop/cop/style/conditional_assignment.rb +49 -60
- data/lib/rubocop/cop/style/date_time.rb +12 -1
- data/lib/rubocop/cop/style/dir.rb +1 -0
- data/lib/rubocop/cop/style/double_negation.rb +1 -0
- data/lib/rubocop/cop/style/empty_block_parameter.rb +9 -10
- data/lib/rubocop/cop/style/empty_lambda_parameter.rb +9 -10
- data/lib/rubocop/cop/style/empty_literal.rb +3 -1
- data/lib/rubocop/cop/style/eval_with_location.rb +1 -3
- data/lib/rubocop/cop/style/even_odd.rb +1 -0
- data/lib/rubocop/cop/style/expand_path_arguments.rb +2 -2
- data/lib/rubocop/cop/style/explicit_block_argument.rb +7 -3
- data/lib/rubocop/cop/style/float_division.rb +2 -0
- data/lib/rubocop/cop/style/for.rb +0 -4
- data/lib/rubocop/cop/style/format_string.rb +1 -4
- data/lib/rubocop/cop/style/format_string_token.rb +1 -1
- data/lib/rubocop/cop/style/guard_clause.rb +1 -0
- data/lib/rubocop/cop/style/hash_as_last_array_item.rb +24 -5
- data/lib/rubocop/cop/style/hash_syntax.rb +6 -5
- data/lib/rubocop/cop/style/hash_transform_keys.rb +16 -9
- data/lib/rubocop/cop/style/hash_transform_values.rb +16 -9
- data/lib/rubocop/cop/style/if_unless_modifier.rb +2 -6
- data/lib/rubocop/cop/style/implicit_runtime_error.rb +1 -0
- data/lib/rubocop/cop/style/keyword_parameters_order.rb +53 -0
- data/lib/rubocop/cop/style/lambda_call.rb +3 -1
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +10 -1
- data/lib/rubocop/cop/style/method_def_parentheses.rb +0 -4
- data/lib/rubocop/cop/style/mixin_usage.rb +8 -27
- data/lib/rubocop/cop/style/multiline_block_chain.rb +2 -2
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +14 -1
- data/lib/rubocop/cop/style/multiline_when_then.rb +3 -2
- data/lib/rubocop/cop/style/negated_if.rb +6 -6
- data/lib/rubocop/cop/style/negated_unless.rb +6 -6
- data/lib/rubocop/cop/style/negated_while.rb +7 -15
- data/lib/rubocop/cop/style/nested_modifier.rb +10 -13
- data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +11 -11
- data/lib/rubocop/cop/style/nested_ternary_operator.rb +16 -16
- data/lib/rubocop/cop/style/next.rb +10 -14
- data/lib/rubocop/cop/style/nil_comparison.rb +13 -11
- data/lib/rubocop/cop/style/non_nil_check.rb +34 -26
- data/lib/rubocop/cop/style/not.rb +20 -26
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +4 -9
- data/lib/rubocop/cop/style/numeric_predicate.rb +5 -14
- data/lib/rubocop/cop/style/one_line_conditional.rb +73 -23
- data/lib/rubocop/cop/style/option_hash.rb +1 -1
- data/lib/rubocop/cop/style/optional_arguments.rb +1 -1
- data/lib/rubocop/cop/style/optional_boolean_parameter.rb +12 -1
- data/lib/rubocop/cop/style/or_assignment.rb +13 -10
- data/lib/rubocop/cop/style/parallel_assignment.rb +14 -14
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +6 -6
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +13 -19
- data/lib/rubocop/cop/style/percent_q_literals.rb +8 -10
- data/lib/rubocop/cop/style/perl_backrefs.rb +8 -10
- data/lib/rubocop/cop/style/preferred_hash_methods.rb +11 -14
- data/lib/rubocop/cop/style/proc.rb +6 -6
- data/lib/rubocop/cop/style/raise_args.rb +12 -24
- data/lib/rubocop/cop/style/random_with_offset.rb +19 -19
- data/lib/rubocop/cop/style/redundant_assignment.rb +8 -18
- data/lib/rubocop/cop/style/redundant_begin.rb +28 -12
- data/lib/rubocop/cop/style/redundant_capital_w.rb +6 -9
- data/lib/rubocop/cop/style/redundant_condition.rb +10 -7
- data/lib/rubocop/cop/style/redundant_conditional.rb +4 -5
- data/lib/rubocop/cop/style/redundant_exception.rb +1 -3
- data/lib/rubocop/cop/style/redundant_fetch_block.rb +3 -12
- data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +9 -8
- data/lib/rubocop/cop/style/redundant_freeze.rb +5 -7
- data/lib/rubocop/cop/style/redundant_interpolation.rb +31 -25
- data/lib/rubocop/cop/style/redundant_parentheses.rb +21 -15
- data/lib/rubocop/cop/style/redundant_percent_q.rb +9 -11
- data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +44 -36
- data/lib/rubocop/cop/style/redundant_regexp_escape.rb +13 -29
- data/lib/rubocop/cop/style/redundant_return.rb +17 -17
- data/lib/rubocop/cop/style/redundant_self.rb +9 -11
- data/lib/rubocop/cop/style/redundant_self_assignment.rb +116 -0
- data/lib/rubocop/cop/style/redundant_sort.rb +12 -29
- data/lib/rubocop/cop/style/redundant_sort_by.rb +5 -9
- data/lib/rubocop/cop/style/regexp_literal.rb +10 -21
- data/lib/rubocop/cop/style/rescue_modifier.rb +29 -9
- data/lib/rubocop/cop/style/rescue_standard_error.rb +20 -16
- data/lib/rubocop/cop/style/return_nil.rb +5 -5
- data/lib/rubocop/cop/style/safe_navigation.rb +18 -12
- data/lib/rubocop/cop/style/sample.rb +12 -14
- data/lib/rubocop/cop/style/self_assignment.rb +26 -22
- data/lib/rubocop/cop/style/semicolon.rb +6 -9
- data/lib/rubocop/cop/style/send.rb +4 -5
- data/lib/rubocop/cop/style/signal_exception.rb +23 -19
- data/lib/rubocop/cop/style/single_argument_dig.rb +1 -0
- data/lib/rubocop/cop/style/single_line_block_params.rb +4 -2
- data/lib/rubocop/cop/style/single_line_methods.rb +17 -16
- data/lib/rubocop/cop/style/slicing_with_range.rb +6 -8
- data/lib/rubocop/cop/style/sole_nested_conditional.rb +66 -0
- data/lib/rubocop/cop/style/special_global_vars.rb +10 -15
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +17 -21
- data/lib/rubocop/cop/style/stderr_puts.rb +5 -6
- data/lib/rubocop/cop/style/string_concatenation.rb +17 -3
- data/lib/rubocop/cop/style/string_hash_keys.rb +6 -7
- data/lib/rubocop/cop/style/string_methods.rb +7 -17
- data/lib/rubocop/cop/style/strip.rb +9 -14
- data/lib/rubocop/cop/style/struct_inheritance.rb +3 -6
- data/lib/rubocop/cop/style/symbol_array.rb +5 -16
- data/lib/rubocop/cop/style/symbol_literal.rb +4 -6
- data/lib/rubocop/cop/style/symbol_proc.rb +14 -18
- data/lib/rubocop/cop/style/ternary_parentheses.rb +22 -22
- data/lib/rubocop/cop/style/trailing_body_on_class.rb +3 -6
- data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +4 -7
- data/lib/rubocop/cop/style/trailing_body_on_module.rb +3 -6
- data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +2 -5
- data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +2 -5
- data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +11 -9
- data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +2 -5
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +8 -17
- data/lib/rubocop/cop/style/trivial_accessors.rb +26 -30
- data/lib/rubocop/cop/style/unless_else.rb +5 -8
- data/lib/rubocop/cop/style/unpack_first.rb +5 -8
- data/lib/rubocop/cop/style/variable_interpolation.rb +7 -10
- data/lib/rubocop/cop/style/when_then.rb +4 -6
- data/lib/rubocop/cop/style/while_until_do.rb +6 -16
- data/lib/rubocop/cop/style/while_until_modifier.rb +6 -20
- data/lib/rubocop/cop/style/word_array.rb +5 -23
- data/lib/rubocop/cop/style/yoda_condition.rb +4 -15
- data/lib/rubocop/cop/style/zero_length_predicate.rb +12 -18
- data/lib/rubocop/cop/team.rb +1 -0
- data/lib/rubocop/cop/util.rb +1 -2
- data/lib/rubocop/cop/utils/format_string.rb +3 -5
- data/lib/rubocop/cop/variable_force.rb +2 -0
- data/lib/rubocop/cop/variable_force/branch.rb +0 -4
- data/lib/rubocop/cops_documentation_generator.rb +4 -2
- data/lib/rubocop/core_ext/string.rb +2 -2
- data/lib/rubocop/directive_comment.rb +32 -0
- data/lib/rubocop/ext/regexp_node.rb +62 -0
- data/lib/rubocop/file_finder.rb +1 -0
- data/lib/rubocop/formatter/auto_gen_config_formatter.rb +2 -1
- data/lib/rubocop/formatter/disabled_config_formatter.rb +12 -5
- data/lib/rubocop/formatter/html_formatter.rb +2 -0
- data/lib/rubocop/formatter/progress_formatter.rb +2 -1
- data/lib/rubocop/formatter/quiet_formatter.rb +1 -1
- data/lib/rubocop/formatter/simple_text_formatter.rb +36 -6
- data/lib/rubocop/name_similarity.rb +1 -0
- data/lib/rubocop/options.rb +40 -17
- data/lib/rubocop/remote_config.rb +1 -0
- data/lib/rubocop/result_cache.rb +39 -15
- data/lib/rubocop/rspec/cop_helper.rb +5 -2
- data/lib/rubocop/rspec/expect_offense.rb +14 -9
- data/lib/rubocop/rspec/shared_contexts.rb +12 -0
- data/lib/rubocop/runner.rb +38 -18
- data/lib/rubocop/string_interpreter.rb +3 -0
- data/lib/rubocop/target_finder.rb +28 -26
- data/lib/rubocop/target_ruby.rb +7 -1
- data/lib/rubocop/version.rb +7 -1
- data/lib/rubocop/yaml_duplication_checker.rb +1 -0
- metadata +31 -17
- data/lib/rubocop/cop/mixin/regexp_literal_help.rb +0 -43
- data/lib/rubocop/cop/tokens_util.rb +0 -84
|
@@ -33,7 +33,7 @@ module RuboCop
|
|
|
33
33
|
'called `%<namespace>s`.'
|
|
34
34
|
MSG_REGEX = '`%<basename>s` should match `%<regex>s`.'
|
|
35
35
|
|
|
36
|
-
SNAKE_CASE = /^[\
|
|
36
|
+
SNAKE_CASE = /^[\d[[:lower:]]_.?!]+$/.freeze
|
|
37
37
|
|
|
38
38
|
def on_new_investigation
|
|
39
39
|
file_path = processed_source.file_path
|
data/lib/rubocop/cop/offense.rb
CHANGED
|
@@ -63,9 +63,23 @@ module RuboCop
|
|
|
63
63
|
attr_reader :corrector
|
|
64
64
|
|
|
65
65
|
PseudoSourceRange = Struct.new(:line, :column, :source_line, :begin_pos,
|
|
66
|
-
:end_pos)
|
|
66
|
+
:end_pos) do
|
|
67
|
+
alias_method :first_line, :line
|
|
68
|
+
alias_method :last_line, :line
|
|
69
|
+
alias_method :last_column, :column
|
|
67
70
|
|
|
68
|
-
|
|
71
|
+
def column_range
|
|
72
|
+
column...last_column
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
def size
|
|
76
|
+
end_pos - begin_pos
|
|
77
|
+
end
|
|
78
|
+
alias_method :length, :size
|
|
79
|
+
end
|
|
80
|
+
private_constant :PseudoSourceRange
|
|
81
|
+
|
|
82
|
+
NO_LOCATION = PseudoSourceRange.new(1, 0, '', 0, 0).freeze
|
|
69
83
|
|
|
70
84
|
# @api private
|
|
71
85
|
def initialize(severity, location, message, cop_name, # rubocop:disable Metrics/ParameterLists
|
data/lib/rubocop/cop/severity.rb
CHANGED
|
@@ -6,7 +6,6 @@ module RuboCop
|
|
|
6
6
|
class Severity
|
|
7
7
|
include Comparable
|
|
8
8
|
|
|
9
|
-
# @api private
|
|
10
9
|
NAMES = %i[refactor convention warning error fatal].freeze
|
|
11
10
|
|
|
12
11
|
# @api private
|
|
@@ -22,7 +21,6 @@ module RuboCop
|
|
|
22
21
|
# any of `:refactor`, `:convention`, `:warning`, `:error` or `:fatal`.
|
|
23
22
|
attr_reader :name
|
|
24
23
|
|
|
25
|
-
# @api private
|
|
26
24
|
def self.name_from_code(code)
|
|
27
25
|
name = code.to_sym
|
|
28
26
|
CODE_TABLE[name] || name
|
|
@@ -37,22 +35,18 @@ module RuboCop
|
|
|
37
35
|
freeze
|
|
38
36
|
end
|
|
39
37
|
|
|
40
|
-
# @api private
|
|
41
38
|
def to_s
|
|
42
39
|
@name.to_s
|
|
43
40
|
end
|
|
44
41
|
|
|
45
|
-
# @api private
|
|
46
42
|
def code
|
|
47
43
|
@name.to_s[0].upcase
|
|
48
44
|
end
|
|
49
45
|
|
|
50
|
-
# @api private
|
|
51
46
|
def level
|
|
52
47
|
NAMES.index(name) + 1
|
|
53
48
|
end
|
|
54
49
|
|
|
55
|
-
# @api private
|
|
56
50
|
def ==(other)
|
|
57
51
|
@name == if other.is_a?(Symbol)
|
|
58
52
|
other
|
|
@@ -61,12 +55,10 @@ module RuboCop
|
|
|
61
55
|
end
|
|
62
56
|
end
|
|
63
57
|
|
|
64
|
-
# @api private
|
|
65
58
|
def hash
|
|
66
59
|
@name.hash
|
|
67
60
|
end
|
|
68
61
|
|
|
69
|
-
# @api private
|
|
70
62
|
def <=>(other)
|
|
71
63
|
level <=> other.level
|
|
72
64
|
end
|
|
@@ -65,8 +65,6 @@ module RuboCop
|
|
|
65
65
|
class AccessModifierDeclarations < Base
|
|
66
66
|
include ConfigurableEnforcedStyle
|
|
67
67
|
|
|
68
|
-
ACCESS_MODIFIERS = %i[private protected public module_function].to_set.freeze
|
|
69
|
-
|
|
70
68
|
GROUP_STYLE_MESSAGE = [
|
|
71
69
|
'`%<access_modifier>s` should not be',
|
|
72
70
|
'inlined in method definitions.'
|
|
@@ -77,14 +75,16 @@ module RuboCop
|
|
|
77
75
|
'inlined in method definitions.'
|
|
78
76
|
].join(' ')
|
|
79
77
|
|
|
78
|
+
RESTRICT_ON_SEND = %i[private protected public module_function].freeze
|
|
79
|
+
|
|
80
80
|
def_node_matcher :access_modifier_with_symbol?, <<~PATTERN
|
|
81
81
|
(send nil? {:private :protected :public} (sym _))
|
|
82
82
|
PATTERN
|
|
83
83
|
|
|
84
84
|
def on_send(node)
|
|
85
|
-
return unless access_modifier?
|
|
86
|
-
return if node.parent
|
|
87
|
-
return if
|
|
85
|
+
return unless node.access_modifier?
|
|
86
|
+
return if node.parent&.pair_type?
|
|
87
|
+
return if allow_modifiers_on_symbols?(node)
|
|
88
88
|
|
|
89
89
|
if offense?(node)
|
|
90
90
|
add_offense(node.loc.selector) if opposite_style_detected
|
|
@@ -95,12 +95,8 @@ module RuboCop
|
|
|
95
95
|
|
|
96
96
|
private
|
|
97
97
|
|
|
98
|
-
def
|
|
99
|
-
|
|
100
|
-
end
|
|
101
|
-
|
|
102
|
-
def maybe_access_modifier?(node)
|
|
103
|
-
!node.receiver && ACCESS_MODIFIERS.include?(node.method_name)
|
|
98
|
+
def allow_modifiers_on_symbols?(node)
|
|
99
|
+
cop_config['AllowModifiersOnSymbols'] && access_modifier_with_symbol?(node)
|
|
104
100
|
end
|
|
105
101
|
|
|
106
102
|
def offense?(node)
|
|
@@ -7,6 +7,9 @@ module RuboCop
|
|
|
7
7
|
# By default it enforces accessors to be placed in grouped declarations,
|
|
8
8
|
# but it can be configured to enforce separating them in multiple declarations.
|
|
9
9
|
#
|
|
10
|
+
# Note: `Sorbet` is not compatible with "grouped" style. Consider "separated" style
|
|
11
|
+
# or disabling this cop.
|
|
12
|
+
#
|
|
10
13
|
# @example EnforcedStyle: grouped (default)
|
|
11
14
|
# # bad
|
|
12
15
|
# class Foo
|
|
@@ -32,6 +32,8 @@ module RuboCop
|
|
|
32
32
|
MSG_SYMBOL_ARGS = 'Use `alias %<prefer>s` instead of ' \
|
|
33
33
|
'`alias %<current>s`.'
|
|
34
34
|
|
|
35
|
+
RESTRICT_ON_SEND = %i[alias_method].freeze
|
|
36
|
+
|
|
35
37
|
def on_send(node)
|
|
36
38
|
return unless node.command?(:alias_method)
|
|
37
39
|
return unless style == :prefer_alias && alias_keyword_possible?(node)
|
|
@@ -5,6 +5,10 @@ module RuboCop
|
|
|
5
5
|
module Style
|
|
6
6
|
# This cop enforces the use of `Array()` instead of explicit `Array` check or `[*var]`.
|
|
7
7
|
#
|
|
8
|
+
# This cop is disabled by default because false positive will occur if
|
|
9
|
+
# the argument of `Array()` is not an array (e.g. Hash, Set),
|
|
10
|
+
# an array will be returned as an incompatibility result.
|
|
11
|
+
#
|
|
8
12
|
# @example
|
|
9
13
|
# # bad
|
|
10
14
|
# paths = [paths] unless paths.is_a?(Array)
|
|
@@ -14,7 +14,7 @@ module RuboCop
|
|
|
14
14
|
# # good
|
|
15
15
|
# something.is_a?(Array)
|
|
16
16
|
# (1..100).include?(7)
|
|
17
|
-
#
|
|
17
|
+
# /something/.match?(some_string)
|
|
18
18
|
#
|
|
19
19
|
# @example AllowOnConstant
|
|
20
20
|
# # Style/CaseEquality:
|
|
@@ -27,17 +27,20 @@ module RuboCop
|
|
|
27
27
|
# # good
|
|
28
28
|
# Array === something
|
|
29
29
|
# (1..100).include?(7)
|
|
30
|
-
#
|
|
30
|
+
# /something/.match?(some_string)
|
|
31
31
|
#
|
|
32
32
|
class CaseEquality < Base
|
|
33
33
|
extend AutoCorrector
|
|
34
34
|
|
|
35
35
|
MSG = 'Avoid the use of the case equality operator `===`.'
|
|
36
|
+
RESTRICT_ON_SEND = %i[===].freeze
|
|
36
37
|
|
|
37
38
|
def_node_matcher :case_equality?, '(send $#const? :=== $_)'
|
|
38
39
|
|
|
39
40
|
def on_send(node)
|
|
40
41
|
case_equality?(node) do |lhs, rhs|
|
|
42
|
+
return if lhs.const_type? && !lhs.module_name?
|
|
43
|
+
|
|
41
44
|
add_offense(node.loc.selector) do |corrector|
|
|
42
45
|
replacement = replacement(lhs, rhs)
|
|
43
46
|
corrector.replace(node, replacement) if replacement
|
|
@@ -58,7 +61,12 @@ module RuboCop
|
|
|
58
61
|
def replacement(lhs, rhs)
|
|
59
62
|
case lhs.type
|
|
60
63
|
when :regexp
|
|
61
|
-
|
|
64
|
+
# The automatic correction from `a === b` to `a.match?(b)` needs to
|
|
65
|
+
# consider `Regexp.last_match?`, `$~`, `$1`, and etc.
|
|
66
|
+
# This correction is expected to be supported by `Performance/Regexp` cop.
|
|
67
|
+
# See: https://github.com/rubocop-hq/rubocop-performance/issues/152
|
|
68
|
+
#
|
|
69
|
+
# So here is noop.
|
|
62
70
|
when :begin
|
|
63
71
|
child = lhs.children.first
|
|
64
72
|
"#{lhs.source}.include?(#{rhs.source})" if child&.range_type?
|
|
@@ -42,6 +42,8 @@ module RuboCop
|
|
|
42
42
|
convertible = true
|
|
43
43
|
|
|
44
44
|
branch_conditions(node).each do |branch_condition|
|
|
45
|
+
return false if regexp_with_working_captures?(branch_condition)
|
|
46
|
+
|
|
45
47
|
conditions << []
|
|
46
48
|
convertible = collect_conditions(branch_condition, target, conditions.last)
|
|
47
49
|
break unless convertible
|
|
@@ -49,9 +51,7 @@ module RuboCop
|
|
|
49
51
|
|
|
50
52
|
return unless convertible
|
|
51
53
|
|
|
52
|
-
add_offense(node)
|
|
53
|
-
autocorrect(corrector, node)
|
|
54
|
-
end
|
|
54
|
+
add_offense(node) { |corrector| autocorrect(corrector, node) }
|
|
55
55
|
end
|
|
56
56
|
|
|
57
57
|
private
|
|
@@ -107,7 +107,7 @@ module RuboCop
|
|
|
107
107
|
when :include?, :cover?
|
|
108
108
|
receiver = deparenthesize(node.receiver)
|
|
109
109
|
node.arguments.first if receiver.range_type?
|
|
110
|
-
when :match, :match
|
|
110
|
+
when :match, :match?, :=~
|
|
111
111
|
find_target_in_match_node(node)
|
|
112
112
|
end
|
|
113
113
|
end
|
|
@@ -115,7 +115,7 @@ module RuboCop
|
|
|
115
115
|
def find_target_in_equality_node(node)
|
|
116
116
|
argument = node.arguments.first
|
|
117
117
|
receiver = node.receiver
|
|
118
|
-
return unless receiver
|
|
118
|
+
return unless argument && receiver
|
|
119
119
|
|
|
120
120
|
if argument.literal? || const_reference?(argument)
|
|
121
121
|
receiver
|
|
@@ -159,9 +159,10 @@ module RuboCop
|
|
|
159
159
|
case node.method_name
|
|
160
160
|
when :is_a?
|
|
161
161
|
node.arguments.first if node.receiver == target
|
|
162
|
-
when :==, :eql?, :equal
|
|
163
|
-
|
|
164
|
-
|
|
162
|
+
when :==, :eql?, :equal?
|
|
163
|
+
condition_from_equality_node(node, target)
|
|
164
|
+
when :=~, :match, :match?
|
|
165
|
+
condition_from_match_node(node, target)
|
|
165
166
|
when :===
|
|
166
167
|
lhs, _method, rhs = *node
|
|
167
168
|
lhs if rhs == target
|
|
@@ -172,6 +173,17 @@ module RuboCop
|
|
|
172
173
|
end
|
|
173
174
|
# rubocop:enable Metrics/CyclomaticComplexity
|
|
174
175
|
|
|
176
|
+
def condition_from_equality_node(node, target)
|
|
177
|
+
lhs, _method, rhs = *node
|
|
178
|
+
condition = condition_from_binary_op(lhs, rhs, target)
|
|
179
|
+
condition if condition && !class_reference?(condition)
|
|
180
|
+
end
|
|
181
|
+
|
|
182
|
+
def condition_from_match_node(node, target)
|
|
183
|
+
lhs, _method, rhs = *node
|
|
184
|
+
condition_from_binary_op(lhs, rhs, target)
|
|
185
|
+
end
|
|
186
|
+
|
|
175
187
|
def condition_from_binary_op(lhs, rhs, target)
|
|
176
188
|
lhs = deparenthesize(lhs)
|
|
177
189
|
rhs = deparenthesize(rhs)
|
|
@@ -202,6 +214,10 @@ module RuboCop
|
|
|
202
214
|
name == name.upcase
|
|
203
215
|
end
|
|
204
216
|
|
|
217
|
+
def class_reference?(node)
|
|
218
|
+
node.const_type? && node.children[1].match?(/[[:lower:]]/)
|
|
219
|
+
end
|
|
220
|
+
|
|
205
221
|
def deparenthesize(node)
|
|
206
222
|
node = node.children.last while node.begin_type?
|
|
207
223
|
node
|
|
@@ -214,6 +230,22 @@ module RuboCop
|
|
|
214
230
|
def indent(node)
|
|
215
231
|
' ' * node.loc.column
|
|
216
232
|
end
|
|
233
|
+
|
|
234
|
+
# Named captures work with `=~` (if regexp is on lhs) and with `match` (both sides)
|
|
235
|
+
def regexp_with_working_captures?(node)
|
|
236
|
+
case node.type
|
|
237
|
+
when :match_with_lvasgn
|
|
238
|
+
lhs, _rhs = *node
|
|
239
|
+
node.loc.selector.source == '=~' && regexp_with_named_captures?(lhs)
|
|
240
|
+
when :send
|
|
241
|
+
lhs, method, rhs = *node
|
|
242
|
+
method == :match && [lhs, rhs].any? { |n| regexp_with_named_captures?(n) }
|
|
243
|
+
end
|
|
244
|
+
end
|
|
245
|
+
|
|
246
|
+
def regexp_with_named_captures?(node)
|
|
247
|
+
node.regexp_type? && node.each_capture(named: true).count.positive?
|
|
248
|
+
end
|
|
217
249
|
end
|
|
218
250
|
end
|
|
219
251
|
end
|
|
@@ -28,19 +28,16 @@ module RuboCop
|
|
|
28
28
|
extend AutoCorrector
|
|
29
29
|
|
|
30
30
|
MSG = 'Prefer `Object#%<prefer>s` over `Object#%<current>s`.'
|
|
31
|
-
|
|
32
|
-
def_node_matcher :class_check?, '(send _ ${:is_a? :kind_of?} _)'
|
|
31
|
+
RESTRICT_ON_SEND = %i[is_a? kind_of?].freeze
|
|
33
32
|
|
|
34
33
|
def on_send(node)
|
|
35
|
-
|
|
36
|
-
return if style == method_name
|
|
34
|
+
return if style == node.method_name
|
|
37
35
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
36
|
+
message = message(node)
|
|
37
|
+
add_offense(node.loc.selector, message: message) do |corrector|
|
|
38
|
+
replacement = node.method?(:is_a?) ? 'kind_of?' : 'is_a?'
|
|
41
39
|
|
|
42
|
-
|
|
43
|
-
end
|
|
40
|
+
corrector.replace(node.loc.selector, replacement)
|
|
44
41
|
end
|
|
45
42
|
end
|
|
46
43
|
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module RuboCop
|
|
4
|
+
module Cop
|
|
5
|
+
module Style
|
|
6
|
+
# This cop enforces the use of `Object#instance_of?` instead of class comparison
|
|
7
|
+
# for equality.
|
|
8
|
+
#
|
|
9
|
+
# @example
|
|
10
|
+
# # bad
|
|
11
|
+
# var.class == Date
|
|
12
|
+
# var.class.equal?(Date)
|
|
13
|
+
# var.class.eql?(Date)
|
|
14
|
+
# var.class.name == 'Date'
|
|
15
|
+
#
|
|
16
|
+
# # good
|
|
17
|
+
# var.instance_of?(Date)
|
|
18
|
+
#
|
|
19
|
+
class ClassEqualityComparison < Base
|
|
20
|
+
include RangeHelp
|
|
21
|
+
include IgnoredMethods
|
|
22
|
+
extend AutoCorrector
|
|
23
|
+
|
|
24
|
+
MSG = 'Use `Object.instance_of?` instead of comparing classes.'
|
|
25
|
+
|
|
26
|
+
RESTRICT_ON_SEND = %i[== equal? eql?].freeze
|
|
27
|
+
|
|
28
|
+
def_node_matcher :class_comparison_candidate?, <<~PATTERN
|
|
29
|
+
(send
|
|
30
|
+
{$(send _ :class) (send $(send _ :class) :name)}
|
|
31
|
+
{:== :equal? :eql?} $_)
|
|
32
|
+
PATTERN
|
|
33
|
+
|
|
34
|
+
def on_send(node)
|
|
35
|
+
def_node = node.each_ancestor(:def, :defs).first
|
|
36
|
+
return if def_node && ignored_method?(def_node.method_name)
|
|
37
|
+
|
|
38
|
+
class_comparison_candidate?(node) do |receiver_node, class_node|
|
|
39
|
+
range = range_between(receiver_node.loc.selector.begin_pos, node.source_range.end_pos)
|
|
40
|
+
|
|
41
|
+
add_offense(range) do |corrector|
|
|
42
|
+
corrector.replace(range, "instance_of?(#{class_node.source})")
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|