rubocop 0.93.1 → 1.79.2
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/LICENSE.txt +1 -1
- data/README.md +133 -103
- data/assets/output.css.erb +159 -0
- data/assets/output.html.erb +2 -161
- data/config/default.yml +1864 -271
- data/config/internal_affairs.yml +31 -0
- data/config/obsoletion.yml +243 -0
- data/exe/rubocop +16 -9
- data/lib/rubocop/arguments_env.rb +17 -0
- data/lib/rubocop/arguments_file.rb +17 -0
- data/lib/rubocop/cache_config.rb +29 -0
- data/lib/rubocop/cached_data.rb +22 -8
- data/lib/rubocop/cli/command/{auto_genenerate_config.rb → auto_generate_config.rb} +55 -29
- data/lib/rubocop/cli/command/execute_runner.rb +39 -19
- data/lib/rubocop/cli/command/init_dotfile.rb +2 -4
- data/lib/rubocop/cli/command/lsp.rb +19 -0
- data/lib/rubocop/cli/command/show_cops.rb +26 -7
- data/lib/rubocop/cli/command/show_docs_url.rb +48 -0
- data/lib/rubocop/cli/command/suggest_extensions.rb +132 -0
- data/lib/rubocop/cli/command/version.rb +2 -2
- data/lib/rubocop/cli.rb +108 -16
- data/lib/rubocop/comment_config.rb +107 -104
- data/lib/rubocop/config.rb +160 -58
- data/lib/rubocop/config_finder.rb +78 -0
- data/lib/rubocop/config_loader.rb +112 -102
- data/lib/rubocop/config_loader_resolver.rb +124 -47
- data/lib/rubocop/config_obsoletion/changed_enforced_styles.rb +33 -0
- data/lib/rubocop/config_obsoletion/changed_parameter.rb +26 -0
- data/lib/rubocop/config_obsoletion/cop_rule.rb +33 -0
- data/lib/rubocop/config_obsoletion/extracted_cop.rb +47 -0
- data/lib/rubocop/config_obsoletion/parameter_rule.rb +56 -0
- data/lib/rubocop/config_obsoletion/removed_cop.rb +41 -0
- data/lib/rubocop/config_obsoletion/renamed_cop.rb +49 -0
- data/lib/rubocop/config_obsoletion/rule.rb +41 -0
- data/lib/rubocop/config_obsoletion/split_cop.rb +27 -0
- data/lib/rubocop/config_obsoletion.rb +110 -238
- data/lib/rubocop/config_regeneration.rb +1 -1
- data/lib/rubocop/config_store.rb +13 -3
- data/lib/rubocop/config_validator.rb +110 -43
- data/lib/rubocop/cop/autocorrect_logic.rb +82 -18
- data/lib/rubocop/cop/badge.rb +21 -26
- data/lib/rubocop/cop/base.rb +235 -118
- data/lib/rubocop/cop/bundler/duplicated_gem.rb +33 -16
- data/lib/rubocop/cop/bundler/duplicated_group.rb +127 -0
- data/lib/rubocop/cop/bundler/gem_comment.rb +46 -13
- data/lib/rubocop/cop/bundler/gem_filename.rb +102 -0
- data/lib/rubocop/cop/bundler/gem_version.rb +132 -0
- data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +46 -22
- data/lib/rubocop/cop/bundler/ordered_gems.rb +17 -20
- data/lib/rubocop/cop/commissioner.rb +57 -36
- data/lib/rubocop/cop/cop.rb +86 -54
- data/lib/rubocop/cop/corrector.rb +41 -22
- data/lib/rubocop/cop/correctors/alignment_corrector.rb +10 -27
- data/lib/rubocop/cop/correctors/condition_corrector.rb +1 -1
- data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +8 -14
- data/lib/rubocop/cop/correctors/empty_line_corrector.rb +1 -1
- data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +11 -18
- data/lib/rubocop/cop/correctors/if_then_corrector.rb +55 -0
- data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +10 -7
- data/lib/rubocop/cop/correctors/line_break_corrector.rb +13 -8
- data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +26 -12
- data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +10 -16
- data/lib/rubocop/cop/correctors/parentheses_corrector.rb +65 -4
- data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +17 -13
- data/lib/rubocop/cop/correctors/punctuation_corrector.rb +1 -1
- data/lib/rubocop/cop/correctors/require_library_corrector.rb +23 -0
- data/lib/rubocop/cop/correctors/space_corrector.rb +1 -1
- data/lib/rubocop/cop/correctors/string_literal_corrector.rb +7 -9
- data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +2 -2
- data/lib/rubocop/cop/documentation.rb +47 -3
- data/lib/rubocop/cop/exclude_limit.rb +26 -0
- data/lib/rubocop/cop/force.rb +13 -1
- data/lib/rubocop/cop/gemspec/add_runtime_dependency.rb +38 -0
- data/lib/rubocop/cop/gemspec/attribute_assignment.rb +91 -0
- data/lib/rubocop/cop/gemspec/dependency_version.rb +152 -0
- data/lib/rubocop/cop/gemspec/deprecated_attribute_assignment.rb +91 -0
- data/lib/rubocop/cop/gemspec/development_dependencies.rb +107 -0
- data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +47 -40
- data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +16 -19
- data/lib/rubocop/cop/gemspec/require_mfa.rb +159 -0
- data/lib/rubocop/cop/gemspec/required_ruby_version.rb +50 -32
- data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +9 -14
- data/lib/rubocop/cop/generator/configuration_injector.rb +2 -3
- data/lib/rubocop/cop/generator/require_file_injector.rb +5 -8
- data/lib/rubocop/cop/generator.rb +38 -39
- data/lib/rubocop/cop/internal_affairs/cop_description.rb +118 -0
- data/lib/rubocop/cop/internal_affairs/cop_enabled.rb +85 -0
- data/lib/rubocop/cop/internal_affairs/create_empty_file.rb +37 -0
- data/lib/rubocop/cop/internal_affairs/empty_line_between_expect_offense_and_correction.rb +69 -0
- data/lib/rubocop/cop/internal_affairs/example_description.rb +118 -0
- data/lib/rubocop/cop/internal_affairs/example_heredoc_delimiter.rb +111 -0
- data/lib/rubocop/cop/internal_affairs/inherit_deprecated_cop_class.rb +34 -0
- data/lib/rubocop/cop/internal_affairs/lambda_or_proc.rb +46 -0
- data/lib/rubocop/cop/internal_affairs/location_exists.rb +116 -0
- data/lib/rubocop/cop/internal_affairs/location_expression.rb +38 -0
- data/lib/rubocop/cop/internal_affairs/location_line_equality_comparison.rb +61 -0
- data/lib/rubocop/cop/internal_affairs/method_name_end_with.rb +82 -0
- data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +19 -22
- data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +3 -3
- data/lib/rubocop/cop/internal_affairs/node_first_or_last_argument.rb +54 -0
- data/lib/rubocop/cop/internal_affairs/node_matcher_directive.rb +241 -0
- data/lib/rubocop/cop/internal_affairs/node_pattern_groups/ast_processor.rb +63 -0
- data/lib/rubocop/cop/internal_affairs/node_pattern_groups/ast_walker.rb +131 -0
- data/lib/rubocop/cop/internal_affairs/node_pattern_groups.rb +231 -0
- data/lib/rubocop/cop/internal_affairs/node_type_group.rb +92 -0
- data/lib/rubocop/cop/internal_affairs/node_type_multiple_predicates.rb +126 -0
- data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +5 -5
- data/lib/rubocop/cop/internal_affairs/numblock_handler.rb +69 -0
- data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +3 -2
- data/lib/rubocop/cop/internal_affairs/on_send_without_on_csend.rb +90 -0
- data/lib/rubocop/cop/internal_affairs/operator_keyword.rb +48 -0
- data/lib/rubocop/cop/internal_affairs/plugin.rb +33 -0
- data/lib/rubocop/cop/internal_affairs/processed_source_buffer_name.rb +42 -0
- data/lib/rubocop/cop/internal_affairs/redundant_context_config_parameter.rb +46 -0
- data/lib/rubocop/cop/internal_affairs/redundant_described_class_as_subject.rb +63 -0
- data/lib/rubocop/cop/internal_affairs/redundant_expect_offense_arguments.rb +34 -0
- data/lib/rubocop/cop/internal_affairs/redundant_let_rubocop_config_new.rb +73 -0
- data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +2 -1
- data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +9 -21
- data/lib/rubocop/cop/internal_affairs/redundant_method_dispatch_node.rb +56 -0
- data/lib/rubocop/cop/internal_affairs/redundant_source_range.rb +75 -0
- data/lib/rubocop/cop/internal_affairs/single_line_comparison.rb +63 -0
- data/lib/rubocop/cop/internal_affairs/style_detected_api_use.rb +146 -0
- data/lib/rubocop/cop/internal_affairs/undefined_config.rb +94 -0
- data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +6 -9
- data/lib/rubocop/cop/internal_affairs/useless_restrict_on_send.rb +60 -0
- data/lib/rubocop/cop/internal_affairs.rb +32 -1
- data/lib/rubocop/cop/layout/access_modifier_indentation.rb +18 -12
- data/lib/rubocop/cop/layout/argument_alignment.rb +79 -21
- data/lib/rubocop/cop/layout/array_alignment.rb +11 -10
- data/lib/rubocop/cop/layout/assignment_indentation.rb +13 -11
- data/lib/rubocop/cop/layout/begin_end_alignment.rb +2 -6
- data/lib/rubocop/cop/layout/block_alignment.rb +64 -53
- data/lib/rubocop/cop/layout/block_end_newline.rb +34 -15
- data/lib/rubocop/cop/layout/case_indentation.rb +73 -11
- data/lib/rubocop/cop/layout/class_structure.rb +114 -38
- data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +2 -3
- data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +26 -36
- data/lib/rubocop/cop/layout/comment_indentation.rb +55 -28
- data/lib/rubocop/cop/layout/condition_position.rb +1 -5
- data/lib/rubocop/cop/layout/def_end_alignment.rb +6 -10
- data/lib/rubocop/cop/layout/dot_position.rb +48 -15
- data/lib/rubocop/cop/layout/else_alignment.rb +27 -13
- data/lib/rubocop/cop/layout/empty_comment.rb +9 -14
- data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +82 -28
- data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +14 -7
- data/lib/rubocop/cop/layout/empty_line_after_multiline_condition.rb +2 -2
- data/lib/rubocop/cop/layout/empty_line_between_defs.rb +170 -27
- data/lib/rubocop/cop/layout/empty_lines.rb +4 -4
- data/lib/rubocop/cop/layout/empty_lines_after_module_inclusion.rb +101 -0
- data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +48 -22
- data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +13 -29
- data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +26 -5
- data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +6 -7
- data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +8 -5
- data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +11 -11
- data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +24 -17
- data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +24 -2
- data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +10 -10
- data/lib/rubocop/cop/layout/end_alignment.rb +36 -10
- data/lib/rubocop/cop/layout/end_of_line.rb +11 -11
- data/lib/rubocop/cop/layout/extra_spacing.rb +19 -21
- data/lib/rubocop/cop/layout/first_argument_indentation.rb +70 -39
- data/lib/rubocop/cop/layout/first_array_element_indentation.rb +49 -31
- data/lib/rubocop/cop/layout/first_array_element_line_break.rb +37 -11
- data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +79 -29
- data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +39 -5
- data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +67 -11
- data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +54 -22
- data/lib/rubocop/cop/layout/first_parameter_indentation.rb +12 -11
- data/lib/rubocop/cop/layout/hash_alignment.rb +73 -37
- data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +41 -15
- data/lib/rubocop/cop/layout/heredoc_indentation.rb +16 -27
- data/lib/rubocop/cop/layout/indentation_consistency.rb +10 -7
- data/lib/rubocop/cop/layout/indentation_style.rb +32 -32
- data/lib/rubocop/cop/layout/indentation_width.rb +64 -37
- data/lib/rubocop/cop/layout/initial_indentation.rb +3 -6
- data/lib/rubocop/cop/layout/leading_comment_space.rb +87 -5
- data/lib/rubocop/cop/layout/leading_empty_lines.rb +1 -1
- data/lib/rubocop/cop/layout/line_continuation_leading_space.rb +153 -0
- data/lib/rubocop/cop/layout/line_continuation_spacing.rb +146 -0
- data/lib/rubocop/cop/layout/line_end_string_concatenation_indentation.rb +143 -0
- data/lib/rubocop/cop/layout/line_length.rb +200 -64
- data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +7 -7
- data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +33 -4
- data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +31 -5
- data/lib/rubocop/cop/layout/multiline_block_layout.rb +15 -20
- data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +7 -7
- data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +32 -5
- data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +68 -4
- data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +9 -8
- data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +69 -26
- data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +8 -8
- data/lib/rubocop/cop/layout/multiline_method_parameter_line_breaks.rb +78 -0
- data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +21 -18
- data/lib/rubocop/cop/layout/parameter_alignment.rb +11 -11
- data/lib/rubocop/cop/layout/redundant_line_break.rb +134 -0
- data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +38 -36
- data/lib/rubocop/cop/layout/single_line_block_chain.rb +69 -0
- data/lib/rubocop/cop/layout/space_after_colon.rb +4 -6
- data/lib/rubocop/cop/layout/space_after_comma.rb +10 -2
- data/lib/rubocop/cop/layout/space_after_method_name.rb +3 -5
- data/lib/rubocop/cop/layout/space_after_not.rb +3 -2
- data/lib/rubocop/cop/layout/space_after_semicolon.rb +11 -1
- data/lib/rubocop/cop/layout/space_around_block_parameters.rb +32 -34
- data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +3 -2
- data/lib/rubocop/cop/layout/space_around_keyword.rb +42 -11
- data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +3 -3
- data/lib/rubocop/cop/layout/space_around_operators.rb +101 -41
- data/lib/rubocop/cop/layout/space_before_block_braces.rb +29 -16
- data/lib/rubocop/cop/layout/space_before_brackets.rb +40 -0
- data/lib/rubocop/cop/layout/space_before_comma.rb +1 -1
- data/lib/rubocop/cop/layout/space_before_comment.rb +4 -6
- data/lib/rubocop/cop/layout/space_before_first_arg.rb +10 -12
- data/lib/rubocop/cop/layout/space_before_semicolon.rb +1 -1
- data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +16 -12
- data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +51 -39
- data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +5 -7
- data/lib/rubocop/cop/layout/space_inside_block_braces.rb +56 -33
- data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +41 -8
- data/lib/rubocop/cop/layout/space_inside_parens.rb +93 -25
- data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +34 -0
- data/lib/rubocop/cop/layout/space_inside_range_literal.rb +1 -1
- data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +12 -9
- data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +7 -8
- data/lib/rubocop/cop/layout/trailing_empty_lines.rb +15 -10
- data/lib/rubocop/cop/layout/trailing_whitespace.rb +72 -16
- data/lib/rubocop/cop/legacy/corrections_proxy.rb +3 -9
- data/lib/rubocop/cop/legacy/corrector.rb +13 -5
- data/lib/rubocop/cop/lint/ambiguous_assignment.rb +54 -0
- data/lib/rubocop/cop/lint/ambiguous_block_association.rb +50 -12
- data/lib/rubocop/cop/lint/ambiguous_operator.rb +11 -9
- data/lib/rubocop/cop/lint/ambiguous_operator_precedence.rb +111 -0
- data/lib/rubocop/cop/lint/ambiguous_range.rb +113 -0
- data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +13 -7
- data/lib/rubocop/cop/lint/array_literal_in_regexp.rb +118 -0
- data/lib/rubocop/cop/lint/assignment_in_condition.rb +25 -15
- data/lib/rubocop/cop/lint/big_decimal_new.rb +5 -7
- data/lib/rubocop/cop/lint/binary_operator_with_identical_operands.rb +30 -14
- data/lib/rubocop/cop/lint/boolean_symbol.rb +10 -7
- data/lib/rubocop/cop/lint/circular_argument_reference.rb +5 -15
- data/lib/rubocop/cop/lint/constant_definition_in_block.rb +30 -4
- data/lib/rubocop/cop/lint/constant_overwritten_in_rescue.rb +51 -0
- data/lib/rubocop/cop/lint/constant_reassignment.rb +148 -0
- data/lib/rubocop/cop/lint/constant_resolution.rb +7 -3
- data/lib/rubocop/cop/lint/cop_directive_syntax.rb +84 -0
- data/lib/rubocop/cop/lint/debugger.rb +99 -35
- data/lib/rubocop/cop/lint/deprecated_class_methods.rb +73 -63
- data/lib/rubocop/cop/lint/deprecated_constants.rb +88 -0
- data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +25 -21
- data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +24 -1
- data/lib/rubocop/cop/lint/duplicate_branch.rb +188 -0
- data/lib/rubocop/cop/lint/duplicate_case_condition.rb +4 -18
- data/lib/rubocop/cop/lint/duplicate_elsif_condition.rb +1 -1
- data/lib/rubocop/cop/lint/duplicate_hash_key.rb +4 -9
- data/lib/rubocop/cop/lint/duplicate_magic_comment.rb +73 -0
- data/lib/rubocop/cop/lint/duplicate_match_pattern.rb +122 -0
- data/lib/rubocop/cop/lint/duplicate_methods.rb +168 -58
- data/lib/rubocop/cop/lint/duplicate_regexp_character_class_element.rb +121 -0
- data/lib/rubocop/cop/lint/duplicate_require.rb +14 -4
- data/lib/rubocop/cop/lint/duplicate_rescue_exception.rb +1 -1
- data/lib/rubocop/cop/lint/duplicate_set_element.rb +87 -0
- data/lib/rubocop/cop/lint/each_with_object_argument.rb +3 -6
- data/lib/rubocop/cop/lint/else_layout.rb +32 -10
- data/lib/rubocop/cop/lint/empty_block.rb +94 -0
- data/lib/rubocop/cop/lint/empty_class.rb +95 -0
- data/lib/rubocop/cop/lint/empty_conditional_body.rb +85 -4
- data/lib/rubocop/cop/lint/empty_ensure.rb +3 -15
- data/lib/rubocop/cop/lint/empty_expression.rb +1 -3
- data/lib/rubocop/cop/lint/empty_file.rb +2 -6
- data/lib/rubocop/cop/lint/empty_in_pattern.rb +64 -0
- data/lib/rubocop/cop/lint/empty_interpolation.rb +5 -9
- data/lib/rubocop/cop/lint/empty_when.rb +5 -5
- data/lib/rubocop/cop/lint/ensure_return.rb +3 -13
- data/lib/rubocop/cop/lint/erb_new_arguments.rb +40 -43
- data/lib/rubocop/cop/lint/flip_flop.rb +8 -2
- data/lib/rubocop/cop/lint/float_comparison.rb +59 -16
- data/lib/rubocop/cop/lint/float_out_of_range.rb +2 -9
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +17 -22
- data/lib/rubocop/cop/lint/hash_compare_by_identity.rb +15 -4
- data/lib/rubocop/cop/lint/hash_new_with_keyword_arguments_as_default.rb +55 -0
- data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +18 -21
- data/lib/rubocop/cop/lint/identity_comparison.rb +19 -16
- data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +25 -15
- data/lib/rubocop/cop/lint/incompatible_io_select_with_fiber_scheduler.rb +81 -0
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +6 -16
- data/lib/rubocop/cop/lint/inherit_exception.rb +29 -29
- data/lib/rubocop/cop/lint/interpolation_check.rb +21 -13
- data/lib/rubocop/cop/lint/it_without_arguments_in_block.rb +50 -0
- data/lib/rubocop/cop/lint/lambda_without_literal_block.rb +51 -0
- data/lib/rubocop/cop/lint/literal_as_condition.rb +145 -13
- data/lib/rubocop/cop/lint/literal_assignment_in_condition.rb +85 -0
- data/lib/rubocop/cop/lint/literal_in_interpolation.rb +130 -18
- data/lib/rubocop/cop/lint/loop.rb +13 -19
- data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +48 -22
- data/lib/rubocop/cop/lint/missing_super.rb +70 -10
- data/lib/rubocop/cop/lint/mixed_case_range.rb +113 -0
- data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +3 -3
- data/lib/rubocop/cop/lint/multiple_comparison.rb +5 -4
- data/lib/rubocop/cop/lint/nested_method_definition.rb +64 -20
- data/lib/rubocop/cop/lint/nested_percent_literal.rb +17 -5
- data/lib/rubocop/cop/lint/next_without_accumulator.rb +11 -10
- data/lib/rubocop/cop/lint/no_return_in_begin_end_blocks.rb +53 -0
- data/lib/rubocop/cop/lint/non_atomic_file_operation.rb +174 -0
- data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +41 -18
- data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +7 -4
- data/lib/rubocop/cop/lint/number_conversion.rb +142 -21
- data/lib/rubocop/cop/lint/numbered_parameter_assignment.rb +46 -0
- data/lib/rubocop/cop/lint/numeric_operation_with_constant_result.rb +94 -0
- data/lib/rubocop/cop/lint/or_assignment_to_constant.rb +41 -0
- data/lib/rubocop/cop/lint/ordered_magic_comments.rb +5 -8
- data/lib/rubocop/cop/lint/out_of_range_regexp_ref.rb +63 -13
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +17 -15
- data/lib/rubocop/cop/lint/percent_string_array.rb +13 -7
- data/lib/rubocop/cop/lint/percent_symbol_array.rb +4 -10
- data/lib/rubocop/cop/lint/raise_exception.rb +36 -12
- data/lib/rubocop/cop/lint/rand_one.rb +3 -7
- data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +156 -97
- data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +33 -23
- data/lib/rubocop/cop/lint/redundant_dir_glob_sort.rb +62 -0
- data/lib/rubocop/cop/lint/redundant_regexp_quantifiers.rb +130 -0
- data/lib/rubocop/cop/lint/redundant_require_statement.rb +36 -6
- data/lib/rubocop/cop/lint/redundant_safe_navigation.rb +196 -15
- data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +67 -33
- data/lib/rubocop/cop/lint/redundant_string_coercion.rb +37 -21
- data/lib/rubocop/cop/lint/redundant_type_conversion.rb +261 -0
- data/lib/rubocop/cop/lint/redundant_with_index.rb +22 -14
- data/lib/rubocop/cop/lint/redundant_with_object.rb +17 -15
- data/lib/rubocop/cop/lint/refinement_import_methods.rb +52 -0
- data/lib/rubocop/cop/lint/regexp_as_condition.rb +9 -6
- data/lib/rubocop/cop/lint/require_parentheses.rb +6 -10
- data/lib/rubocop/cop/lint/require_range_parentheses.rb +57 -0
- data/lib/rubocop/cop/lint/require_relative_self_path.rb +50 -0
- data/lib/rubocop/cop/lint/rescue_exception.rb +2 -7
- data/lib/rubocop/cop/lint/rescue_type.rb +7 -18
- data/lib/rubocop/cop/lint/return_in_void_context.rb +13 -30
- data/lib/rubocop/cop/lint/safe_navigation_chain.rb +73 -19
- data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +109 -47
- data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +3 -3
- data/lib/rubocop/cop/lint/script_permission.rb +4 -4
- data/lib/rubocop/cop/lint/self_assignment.rb +72 -11
- data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +8 -12
- data/lib/rubocop/cop/lint/shadowed_argument.rb +8 -13
- data/lib/rubocop/cop/lint/shadowed_exception.rb +30 -43
- data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +68 -5
- data/lib/rubocop/cop/lint/shared_mutable_default.rb +76 -0
- data/lib/rubocop/cop/lint/struct_new_override.rb +16 -16
- data/lib/rubocop/cop/lint/suppressed_exception.rb +48 -5
- data/lib/rubocop/cop/lint/suppressed_exception_in_number_conversion.rb +111 -0
- data/lib/rubocop/cop/lint/symbol_conversion.rb +184 -0
- data/lib/rubocop/cop/lint/syntax.rb +17 -10
- data/lib/rubocop/cop/lint/to_enum_arguments.rb +99 -0
- data/lib/rubocop/cop/lint/to_json.rb +2 -3
- data/lib/rubocop/cop/lint/top_level_return_with_argument.rb +24 -10
- data/lib/rubocop/cop/lint/trailing_comma_in_attribute_declaration.rb +4 -6
- data/lib/rubocop/cop/lint/triple_quotes.rb +71 -0
- data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +2 -4
- data/lib/rubocop/cop/lint/unescaped_bracket_in_regexp.rb +88 -0
- data/lib/rubocop/cop/lint/unexpected_block_arity.rb +92 -0
- data/lib/rubocop/cop/lint/unified_integer.rb +4 -5
- data/lib/rubocop/cop/lint/unmodified_reduce_accumulator.rb +205 -0
- data/lib/rubocop/cop/lint/unreachable_code.rb +59 -14
- data/lib/rubocop/cop/lint/unreachable_loop.rb +48 -11
- data/lib/rubocop/cop/lint/unused_block_argument.rb +11 -9
- data/lib/rubocop/cop/lint/unused_method_argument.rb +29 -9
- data/lib/rubocop/cop/lint/uri_escape_unescape.rb +2 -1
- data/lib/rubocop/cop/lint/uri_regexp.rb +25 -7
- data/lib/rubocop/cop/lint/useless_access_modifier.rb +57 -24
- data/lib/rubocop/cop/lint/useless_assignment.rb +109 -25
- data/lib/rubocop/cop/lint/useless_constant_scoping.rb +71 -0
- data/lib/rubocop/cop/lint/useless_default_value_argument.rb +90 -0
- data/lib/rubocop/cop/lint/useless_defined.rb +55 -0
- data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +6 -7
- data/lib/rubocop/cop/lint/useless_method_definition.rb +18 -11
- data/lib/rubocop/cop/lint/useless_numeric_operation.rb +79 -0
- data/lib/rubocop/cop/lint/useless_or.rb +98 -0
- data/lib/rubocop/cop/lint/useless_rescue.rb +89 -0
- data/lib/rubocop/cop/lint/useless_ruby2_keywords.rb +127 -0
- data/lib/rubocop/cop/lint/useless_setter_call.rb +29 -37
- data/lib/rubocop/cop/lint/useless_times.rb +25 -17
- data/lib/rubocop/cop/lint/utils/nil_receiver_checker.rb +121 -0
- data/lib/rubocop/cop/lint/void.rb +156 -31
- data/lib/rubocop/cop/message_annotator.rb +12 -7
- data/lib/rubocop/cop/metrics/abc_size.rb +35 -3
- data/lib/rubocop/cop/metrics/block_length.rb +30 -16
- data/lib/rubocop/cop/metrics/block_nesting.rb +23 -16
- data/lib/rubocop/cop/metrics/class_length.rb +30 -20
- data/lib/rubocop/cop/metrics/collection_literal_length.rb +83 -0
- data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +7 -14
- data/lib/rubocop/cop/metrics/method_length.rb +32 -11
- data/lib/rubocop/cop/metrics/module_length.rb +17 -14
- data/lib/rubocop/cop/metrics/parameter_lists.rb +104 -7
- data/lib/rubocop/cop/metrics/perceived_complexity.rb +3 -4
- data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +28 -26
- data/lib/rubocop/cop/metrics/utils/code_length_calculator.rb +69 -18
- data/lib/rubocop/cop/metrics/utils/repeated_attribute_discount.rb +143 -0
- data/lib/rubocop/cop/metrics/utils/repeated_csend_discount.rb +6 -1
- data/lib/rubocop/cop/migration/department_name.rb +8 -10
- data/lib/rubocop/cop/mixin/alignment.rb +20 -11
- data/lib/rubocop/cop/mixin/allowed_identifiers.rb +18 -0
- data/lib/rubocop/cop/mixin/allowed_methods.rb +29 -2
- data/lib/rubocop/cop/mixin/allowed_pattern.rb +68 -0
- data/lib/rubocop/cop/mixin/allowed_receivers.rb +34 -0
- data/lib/rubocop/cop/mixin/annotation_comment.rb +56 -28
- data/lib/rubocop/cop/mixin/check_assignment.rb +4 -12
- data/lib/rubocop/cop/mixin/check_line_breakable.rb +53 -9
- data/lib/rubocop/cop/mixin/check_single_line_suitability.rb +49 -0
- data/lib/rubocop/cop/mixin/code_length.rb +17 -6
- data/lib/rubocop/cop/mixin/comments_help.rb +62 -15
- data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +23 -11
- data/lib/rubocop/cop/mixin/configurable_formatting.rb +4 -8
- data/lib/rubocop/cop/mixin/configurable_max.rb +5 -0
- data/lib/rubocop/cop/mixin/configurable_numbering.rb +4 -3
- data/lib/rubocop/cop/mixin/def_node.rb +5 -12
- data/lib/rubocop/cop/mixin/dig_help.rb +27 -0
- data/lib/rubocop/cop/mixin/documentation_comment.rb +8 -8
- data/lib/rubocop/cop/mixin/duplication.rb +1 -1
- data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +7 -8
- data/lib/rubocop/cop/mixin/empty_parameter.rb +2 -3
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +3 -6
- data/lib/rubocop/cop/mixin/endless_method_rewriter.rb +24 -0
- data/lib/rubocop/cop/mixin/enforce_superclass.rb +19 -7
- data/lib/rubocop/cop/mixin/first_element_line_break.rb +13 -11
- data/lib/rubocop/cop/mixin/forbidden_identifiers.rb +20 -0
- data/lib/rubocop/cop/mixin/forbidden_pattern.rb +16 -0
- data/lib/rubocop/cop/mixin/frozen_string_literal.rb +53 -16
- data/lib/rubocop/cop/mixin/gem_declaration.rb +13 -0
- data/lib/rubocop/cop/mixin/gemspec_help.rb +52 -0
- data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +34 -24
- data/lib/rubocop/cop/mixin/hash_shorthand_syntax.rb +236 -0
- data/lib/rubocop/cop/mixin/hash_subset.rb +203 -0
- data/lib/rubocop/cop/mixin/hash_transform_method.rb +83 -88
- data/lib/rubocop/cop/mixin/heredoc.rb +11 -2
- data/lib/rubocop/cop/mixin/interpolation.rb +1 -3
- data/lib/rubocop/cop/mixin/line_length_help.rb +65 -20
- data/lib/rubocop/cop/mixin/match_range.rb +2 -5
- data/lib/rubocop/cop/mixin/method_complexity.rb +33 -19
- data/lib/rubocop/cop/mixin/method_preference.rb +1 -2
- data/lib/rubocop/cop/mixin/min_branches_count.rb +40 -0
- data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +39 -16
- data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +6 -9
- data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +26 -55
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +2 -3
- data/lib/rubocop/cop/mixin/negative_conditional.rb +4 -2
- data/lib/rubocop/cop/mixin/ordered_gem_node.rb +12 -7
- data/lib/rubocop/cop/mixin/percent_array.rb +75 -9
- data/lib/rubocop/cop/mixin/percent_literal.rb +2 -8
- data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +79 -41
- data/lib/rubocop/cop/mixin/preferred_delimiters.rb +6 -9
- data/lib/rubocop/cop/mixin/range_help.rb +51 -22
- data/lib/rubocop/cop/mixin/rational_literal.rb +1 -0
- data/lib/rubocop/cop/mixin/require_library.rb +61 -0
- data/lib/rubocop/cop/mixin/rescue_node.rb +9 -7
- data/lib/rubocop/cop/mixin/safe_assignment.rb +7 -3
- data/lib/rubocop/cop/mixin/space_after_punctuation.rb +3 -5
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +3 -4
- data/lib/rubocop/cop/mixin/statement_modifier.rb +34 -10
- data/lib/rubocop/cop/mixin/string_help.rb +10 -5
- data/lib/rubocop/cop/mixin/string_literals_help.rb +15 -5
- data/lib/rubocop/cop/mixin/surrounding_space.rb +17 -13
- data/lib/rubocop/cop/mixin/symbol_help.rb +13 -0
- data/lib/rubocop/cop/mixin/target_ruby_version.rb +17 -1
- data/lib/rubocop/cop/mixin/trailing_body.rb +2 -3
- data/lib/rubocop/cop/mixin/trailing_comma.rb +26 -11
- data/lib/rubocop/cop/mixin/uncommunicative_name.rb +12 -14
- data/lib/rubocop/cop/mixin/unused_argument.rb +1 -3
- data/lib/rubocop/cop/mixin/visibility_help.rb +42 -8
- data/lib/rubocop/cop/naming/accessor_method_name.rb +23 -2
- data/lib/rubocop/cop/naming/ascii_identifiers.rb +4 -9
- data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +15 -5
- data/lib/rubocop/cop/naming/block_forwarding.rb +156 -0
- data/lib/rubocop/cop/naming/block_parameter_name.rb +3 -3
- data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +4 -2
- data/lib/rubocop/cop/naming/constant_name.rb +14 -14
- data/lib/rubocop/cop/naming/file_name.rb +48 -26
- data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +12 -6
- data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +4 -2
- data/lib/rubocop/cop/naming/inclusive_language.rb +297 -0
- data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +155 -32
- data/lib/rubocop/cop/naming/method_name.rb +191 -19
- data/lib/rubocop/cop/naming/method_parameter_name.rb +2 -2
- data/lib/rubocop/cop/naming/predicate_method.rb +306 -0
- data/lib/rubocop/cop/naming/predicate_prefix.rb +204 -0
- data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +72 -13
- data/lib/rubocop/cop/naming/variable_name.rb +65 -5
- data/lib/rubocop/cop/naming/variable_number.rb +107 -13
- data/lib/rubocop/cop/offense.rb +9 -15
- data/lib/rubocop/cop/registry.rb +95 -53
- data/lib/rubocop/cop/security/compound_hash.rb +108 -0
- data/lib/rubocop/cop/security/eval.rb +4 -2
- data/lib/rubocop/cop/security/io_methods.rb +49 -0
- data/lib/rubocop/cop/security/json_load.rb +10 -8
- data/lib/rubocop/cop/security/marshal_load.rb +2 -1
- data/lib/rubocop/cop/security/open.rb +28 -10
- data/lib/rubocop/cop/security/yaml_load.rb +16 -4
- data/lib/rubocop/cop/severity.rb +3 -3
- data/lib/rubocop/cop/style/access_modifier_declarations.rb +238 -8
- data/lib/rubocop/cop/style/accessor_grouping.rb +91 -29
- data/lib/rubocop/cop/style/alias.rb +26 -22
- data/lib/rubocop/cop/style/ambiguous_endless_method_definition.rb +79 -0
- data/lib/rubocop/cop/style/and_or.rb +29 -14
- data/lib/rubocop/cop/style/arguments_forwarding.rb +564 -0
- data/lib/rubocop/cop/style/array_coercion.rb +24 -4
- data/lib/rubocop/cop/style/array_first_last.rb +80 -0
- data/lib/rubocop/cop/style/array_intersect.rb +161 -0
- data/lib/rubocop/cop/style/array_join.rb +2 -1
- data/lib/rubocop/cop/style/ascii_comments.rb +4 -8
- data/lib/rubocop/cop/style/attr.rb +13 -4
- data/lib/rubocop/cop/style/auto_resource_cleanup.rb +22 -18
- data/lib/rubocop/cop/style/bare_percent_literals.rb +1 -1
- data/lib/rubocop/cop/style/begin_block.rb +1 -2
- data/lib/rubocop/cop/style/bisected_attr_accessor/macro.rb +60 -0
- data/lib/rubocop/cop/style/bisected_attr_accessor.rb +61 -77
- data/lib/rubocop/cop/style/bitwise_predicate.rb +100 -0
- data/lib/rubocop/cop/style/block_comments.rb +4 -4
- data/lib/rubocop/cop/style/block_delimiters.rb +144 -23
- data/lib/rubocop/cop/style/case_equality.rb +49 -21
- data/lib/rubocop/cop/style/case_like_if.rb +56 -31
- data/lib/rubocop/cop/style/character_literal.rb +20 -16
- data/lib/rubocop/cop/style/class_and_module_children.rb +97 -26
- data/lib/rubocop/cop/style/class_check.rb +2 -1
- data/lib/rubocop/cop/style/class_equality_comparison.rb +83 -13
- data/lib/rubocop/cop/style/class_methods.rb +2 -4
- data/lib/rubocop/cop/style/class_methods_definitions.rb +3 -2
- data/lib/rubocop/cop/style/class_vars.rb +4 -4
- data/lib/rubocop/cop/style/collection_compact.rb +143 -0
- data/lib/rubocop/cop/style/collection_methods.rb +27 -7
- data/lib/rubocop/cop/style/collection_querying.rb +167 -0
- data/lib/rubocop/cop/style/colon_method_call.rb +4 -5
- data/lib/rubocop/cop/style/colon_method_definition.rb +1 -1
- data/lib/rubocop/cop/style/combinable_defined.rb +115 -0
- data/lib/rubocop/cop/style/combinable_loops.rb +52 -12
- data/lib/rubocop/cop/style/command_literal.rb +6 -11
- data/lib/rubocop/cop/style/comment_annotation.rb +59 -32
- data/lib/rubocop/cop/style/commented_keyword.rb +65 -22
- data/lib/rubocop/cop/style/comparable_between.rb +78 -0
- data/lib/rubocop/cop/style/comparable_clamp.rb +125 -0
- data/lib/rubocop/cop/style/concat_array_literals.rb +95 -0
- data/lib/rubocop/cop/style/conditional_assignment.rb +88 -76
- data/lib/rubocop/cop/style/constant_visibility.rb +28 -9
- data/lib/rubocop/cop/style/copyright.rb +39 -29
- data/lib/rubocop/cop/style/data_inheritance.rb +82 -0
- data/lib/rubocop/cop/style/date_time.rb +16 -10
- data/lib/rubocop/cop/style/def_with_parentheses.rb +30 -15
- data/lib/rubocop/cop/style/dig_chain.rb +89 -0
- data/lib/rubocop/cop/style/dir.rb +5 -1
- data/lib/rubocop/cop/style/dir_empty.rb +54 -0
- data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +49 -9
- data/lib/rubocop/cop/style/document_dynamic_eval_definition.rb +169 -0
- data/lib/rubocop/cop/style/documentation.rb +95 -30
- data/lib/rubocop/cop/style/documentation_method.rb +31 -4
- data/lib/rubocop/cop/style/double_cop_disable_directive.rb +1 -7
- data/lib/rubocop/cop/style/double_negation.rb +97 -11
- data/lib/rubocop/cop/style/each_for_simple_loop.rb +45 -14
- data/lib/rubocop/cop/style/each_with_object.rb +42 -11
- data/lib/rubocop/cop/style/empty_block_parameter.rb +3 -3
- data/lib/rubocop/cop/style/empty_case_condition.rb +21 -12
- data/lib/rubocop/cop/style/empty_else.rb +52 -18
- data/lib/rubocop/cop/style/empty_heredoc.rb +60 -0
- data/lib/rubocop/cop/style/empty_lambda_parameter.rb +3 -3
- data/lib/rubocop/cop/style/empty_literal.rb +62 -33
- data/lib/rubocop/cop/style/empty_method.rb +19 -8
- data/lib/rubocop/cop/style/empty_string_inside_interpolation.rb +100 -0
- data/lib/rubocop/cop/style/encoding.rb +27 -16
- data/lib/rubocop/cop/style/end_block.rb +2 -3
- data/lib/rubocop/cop/style/endless_method.rb +233 -0
- data/lib/rubocop/cop/style/env_home.rb +56 -0
- data/lib/rubocop/cop/style/eval_with_location.rb +144 -63
- data/lib/rubocop/cop/style/even_odd.rb +2 -1
- data/lib/rubocop/cop/style/exact_regexp_match.rb +69 -0
- data/lib/rubocop/cop/style/expand_path_arguments.rb +7 -11
- data/lib/rubocop/cop/style/explicit_block_argument.rb +78 -18
- data/lib/rubocop/cop/style/exponential_notation.rb +12 -12
- data/lib/rubocop/cop/style/fetch_env_var.rb +159 -0
- data/lib/rubocop/cop/style/file_empty.rb +71 -0
- data/lib/rubocop/cop/style/file_null.rb +89 -0
- data/lib/rubocop/cop/style/file_read.rb +109 -0
- data/lib/rubocop/cop/style/file_touch.rb +75 -0
- data/lib/rubocop/cop/style/file_write.rb +133 -0
- data/lib/rubocop/cop/style/float_division.rb +68 -6
- data/lib/rubocop/cop/style/for.rb +13 -3
- data/lib/rubocop/cop/style/format_string.rb +44 -16
- data/lib/rubocop/cop/style/format_string_token.rb +163 -26
- data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +27 -18
- data/lib/rubocop/cop/style/global_std_stream.rb +16 -2
- data/lib/rubocop/cop/style/global_vars.rb +2 -4
- data/lib/rubocop/cop/style/guard_clause.rb +206 -32
- data/lib/rubocop/cop/style/hash_as_last_array_item.rb +12 -0
- data/lib/rubocop/cop/style/hash_conversion.rb +151 -0
- data/lib/rubocop/cop/style/hash_each_methods.rb +147 -12
- data/lib/rubocop/cop/style/hash_except.rb +80 -0
- data/lib/rubocop/cop/style/hash_fetch_chain.rb +104 -0
- data/lib/rubocop/cop/style/hash_like_case.rb +6 -11
- data/lib/rubocop/cop/style/hash_slice.rb +80 -0
- data/lib/rubocop/cop/style/hash_syntax.rb +117 -33
- data/lib/rubocop/cop/style/hash_transform_keys.rb +19 -15
- data/lib/rubocop/cop/style/hash_transform_values.rb +19 -14
- data/lib/rubocop/cop/style/identical_conditional_branches.rb +153 -10
- data/lib/rubocop/cop/style/if_inside_else.rb +67 -2
- data/lib/rubocop/cop/style/if_unless_modifier.rb +188 -29
- data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +4 -7
- data/lib/rubocop/cop/style/if_with_boolean_literal_branches.rb +163 -0
- data/lib/rubocop/cop/style/if_with_semicolon.rb +96 -7
- data/lib/rubocop/cop/style/implicit_runtime_error.rb +4 -3
- data/lib/rubocop/cop/style/in_pattern_then.rb +60 -0
- data/lib/rubocop/cop/style/infinite_loop.rb +9 -10
- data/lib/rubocop/cop/style/inline_comment.rb +1 -1
- data/lib/rubocop/cop/style/inverse_methods.rb +41 -28
- data/lib/rubocop/cop/style/invertible_unless_condition.rb +160 -0
- data/lib/rubocop/cop/style/ip_addresses.rb +5 -6
- data/lib/rubocop/cop/style/it_assignment.rb +93 -0
- data/lib/rubocop/cop/style/it_block_parameter.rb +121 -0
- data/lib/rubocop/cop/style/keyword_arguments_merging.rb +67 -0
- data/lib/rubocop/cop/style/keyword_parameters_order.rb +34 -6
- data/lib/rubocop/cop/style/lambda.rb +8 -9
- data/lib/rubocop/cop/style/lambda_call.rb +27 -24
- data/lib/rubocop/cop/style/line_end_concatenation.rb +31 -16
- data/lib/rubocop/cop/style/magic_comment_format.rb +307 -0
- data/lib/rubocop/cop/style/map_compact_with_conditional_block.rb +168 -0
- data/lib/rubocop/cop/style/map_into_array.rb +236 -0
- data/lib/rubocop/cop/style/map_to_hash.rb +90 -0
- data/lib/rubocop/cop/style/map_to_set.rb +63 -0
- data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +138 -53
- data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +11 -11
- data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +109 -36
- data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +62 -18
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +7 -7
- data/lib/rubocop/cop/style/method_def_parentheses.rb +37 -14
- data/lib/rubocop/cop/style/min_max.rb +6 -6
- data/lib/rubocop/cop/style/min_max_comparison.rb +91 -0
- data/lib/rubocop/cop/style/missing_else.rb +48 -33
- data/lib/rubocop/cop/style/missing_respond_to_missing.rb +37 -8
- data/lib/rubocop/cop/style/mixin_grouping.rb +10 -20
- data/lib/rubocop/cop/style/mixin_usage.rb +4 -3
- data/lib/rubocop/cop/style/module_function.rb +41 -18
- data/lib/rubocop/cop/style/multiline_block_chain.rb +7 -5
- data/lib/rubocop/cop/style/multiline_if_modifier.rb +4 -6
- data/lib/rubocop/cop/style/multiline_if_then.rb +1 -1
- data/lib/rubocop/cop/style/multiline_in_pattern_then.rb +60 -0
- data/lib/rubocop/cop/style/multiline_memoization.rb +5 -5
- data/lib/rubocop/cop/style/multiline_method_signature.rb +37 -3
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +54 -12
- data/lib/rubocop/cop/style/multiline_when_then.rb +8 -21
- data/lib/rubocop/cop/style/multiple_comparison.rb +104 -32
- data/lib/rubocop/cop/style/mutable_constant.rb +99 -28
- data/lib/rubocop/cop/style/negated_if.rb +1 -2
- data/lib/rubocop/cop/style/negated_if_else_condition.rb +137 -0
- data/lib/rubocop/cop/style/negated_unless.rb +1 -2
- data/lib/rubocop/cop/style/nested_file_dirname.rb +66 -0
- data/lib/rubocop/cop/style/nested_modifier.rb +5 -9
- data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +17 -4
- data/lib/rubocop/cop/style/nested_ternary_operator.rb +23 -19
- data/lib/rubocop/cop/style/next.rb +51 -14
- data/lib/rubocop/cop/style/nil_comparison.rb +9 -1
- data/lib/rubocop/cop/style/nil_lambda.rb +70 -0
- data/lib/rubocop/cop/style/non_nil_check.rb +32 -18
- data/lib/rubocop/cop/style/not.rb +5 -5
- data/lib/rubocop/cop/style/numbered_parameters.rb +46 -0
- data/lib/rubocop/cop/style/numbered_parameters_limit.rb +58 -0
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +2 -2
- data/lib/rubocop/cop/style/numeric_literals.rb +44 -29
- data/lib/rubocop/cop/style/numeric_predicate.rb +73 -20
- data/lib/rubocop/cop/style/object_then.rb +76 -0
- data/lib/rubocop/cop/style/one_line_conditional.rb +46 -46
- data/lib/rubocop/cop/style/open_struct_use.rb +69 -0
- data/lib/rubocop/cop/style/operator_method_call.rb +91 -0
- data/lib/rubocop/cop/style/option_hash.rb +3 -4
- data/lib/rubocop/cop/style/optional_arguments.rb +7 -6
- data/lib/rubocop/cop/style/optional_boolean_parameter.rb +16 -5
- data/lib/rubocop/cop/style/or_assignment.rb +8 -13
- data/lib/rubocop/cop/style/parallel_assignment.rb +81 -66
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +22 -3
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +6 -9
- data/lib/rubocop/cop/style/percent_q_literals.rb +6 -7
- data/lib/rubocop/cop/style/perl_backrefs.rb +101 -10
- data/lib/rubocop/cop/style/preferred_hash_methods.rb +11 -9
- data/lib/rubocop/cop/style/proc.rb +6 -3
- data/lib/rubocop/cop/style/quoted_symbols.rb +122 -0
- data/lib/rubocop/cop/style/raise_args.rb +57 -30
- data/lib/rubocop/cop/style/random_with_offset.rb +12 -12
- data/lib/rubocop/cop/style/redundant_argument.rb +129 -0
- data/lib/rubocop/cop/style/redundant_array_constructor.rb +77 -0
- data/lib/rubocop/cop/style/redundant_array_flatten.rb +50 -0
- data/lib/rubocop/cop/style/redundant_assignment.rb +14 -7
- data/lib/rubocop/cop/style/redundant_begin.rb +96 -8
- data/lib/rubocop/cop/style/redundant_capital_w.rb +3 -5
- data/lib/rubocop/cop/style/redundant_condition.rb +235 -32
- data/lib/rubocop/cop/style/redundant_conditional.rb +6 -19
- data/lib/rubocop/cop/style/redundant_constant_base.rb +85 -0
- data/lib/rubocop/cop/style/redundant_current_directory_in_path.rb +50 -0
- data/lib/rubocop/cop/style/redundant_double_splat_hash_braces.rb +129 -0
- data/lib/rubocop/cop/style/redundant_each.rb +119 -0
- data/lib/rubocop/cop/style/redundant_exception.rb +36 -17
- data/lib/rubocop/cop/style/redundant_fetch_block.rb +17 -17
- data/lib/rubocop/cop/style/redundant_file_extension_in_require.rb +15 -5
- data/lib/rubocop/cop/style/redundant_filter_chain.rb +118 -0
- data/lib/rubocop/cop/style/redundant_format.rb +262 -0
- data/lib/rubocop/cop/style/redundant_freeze.rb +12 -8
- data/lib/rubocop/cop/style/redundant_heredoc_delimiter_quotes.rb +58 -0
- data/lib/rubocop/cop/style/redundant_initialize.rb +165 -0
- data/lib/rubocop/cop/style/redundant_interpolation.rb +42 -8
- data/lib/rubocop/cop/style/redundant_interpolation_unfreeze.rb +46 -0
- data/lib/rubocop/cop/style/redundant_line_continuation.rb +236 -0
- data/lib/rubocop/cop/style/redundant_parentheses.rb +184 -66
- data/lib/rubocop/cop/style/redundant_percent_q.rb +6 -8
- data/lib/rubocop/cop/style/redundant_regexp_argument.rb +107 -0
- data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +27 -6
- data/lib/rubocop/cop/style/redundant_regexp_constructor.rb +46 -0
- data/lib/rubocop/cop/style/redundant_regexp_escape.rb +24 -9
- data/lib/rubocop/cop/style/redundant_return.rb +28 -8
- data/lib/rubocop/cop/style/redundant_self.rb +70 -21
- data/lib/rubocop/cop/style/redundant_self_assignment.rb +27 -37
- data/lib/rubocop/cop/style/redundant_self_assignment_branch.rb +90 -0
- data/lib/rubocop/cop/style/redundant_sort.rb +81 -34
- data/lib/rubocop/cop/style/redundant_sort_by.rb +41 -8
- data/lib/rubocop/cop/style/redundant_string_escape.rb +185 -0
- data/lib/rubocop/cop/style/regexp_literal.rb +25 -11
- data/lib/rubocop/cop/style/require_order.rb +139 -0
- data/lib/rubocop/cop/style/rescue_modifier.rb +39 -20
- data/lib/rubocop/cop/style/rescue_standard_error.rb +19 -21
- data/lib/rubocop/cop/style/return_nil.rb +16 -6
- data/lib/rubocop/cop/style/return_nil_in_predicate_method_definition.rb +137 -0
- data/lib/rubocop/cop/style/safe_navigation.rb +222 -89
- data/lib/rubocop/cop/style/safe_navigation_chain_length.rb +52 -0
- data/lib/rubocop/cop/style/sample.rb +10 -8
- data/lib/rubocop/cop/style/select_by_regexp.rb +169 -0
- data/lib/rubocop/cop/style/self_assignment.rb +15 -21
- data/lib/rubocop/cop/style/semicolon.rb +101 -27
- data/lib/rubocop/cop/style/send.rb +6 -7
- data/lib/rubocop/cop/style/send_with_literal_method_name.rb +105 -0
- data/lib/rubocop/cop/style/signal_exception.rb +17 -17
- data/lib/rubocop/cop/style/single_argument_dig.rb +26 -8
- data/lib/rubocop/cop/style/single_line_block_params.rb +38 -16
- data/lib/rubocop/cop/style/single_line_do_end_block.rb +78 -0
- data/lib/rubocop/cop/style/single_line_methods.rb +78 -15
- data/lib/rubocop/cop/style/slicing_with_range.rb +119 -10
- data/lib/rubocop/cop/style/sole_nested_conditional.rb +178 -7
- data/lib/rubocop/cop/style/special_global_vars.rb +97 -40
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +2 -3
- data/lib/rubocop/cop/style/static_class.rb +128 -0
- data/lib/rubocop/cop/style/stderr_puts.rb +4 -7
- data/lib/rubocop/cop/style/string_chars.rb +42 -0
- data/lib/rubocop/cop/style/string_concatenation.rb +96 -24
- data/lib/rubocop/cop/style/string_hash_keys.rb +11 -2
- data/lib/rubocop/cop/style/string_literals.rb +21 -21
- data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +35 -8
- data/lib/rubocop/cop/style/string_methods.rb +2 -2
- data/lib/rubocop/cop/style/strip.rb +9 -5
- data/lib/rubocop/cop/style/struct_inheritance.rb +27 -5
- data/lib/rubocop/cop/style/super_arguments.rb +221 -0
- data/lib/rubocop/cop/style/super_with_args_parentheses.rb +35 -0
- data/lib/rubocop/cop/style/swap_values.rb +101 -0
- data/lib/rubocop/cop/style/symbol_array.rb +47 -22
- data/lib/rubocop/cop/style/symbol_literal.rb +2 -4
- data/lib/rubocop/cop/style/symbol_proc.rb +198 -22
- data/lib/rubocop/cop/style/ternary_parentheses.rb +49 -29
- data/lib/rubocop/cop/style/top_level_method_definition.rb +86 -0
- data/lib/rubocop/cop/style/trailing_body_on_class.rb +2 -1
- data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +7 -3
- data/lib/rubocop/cop/style/trailing_body_on_module.rb +1 -1
- data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +16 -7
- data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +48 -7
- data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +24 -9
- data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +49 -7
- data/lib/rubocop/cop/style/trailing_method_end_statement.rb +5 -11
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +12 -16
- data/lib/rubocop/cop/style/trivial_accessors.rb +82 -16
- data/lib/rubocop/cop/style/unless_else.rb +6 -3
- data/lib/rubocop/cop/style/unless_logical_operators.rb +106 -0
- data/lib/rubocop/cop/style/unpack_first.rb +16 -15
- data/lib/rubocop/cop/style/variable_interpolation.rb +2 -3
- data/lib/rubocop/cop/style/when_then.rb +5 -3
- data/lib/rubocop/cop/style/while_until_do.rb +0 -2
- data/lib/rubocop/cop/style/while_until_modifier.rb +11 -7
- data/lib/rubocop/cop/style/word_array.rb +79 -8
- data/lib/rubocop/cop/style/yaml_file_read.rb +66 -0
- data/lib/rubocop/cop/style/yoda_condition.rb +52 -29
- data/lib/rubocop/cop/style/yoda_expression.rb +92 -0
- data/lib/rubocop/cop/style/zero_length_predicate.rb +77 -38
- data/lib/rubocop/cop/team.rb +94 -61
- data/lib/rubocop/cop/util.rb +100 -24
- data/lib/rubocop/cop/utils/format_string.rb +11 -8
- data/lib/rubocop/cop/variable_force/assignment.rb +66 -7
- data/lib/rubocop/cop/variable_force/branch.rb +19 -5
- data/lib/rubocop/cop/variable_force/reference.rb +1 -3
- data/lib/rubocop/cop/variable_force/scope.rb +8 -12
- data/lib/rubocop/cop/variable_force/variable.rb +20 -9
- data/lib/rubocop/cop/variable_force/variable_table.rb +9 -7
- data/lib/rubocop/cop/variable_force.rb +63 -66
- data/lib/rubocop/cops_documentation_generator.rb +197 -75
- data/lib/rubocop/core_ext/string.rb +2 -6
- data/lib/rubocop/directive_comment.rb +158 -10
- data/lib/rubocop/ext/comment.rb +18 -0
- data/lib/rubocop/ext/processed_source.rb +2 -0
- data/lib/rubocop/ext/range.rb +15 -0
- data/lib/rubocop/ext/regexp_node.rb +18 -11
- data/lib/rubocop/ext/regexp_parser.rb +78 -0
- data/lib/rubocop/feature_loader.rb +94 -0
- data/lib/rubocop/file_finder.rb +12 -12
- data/lib/rubocop/file_patterns.rb +43 -0
- data/lib/rubocop/formatter/clang_style_formatter.rb +8 -10
- data/lib/rubocop/formatter/disabled_config_formatter.rb +92 -32
- data/lib/rubocop/formatter/emacs_style_formatter.rb +2 -0
- data/lib/rubocop/formatter/formatter_set.rb +29 -20
- data/lib/rubocop/formatter/fuubar_style_formatter.rb +1 -1
- data/lib/rubocop/formatter/github_actions_formatter.rb +57 -0
- data/lib/rubocop/formatter/html_formatter.rb +50 -38
- data/lib/rubocop/formatter/json_formatter.rb +5 -7
- data/lib/rubocop/formatter/junit_formatter.rb +85 -26
- data/lib/rubocop/formatter/markdown_formatter.rb +79 -0
- data/lib/rubocop/formatter/offense_count_formatter.rb +28 -9
- data/lib/rubocop/formatter/pacman_formatter.rb +2 -1
- data/lib/rubocop/formatter/progress_formatter.rb +1 -3
- data/lib/rubocop/formatter/simple_text_formatter.rb +13 -9
- data/lib/rubocop/formatter/tap_formatter.rb +10 -10
- data/lib/rubocop/formatter/worst_offenders_formatter.rb +8 -6
- data/lib/rubocop/formatter.rb +34 -0
- data/lib/rubocop/lockfile.rb +91 -0
- data/lib/rubocop/lsp/diagnostic.rb +189 -0
- data/lib/rubocop/lsp/logger.rb +22 -0
- data/lib/rubocop/lsp/routes.rb +227 -0
- data/lib/rubocop/lsp/runtime.rb +69 -0
- data/lib/rubocop/lsp/server.rb +70 -0
- data/lib/rubocop/lsp/severity.rb +27 -0
- data/lib/rubocop/lsp/stdin_runner.rb +85 -0
- data/lib/rubocop/lsp.rb +36 -0
- data/lib/rubocop/magic_comment.rb +115 -21
- data/lib/rubocop/name_similarity.rb +1 -1
- data/lib/rubocop/options.rb +348 -197
- data/lib/rubocop/path_util.rb +62 -25
- data/lib/rubocop/pending_cops_reporter.rb +56 -0
- data/lib/rubocop/plugin/configuration_integrator.rb +143 -0
- data/lib/rubocop/plugin/load_error.rb +26 -0
- data/lib/rubocop/plugin/loader.rb +100 -0
- data/lib/rubocop/plugin/not_supported_error.rb +29 -0
- data/lib/rubocop/plugin.rb +46 -0
- data/lib/rubocop/rake_task.rb +42 -11
- data/lib/rubocop/remote_config.rb +20 -13
- data/lib/rubocop/result_cache.rb +60 -57
- data/lib/rubocop/rspec/cop_helper.rb +45 -8
- data/lib/rubocop/rspec/expect_offense.rb +80 -45
- data/lib/rubocop/rspec/parallel_formatter.rb +90 -0
- data/lib/rubocop/rspec/shared_contexts.rb +164 -33
- data/lib/rubocop/rspec/support.rb +24 -3
- data/lib/rubocop/runner.rb +168 -52
- data/lib/rubocop/server/cache.rb +208 -0
- data/lib/rubocop/server/cli.rb +147 -0
- data/lib/rubocop/server/client_command/base.rb +54 -0
- data/lib/rubocop/server/client_command/exec.rb +65 -0
- data/lib/rubocop/server/client_command/restart.rb +25 -0
- data/lib/rubocop/server/client_command/start.rb +58 -0
- data/lib/rubocop/server/client_command/status.rb +28 -0
- data/lib/rubocop/server/client_command/stop.rb +31 -0
- data/lib/rubocop/server/client_command.rb +26 -0
- data/lib/rubocop/server/core.rb +116 -0
- data/lib/rubocop/server/errors.rb +23 -0
- data/lib/rubocop/server/helper.rb +34 -0
- data/lib/rubocop/server/server_command/base.rb +50 -0
- data/lib/rubocop/server/server_command/exec.rb +33 -0
- data/lib/rubocop/server/server_command/stop.rb +24 -0
- data/lib/rubocop/server/server_command.rb +21 -0
- data/lib/rubocop/server/socket_reader.rb +69 -0
- data/lib/rubocop/server.rb +53 -0
- data/lib/rubocop/string_interpreter.rb +7 -7
- data/lib/rubocop/target_finder.rb +113 -93
- data/lib/rubocop/target_ruby.rb +156 -19
- data/lib/rubocop/util.rb +16 -0
- data/lib/rubocop/version.rb +139 -8
- data/lib/rubocop/yaml_duplication_checker.rb +20 -26
- data/lib/rubocop.rb +219 -39
- data/lib/ruby_lsp/rubocop/addon.rb +75 -0
- data/lib/ruby_lsp/rubocop/runtime_adapter.rb +65 -0
- metadata +352 -66
- data/bin/console +0 -10
- data/bin/rubocop-profile +0 -32
- data/bin/setup +0 -7
- data/lib/rubocop/cop/mixin/ignored_methods.rb +0 -19
- data/lib/rubocop/cop/mixin/ignored_pattern.rb +0 -29
- data/lib/rubocop/cop/naming/predicate_name.rb +0 -104
- data/lib/rubocop/rspec/host_environment_simulation_helper.rb +0 -28
@@ -6,28 +6,28 @@ module RuboCop
|
|
6
6
|
class MethodCallWithArgsParentheses
|
7
7
|
# Style require_parentheses
|
8
8
|
module RequireParentheses
|
9
|
-
|
10
|
-
|
11
|
-
|
9
|
+
REQUIRE_MSG = 'Use parentheses for method calls with arguments.'
|
10
|
+
private_constant :REQUIRE_MSG
|
11
|
+
|
12
|
+
private
|
13
|
+
|
14
|
+
def require_parentheses(node)
|
15
|
+
return if allowed_method_name?(node.method_name)
|
16
|
+
return if matches_allowed_pattern?(node.method_name)
|
12
17
|
return if eligible_for_parentheses_omission?(node)
|
13
18
|
return unless node.arguments? && !node.parenthesized?
|
14
19
|
|
15
|
-
add_offense(node) do |corrector|
|
20
|
+
add_offense(node, message: REQUIRE_MSG) do |corrector|
|
16
21
|
corrector.replace(args_begin(node), '(')
|
17
22
|
|
18
23
|
corrector.insert_after(args_end(node), ')') unless args_parenthesized?(node)
|
19
24
|
end
|
20
25
|
end
|
21
|
-
alias on_csend on_send
|
22
|
-
alias on_super on_send
|
23
|
-
alias on_yield on_send
|
24
26
|
|
25
|
-
def
|
26
|
-
|
27
|
+
def allowed_method_name?(name)
|
28
|
+
allowed_method?(name) || matches_allowed_pattern?(name)
|
27
29
|
end
|
28
30
|
|
29
|
-
private
|
30
|
-
|
31
31
|
def eligible_for_parentheses_omission?(node)
|
32
32
|
node.operator_method? || node.setter_method? || ignored_macro?(node)
|
33
33
|
end
|
@@ -3,25 +3,23 @@
|
|
3
3
|
module RuboCop
|
4
4
|
module Cop
|
5
5
|
module Style
|
6
|
-
#
|
7
|
-
# method calls containing
|
6
|
+
# Enforces the presence (default) or absence of parentheses in
|
7
|
+
# method calls containing arguments.
|
8
8
|
#
|
9
|
-
# In the default style (require_parentheses), macro methods are
|
10
|
-
# Additional methods can be added to the `
|
11
|
-
#
|
12
|
-
#
|
13
|
-
#
|
14
|
-
# the `IncludedMacros` list.
|
9
|
+
# In the default style (require_parentheses), macro methods are allowed.
|
10
|
+
# Additional methods can be added to the `AllowedMethods` or
|
11
|
+
# `AllowedPatterns` list. These options are valid only in the default
|
12
|
+
# style. Macros can be included by either setting `IgnoreMacros` to false
|
13
|
+
# or adding specific macros to the `IncludedMacros` list.
|
15
14
|
#
|
16
|
-
# Precedence of options is
|
15
|
+
# Precedence of options is as follows:
|
17
16
|
#
|
18
|
-
# 1. `
|
19
|
-
# 2. `
|
17
|
+
# 1. `AllowedMethods`
|
18
|
+
# 2. `AllowedPatterns`
|
20
19
|
# 3. `IncludedMacros`
|
21
20
|
#
|
22
|
-
#
|
23
|
-
#
|
24
|
-
# precedence (that is, the method is ignored).
|
21
|
+
# If a method is listed in both `IncludedMacros` and `AllowedMethods`,
|
22
|
+
# then the latter takes precedence (that is, the method is allowed).
|
25
23
|
#
|
26
24
|
# In the alternative style (omit_parentheses), there are three additional
|
27
25
|
# options.
|
@@ -40,6 +38,32 @@ module RuboCop
|
|
40
38
|
# to `true` allows the presence of parentheses in such a method call
|
41
39
|
# even with arguments.
|
42
40
|
#
|
41
|
+
# NOTE: The style of `omit_parentheses` allows parentheses in cases where
|
42
|
+
# omitting them results in ambiguous or syntactically incorrect code.
|
43
|
+
#
|
44
|
+
# Non-exhaustive list of examples:
|
45
|
+
#
|
46
|
+
# - Parentheses are required allowed in method calls with arguments inside
|
47
|
+
# literals, logical operators, setting default values in position and
|
48
|
+
# keyword arguments, chaining and more.
|
49
|
+
# - Parentheses are allowed in method calls with arguments inside
|
50
|
+
# operators to avoid ambiguity.
|
51
|
+
# triple-dot syntax introduced in Ruby 2.7 as omitting them starts an
|
52
|
+
# endless range.
|
53
|
+
# - Parentheses are allowed when forwarding arguments with the
|
54
|
+
# triple-dot syntax introduced in Ruby 2.7 as omitting them starts an
|
55
|
+
# endless range.
|
56
|
+
# - Parentheses are required in calls with arguments when inside an
|
57
|
+
# endless method definition introduced in Ruby 3.0.
|
58
|
+
# - Ruby 3.1's hash omission syntax allows parentheses if the method call
|
59
|
+
# is in conditionals and requires parentheses if the call
|
60
|
+
# is not the value-returning expression. See
|
61
|
+
# https://bugs.ruby-lang.org/issues/18396.
|
62
|
+
# - Parentheses are required in anonymous arguments, keyword arguments
|
63
|
+
# and block passing in Ruby 3.2.
|
64
|
+
# - Parentheses are required when the first argument is a beginless range or
|
65
|
+
# the last argument is an endless range.
|
66
|
+
#
|
43
67
|
# @example EnforcedStyle: require_parentheses (default)
|
44
68
|
#
|
45
69
|
# # bad
|
@@ -56,10 +80,10 @@ module RuboCop
|
|
56
80
|
# # Setter methods don't need parens
|
57
81
|
# foo.bar = baz
|
58
82
|
#
|
59
|
-
# # okay with `puts` listed in `
|
83
|
+
# # okay with `puts` listed in `AllowedMethods`
|
60
84
|
# puts 'test'
|
61
85
|
#
|
62
|
-
# # okay with `^assert` listed in `
|
86
|
+
# # okay with `^assert` listed in `AllowedPatterns`
|
63
87
|
# assert_equal 'test', x
|
64
88
|
#
|
65
89
|
# @example EnforcedStyle: omit_parentheses
|
@@ -71,10 +95,28 @@ module RuboCop
|
|
71
95
|
# array.delete e
|
72
96
|
#
|
73
97
|
# # bad
|
74
|
-
#
|
98
|
+
# action.enforce(strict: true)
|
99
|
+
#
|
100
|
+
# # good
|
101
|
+
# action.enforce strict: true
|
102
|
+
#
|
103
|
+
# # good
|
104
|
+
# # Parentheses are allowed for code that can be ambiguous without
|
105
|
+
# # them.
|
106
|
+
# action.enforce(condition) || other_condition
|
107
|
+
#
|
108
|
+
# # good
|
109
|
+
# # Parentheses are allowed for calls that won't produce valid Ruby
|
110
|
+
# # without them.
|
111
|
+
# yield path, File.basename(path)
|
75
112
|
#
|
76
113
|
# # good
|
77
|
-
#
|
114
|
+
# # Omitting the parentheses in Ruby 3.1 hash omission syntax can lead
|
115
|
+
# # to ambiguous code. We allow them in conditionals and non-last
|
116
|
+
# # expressions. See https://bugs.ruby-lang.org/issues/18396
|
117
|
+
# if meets(criteria:, action:)
|
118
|
+
# safe_action(action) || dangerous_action(action)
|
119
|
+
# end
|
78
120
|
#
|
79
121
|
# @example IgnoreMacros: true (default)
|
80
122
|
#
|
@@ -90,6 +132,22 @@ module RuboCop
|
|
90
132
|
# bar :baz
|
91
133
|
# end
|
92
134
|
#
|
135
|
+
# @example AllowedMethods: ["puts", "print"]
|
136
|
+
#
|
137
|
+
# # good
|
138
|
+
# puts "Hello world"
|
139
|
+
# print "Hello world"
|
140
|
+
# # still enforces parentheses on other methods
|
141
|
+
# array.delete(e)
|
142
|
+
#
|
143
|
+
# @example AllowedPatterns: ["^assert"]
|
144
|
+
#
|
145
|
+
# # good
|
146
|
+
# assert_equal 'test', x
|
147
|
+
# assert_match(/foo/, bar)
|
148
|
+
# # still enforces parentheses on other methods
|
149
|
+
# array.delete(e)
|
150
|
+
#
|
93
151
|
# @example AllowParenthesesInMultilineCall: false (default)
|
94
152
|
#
|
95
153
|
# # bad
|
@@ -143,46 +201,61 @@ module RuboCop
|
|
143
201
|
#
|
144
202
|
# # good
|
145
203
|
# Array 1
|
204
|
+
#
|
205
|
+
# @example AllowParenthesesInStringInterpolation: false (default)
|
206
|
+
#
|
207
|
+
# # bad
|
208
|
+
# "#{t('this.is.bad')}"
|
209
|
+
#
|
210
|
+
# # good
|
211
|
+
# "#{t 'this.is.better'}"
|
212
|
+
#
|
213
|
+
# @example AllowParenthesesInStringInterpolation: true
|
214
|
+
#
|
215
|
+
# # good
|
216
|
+
# "#{t('this.is.good')}"
|
217
|
+
#
|
218
|
+
# # good
|
219
|
+
# "#{t 'this.is.also.good'}"
|
146
220
|
class MethodCallWithArgsParentheses < Base
|
221
|
+
require_relative 'method_call_with_args_parentheses/omit_parentheses'
|
222
|
+
require_relative 'method_call_with_args_parentheses/require_parentheses'
|
223
|
+
|
147
224
|
include ConfigurableEnforcedStyle
|
148
|
-
include
|
149
|
-
include
|
225
|
+
include AllowedMethods
|
226
|
+
include AllowedPattern
|
227
|
+
include RequireParentheses
|
228
|
+
include OmitParentheses
|
150
229
|
extend AutoCorrector
|
151
230
|
|
152
|
-
def
|
153
|
-
|
154
|
-
return unless style_configured?
|
155
|
-
|
156
|
-
case style
|
157
|
-
when :require_parentheses
|
158
|
-
extend RequireParentheses
|
159
|
-
when :omit_parentheses
|
160
|
-
extend OmitParentheses
|
161
|
-
end
|
231
|
+
def self.autocorrect_incompatible_with
|
232
|
+
[Style::NestedParenthesizedCalls, Style::RescueModifier]
|
162
233
|
end
|
163
234
|
|
164
|
-
|
165
|
-
|
235
|
+
def on_send(node)
|
236
|
+
send(style, node) # call require_parentheses or omit_parentheses
|
237
|
+
end
|
238
|
+
alias on_csend on_send
|
239
|
+
alias on_yield on_send
|
166
240
|
|
167
241
|
private
|
168
242
|
|
169
243
|
def args_begin(node)
|
170
244
|
loc = node.loc
|
171
|
-
selector =
|
172
|
-
node.super_type? || node.yield_type? ? loc.keyword : loc.selector
|
245
|
+
selector = node.yield_type? ? loc.keyword : loc.selector
|
173
246
|
|
174
247
|
resize_by = args_parenthesized?(node) ? 2 : 1
|
175
248
|
selector.end.resize(resize_by)
|
176
249
|
end
|
177
250
|
|
178
251
|
def args_end(node)
|
179
|
-
node.
|
252
|
+
node.source_range.end
|
180
253
|
end
|
181
254
|
|
182
255
|
def args_parenthesized?(node)
|
183
256
|
return false unless node.arguments.one?
|
184
257
|
|
185
|
-
first_node = node.
|
258
|
+
first_node = node.first_argument
|
186
259
|
first_node.begin_type? && first_node.parenthesized_call?
|
187
260
|
end
|
188
261
|
end
|
@@ -3,7 +3,13 @@
|
|
3
3
|
module RuboCop
|
4
4
|
module Cop
|
5
5
|
module Style
|
6
|
-
#
|
6
|
+
# Checks for unwanted parentheses in parameterless method calls.
|
7
|
+
#
|
8
|
+
# This cop's allowed methods can be customized with `AllowedMethods`.
|
9
|
+
# By default, there are no allowed methods.
|
10
|
+
#
|
11
|
+
# NOTE: This cop allows the use of `it()` without arguments in blocks,
|
12
|
+
# as in `0.times { it() }`, following `Lint/ItWithoutArgumentsInBlock` cop.
|
7
13
|
#
|
8
14
|
# @example
|
9
15
|
# # bad
|
@@ -11,39 +17,83 @@ module RuboCop
|
|
11
17
|
#
|
12
18
|
# # good
|
13
19
|
# object.some_method
|
20
|
+
#
|
21
|
+
# @example AllowedMethods: [] (default)
|
22
|
+
# # bad
|
23
|
+
# object.foo()
|
24
|
+
#
|
25
|
+
# @example AllowedMethods: [foo]
|
26
|
+
# # good
|
27
|
+
# object.foo()
|
28
|
+
#
|
14
29
|
class MethodCallWithoutArgsParentheses < Base
|
15
|
-
include
|
30
|
+
include AllowedMethods
|
31
|
+
include AllowedPattern
|
16
32
|
extend AutoCorrector
|
17
33
|
|
18
|
-
MSG = 'Do not use parentheses for method calls with '
|
19
|
-
'no arguments.'
|
34
|
+
MSG = 'Do not use parentheses for method calls with no arguments.'
|
20
35
|
|
36
|
+
# rubocop:disable Metrics/CyclomaticComplexity
|
21
37
|
def on_send(node)
|
22
38
|
return unless !node.arguments? && node.parenthesized?
|
23
39
|
return if ineligible_node?(node)
|
24
|
-
return if
|
40
|
+
return if default_argument?(node)
|
41
|
+
return if allowed_method_name?(node.method_name)
|
25
42
|
return if same_name_assignment?(node)
|
43
|
+
return if parenthesized_it_method_in_block?(node)
|
26
44
|
|
45
|
+
register_offense(node)
|
46
|
+
end
|
47
|
+
# rubocop:enable Metrics/CyclomaticComplexity
|
48
|
+
alias on_csend on_send
|
49
|
+
|
50
|
+
private
|
51
|
+
|
52
|
+
def register_offense(node)
|
27
53
|
add_offense(offense_range(node)) do |corrector|
|
28
54
|
corrector.remove(node.loc.begin)
|
29
55
|
corrector.remove(node.loc.end)
|
30
56
|
end
|
31
57
|
end
|
32
58
|
|
33
|
-
private
|
34
|
-
|
35
59
|
def ineligible_node?(node)
|
36
60
|
node.camel_case_method? || node.implicit_call? || node.prefix_not?
|
37
61
|
end
|
38
62
|
|
63
|
+
def default_argument?(node)
|
64
|
+
node.parent&.optarg_type?
|
65
|
+
end
|
66
|
+
|
67
|
+
def allowed_method_name?(name)
|
68
|
+
allowed_method?(name) || matches_allowed_pattern?(name)
|
69
|
+
end
|
70
|
+
|
39
71
|
def same_name_assignment?(node)
|
40
|
-
|
41
|
-
next variable_in_mass_assignment?(node.method_name, asgn_node) if asgn_node.masgn_type?
|
72
|
+
return false if node.receiver
|
42
73
|
|
43
|
-
|
74
|
+
any_assignment?(node) do |asgn_node|
|
75
|
+
if asgn_node.masgn_type?
|
76
|
+
variable_in_mass_assignment?(node.method_name, asgn_node)
|
77
|
+
else
|
78
|
+
asgn_node.loc.name.source == node.method_name.to_s
|
79
|
+
end
|
44
80
|
end
|
45
81
|
end
|
46
82
|
|
83
|
+
# Respects `Lint/ItWithoutArgumentsInBlock` cop and the following Ruby 3.3's warning:
|
84
|
+
#
|
85
|
+
# $ ruby -e '0.times { begin; it; end }'
|
86
|
+
# -e:1: warning: `it` calls without arguments will refer to the first block param in
|
87
|
+
# Ruby 3.4; use it() or self.it
|
88
|
+
#
|
89
|
+
def parenthesized_it_method_in_block?(node)
|
90
|
+
return false unless node.method?(:it)
|
91
|
+
return false unless (block_node = node.each_ancestor(:block).first)
|
92
|
+
return false unless block_node.arguments.empty_and_without_delimiters?
|
93
|
+
|
94
|
+
!node.receiver && node.arguments.empty? && !node.block_literal?
|
95
|
+
end
|
96
|
+
|
47
97
|
def any_assignment?(node)
|
48
98
|
node.each_ancestor(*AST::Node::ASSIGNMENTS).any? do |asgn_node|
|
49
99
|
# `obj.method = value` parses as (send ... :method= ...), and will
|
@@ -51,20 +101,14 @@ module RuboCop
|
|
51
101
|
# `obj.method ||= value` parses as (or-asgn (send ...) ...)
|
52
102
|
# which IS an `asgn_node`. Similarly, `obj.method += value` parses
|
53
103
|
# as (op-asgn (send ...) ...), which is also an `asgn_node`.
|
54
|
-
if asgn_node.shorthand_asgn?
|
55
|
-
asgn_node, _value = *asgn_node
|
56
|
-
next if asgn_node.send_type?
|
57
|
-
end
|
104
|
+
next if asgn_node.shorthand_asgn? && asgn_node.lhs.call_type?
|
58
105
|
|
59
106
|
yield asgn_node
|
60
107
|
end
|
61
108
|
end
|
62
109
|
|
63
110
|
def variable_in_mass_assignment?(variable_name, node)
|
64
|
-
|
65
|
-
var_nodes = *mlhs_node
|
66
|
-
|
67
|
-
var_nodes.any? { |n| n.to_a.first == variable_name }
|
111
|
+
node.assignments.reject(&:send_type?).any? { |n| n.name == variable_name }
|
68
112
|
end
|
69
113
|
|
70
114
|
def offense_range(node)
|
@@ -3,7 +3,7 @@
|
|
3
3
|
module RuboCop
|
4
4
|
module Cop
|
5
5
|
module Style
|
6
|
-
#
|
6
|
+
# Checks for methods called on a do...end block. The point of
|
7
7
|
# this check is that it's easy to miss the call tacked on to the block
|
8
8
|
# when reading code.
|
9
9
|
#
|
@@ -35,16 +35,16 @@ module RuboCop
|
|
35
35
|
ignore_node(node.send_node)
|
36
36
|
end
|
37
37
|
|
38
|
+
alias on_numblock on_block
|
39
|
+
alias on_itblock on_block
|
40
|
+
|
38
41
|
def on_send(node)
|
39
42
|
return if ignored_node?(node)
|
40
43
|
|
41
|
-
receiver = node.receiver
|
42
|
-
|
43
|
-
return unless receiver&.block_type? &&
|
44
|
-
receiver.loc.end.is?('end')
|
44
|
+
return unless (receiver = node.receiver)
|
45
|
+
return unless receiver.any_block_type? && receiver.keywords?
|
45
46
|
|
46
|
-
range = range_between(receiver.loc.end.begin_pos,
|
47
|
-
node.source_range.end_pos)
|
47
|
+
range = range_between(receiver.loc.end.begin_pos, node.source_range.end_pos)
|
48
48
|
|
49
49
|
add_offense(range)
|
50
50
|
end
|
@@ -3,9 +3,19 @@
|
|
3
3
|
module RuboCop
|
4
4
|
module Cop
|
5
5
|
module Style
|
6
|
-
#
|
6
|
+
# Checks for parentheses around the arguments in method
|
7
7
|
# definitions. Both instance and class/singleton methods are checked.
|
8
8
|
#
|
9
|
+
# Regardless of style, parentheses are necessary for:
|
10
|
+
#
|
11
|
+
# 1. Endless methods
|
12
|
+
# 2. Argument lists containing a `forward-arg` (`...`)
|
13
|
+
# 3. Argument lists containing an anonymous rest arguments forwarding (`*`)
|
14
|
+
# 4. Argument lists containing an anonymous keyword rest arguments forwarding (`**`)
|
15
|
+
# 5. Argument lists containing an anonymous block forwarding (`&`)
|
16
|
+
#
|
17
|
+
# Removing the parens would be a syntax error here.
|
18
|
+
#
|
9
19
|
# @example EnforcedStyle: require_parentheses (default)
|
10
20
|
# # The `require_parentheses` style requires method definitions
|
11
21
|
# # to always use parentheses
|
@@ -90,10 +100,11 @@ module RuboCop
|
|
90
100
|
extend AutoCorrector
|
91
101
|
|
92
102
|
MSG_PRESENT = 'Use def without parentheses.'
|
93
|
-
MSG_MISSING = 'Use def with parentheses when there are '
|
94
|
-
'parameters.'
|
103
|
+
MSG_MISSING = 'Use def with parentheses when there are parameters.'
|
95
104
|
|
96
105
|
def on_def(node)
|
106
|
+
return if forced_parentheses?(node)
|
107
|
+
|
97
108
|
args = node.arguments
|
98
109
|
|
99
110
|
if require_parentheses?(args)
|
@@ -117,20 +128,20 @@ module RuboCop
|
|
117
128
|
corrector.remove(arg_node.loc.end)
|
118
129
|
end
|
119
130
|
|
120
|
-
def
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
131
|
+
def forced_parentheses?(node)
|
132
|
+
# Regardless of style, parentheses are necessary for:
|
133
|
+
# 1. Endless methods
|
134
|
+
# 2. Argument lists containing a `forward-arg` (`...`)
|
135
|
+
# 3. Argument lists containing an anonymous rest arguments forwarding (`*`)
|
136
|
+
# 4. Argument lists containing an anonymous keyword rest arguments forwarding (`**`)
|
137
|
+
# 5. Argument lists containing an anonymous block forwarding (`&`)
|
138
|
+
# Removing the parens would be a syntax error here.
|
139
|
+
node.endless? || anonymous_arguments?(node)
|
128
140
|
end
|
129
141
|
|
130
142
|
def require_parentheses?(args)
|
131
143
|
style == :require_parentheses ||
|
132
|
-
(style == :require_no_parentheses_except_multiline &&
|
133
|
-
args.multiline?)
|
144
|
+
(style == :require_no_parentheses_except_multiline && args.multiline?)
|
134
145
|
end
|
135
146
|
|
136
147
|
def arguments_without_parentheses?(node)
|
@@ -141,7 +152,9 @@ module RuboCop
|
|
141
152
|
location = node.arguments.source_range
|
142
153
|
|
143
154
|
add_offense(location, message: MSG_MISSING) do |corrector|
|
144
|
-
|
155
|
+
add_parentheses(node.arguments, corrector)
|
156
|
+
|
157
|
+
unexpected_style_detected 'require_no_parentheses'
|
145
158
|
end
|
146
159
|
end
|
147
160
|
|
@@ -149,8 +162,18 @@ module RuboCop
|
|
149
162
|
add_offense(args, message: MSG_PRESENT) do |corrector|
|
150
163
|
# offense is registered on args node when parentheses are unwanted
|
151
164
|
correct_arguments(args, corrector)
|
165
|
+
unexpected_style_detected 'require_parentheses'
|
152
166
|
end
|
153
167
|
end
|
168
|
+
|
169
|
+
def anonymous_arguments?(node)
|
170
|
+
return true if node.arguments.any? do |arg|
|
171
|
+
arg.type?(:forward_arg, :restarg, :kwrestarg)
|
172
|
+
end
|
173
|
+
return false unless (last_argument = node.last_argument)
|
174
|
+
|
175
|
+
last_argument.blockarg_type? && last_argument.name.nil?
|
176
|
+
end
|
154
177
|
end
|
155
178
|
end
|
156
179
|
end
|
@@ -3,7 +3,7 @@
|
|
3
3
|
module RuboCop
|
4
4
|
module Cop
|
5
5
|
module Style
|
6
|
-
#
|
6
|
+
# Checks for potential uses of `Enumerable#minmax`.
|
7
7
|
#
|
8
8
|
# @example
|
9
9
|
#
|
@@ -34,13 +34,13 @@ module RuboCop
|
|
34
34
|
|
35
35
|
private
|
36
36
|
|
37
|
+
# @!method min_max_candidate(node)
|
37
38
|
def_node_matcher :min_max_candidate, <<~PATTERN
|
38
39
|
({array return} (send [$_receiver !nil?] :min) (send [$_receiver !nil?] :max))
|
39
40
|
PATTERN
|
40
41
|
|
41
42
|
def message(offender, receiver)
|
42
|
-
format(MSG, offender: offender.source,
|
43
|
-
receiver: receiver.source)
|
43
|
+
format(MSG, offender: offender.source, receiver: receiver.source)
|
44
44
|
end
|
45
45
|
|
46
46
|
def offending_range(node)
|
@@ -48,13 +48,13 @@ module RuboCop
|
|
48
48
|
when :return
|
49
49
|
argument_range(node)
|
50
50
|
else
|
51
|
-
node.
|
51
|
+
node.source_range
|
52
52
|
end
|
53
53
|
end
|
54
54
|
|
55
55
|
def argument_range(node)
|
56
|
-
first_argument_range = node.children.first.
|
57
|
-
last_argument_range = node.children.last.
|
56
|
+
first_argument_range = node.children.first.source_range
|
57
|
+
last_argument_range = node.children.last.source_range
|
58
58
|
|
59
59
|
first_argument_range.join(last_argument_range)
|
60
60
|
end
|
@@ -0,0 +1,91 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module RuboCop
|
4
|
+
module Cop
|
5
|
+
module Style
|
6
|
+
# Enforces the use of `max` or `min` instead of comparison for greater or less.
|
7
|
+
#
|
8
|
+
# NOTE: It can be used if you want to present limit or threshold in Ruby 2.7+.
|
9
|
+
# That it is slow though. So autocorrection will apply generic `max` or `min`:
|
10
|
+
#
|
11
|
+
# [source,ruby]
|
12
|
+
# ----
|
13
|
+
# a.clamp(b..) # Same as `[a, b].max`
|
14
|
+
# a.clamp(..b) # Same as `[a, b].min`
|
15
|
+
# ----
|
16
|
+
#
|
17
|
+
# @safety
|
18
|
+
# This cop is unsafe because even if a value has `<` or `>` method,
|
19
|
+
# it is not necessarily `Comparable`.
|
20
|
+
#
|
21
|
+
# @example
|
22
|
+
#
|
23
|
+
# # bad
|
24
|
+
# a > b ? a : b
|
25
|
+
# a >= b ? a : b
|
26
|
+
#
|
27
|
+
# # good
|
28
|
+
# [a, b].max
|
29
|
+
#
|
30
|
+
# # bad
|
31
|
+
# a < b ? a : b
|
32
|
+
# a <= b ? a : b
|
33
|
+
#
|
34
|
+
# # good
|
35
|
+
# [a, b].min
|
36
|
+
#
|
37
|
+
class MinMaxComparison < Base
|
38
|
+
extend AutoCorrector
|
39
|
+
include RangeHelp
|
40
|
+
|
41
|
+
MSG = 'Use `%<prefer>s` instead.'
|
42
|
+
GREATER_OPERATORS = %i[> >=].freeze
|
43
|
+
LESS_OPERATORS = %i[< <=].freeze
|
44
|
+
COMPARISON_OPERATORS = (GREATER_OPERATORS + LESS_OPERATORS).to_set.freeze
|
45
|
+
|
46
|
+
# @!method comparison_condition(node, name)
|
47
|
+
def_node_matcher :comparison_condition, <<~PATTERN
|
48
|
+
{
|
49
|
+
(send $_lhs $COMPARISON_OPERATORS $_rhs)
|
50
|
+
(begin (send $_lhs $COMPARISON_OPERATORS $_rhs))
|
51
|
+
}
|
52
|
+
PATTERN
|
53
|
+
|
54
|
+
def on_if(node)
|
55
|
+
lhs, operator, rhs = comparison_condition(node.condition)
|
56
|
+
return unless operator
|
57
|
+
|
58
|
+
if_branch = node.if_branch
|
59
|
+
else_branch = node.else_branch
|
60
|
+
preferred_method = preferred_method(operator, lhs, rhs, if_branch, else_branch)
|
61
|
+
return unless preferred_method
|
62
|
+
|
63
|
+
replacement = "[#{lhs.source}, #{rhs.source}].#{preferred_method}"
|
64
|
+
|
65
|
+
add_offense(node, message: format(MSG, prefer: replacement)) do |corrector|
|
66
|
+
autocorrect(corrector, node, replacement)
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
private
|
71
|
+
|
72
|
+
def preferred_method(operator, lhs, rhs, if_branch, else_branch)
|
73
|
+
if lhs == if_branch && rhs == else_branch
|
74
|
+
GREATER_OPERATORS.include?(operator) ? 'max' : 'min'
|
75
|
+
elsif lhs == else_branch && rhs == if_branch
|
76
|
+
LESS_OPERATORS.include?(operator) ? 'max' : 'min'
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
def autocorrect(corrector, node, replacement)
|
81
|
+
if node.elsif?
|
82
|
+
corrector.remove(range_between(node.parent.loc.else.begin_pos, node.loc.else.begin_pos))
|
83
|
+
corrector.replace(node.else_branch, replacement)
|
84
|
+
else
|
85
|
+
corrector.replace(node, replacement)
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|