rbhint 0.8.5.rc1
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 +7 -0
- data/LICENSE.txt +20 -0
- data/README.md +107 -0
- data/assets/logo.png +0 -0
- data/assets/output.html.erb +261 -0
- data/bin/console +10 -0
- data/bin/setup +7 -0
- data/config/default.yml +4133 -0
- data/exe/rbhint +17 -0
- data/lib/rbhint.rb +6 -0
- data/lib/rbhint/version.rb +7 -0
- data/lib/rubocop.rb +588 -0
- data/lib/rubocop/ast_aliases.rb +8 -0
- data/lib/rubocop/cached_data.rb +58 -0
- data/lib/rubocop/cli.rb +133 -0
- data/lib/rubocop/cli/command.rb +21 -0
- data/lib/rubocop/cli/command/auto_genenerate_config.rb +105 -0
- data/lib/rubocop/cli/command/base.rb +33 -0
- data/lib/rubocop/cli/command/execute_runner.rb +76 -0
- data/lib/rubocop/cli/command/init_dotfile.rb +45 -0
- data/lib/rubocop/cli/command/show_cops.rb +76 -0
- data/lib/rubocop/cli/command/version.rb +17 -0
- data/lib/rubocop/cli/environment.rb +21 -0
- data/lib/rubocop/comment_config.rb +206 -0
- data/lib/rubocop/config.rb +281 -0
- data/lib/rubocop/config_loader.rb +277 -0
- data/lib/rubocop/config_loader_resolver.rb +234 -0
- data/lib/rubocop/config_obsoletion.rb +278 -0
- data/lib/rubocop/config_store.rb +58 -0
- data/lib/rubocop/config_validator.rb +223 -0
- data/lib/rubocop/cop/autocorrect_logic.rb +105 -0
- data/lib/rubocop/cop/badge.rb +73 -0
- data/lib/rubocop/cop/bundler/duplicated_gem.rb +73 -0
- data/lib/rubocop/cop/bundler/gem_comment.rb +133 -0
- data/lib/rubocop/cop/bundler/insecure_protocol_source.rb +69 -0
- data/lib/rubocop/cop/bundler/ordered_gems.rb +73 -0
- data/lib/rubocop/cop/commissioner.rb +124 -0
- data/lib/rubocop/cop/cop.rb +311 -0
- data/lib/rubocop/cop/corrector.rb +196 -0
- data/lib/rubocop/cop/correctors/alignment_corrector.rb +142 -0
- data/lib/rubocop/cop/correctors/condition_corrector.rb +27 -0
- data/lib/rubocop/cop/correctors/each_to_for_corrector.rb +53 -0
- data/lib/rubocop/cop/correctors/empty_line_corrector.rb +26 -0
- data/lib/rubocop/cop/correctors/for_to_each_corrector.rb +73 -0
- data/lib/rubocop/cop/correctors/lambda_literal_to_method_corrector.rb +136 -0
- data/lib/rubocop/cop/correctors/line_break_corrector.rb +61 -0
- data/lib/rubocop/cop/correctors/multiline_literal_brace_corrector.rb +68 -0
- data/lib/rubocop/cop/correctors/ordered_gem_corrector.rb +44 -0
- data/lib/rubocop/cop/correctors/parentheses_corrector.rb +31 -0
- data/lib/rubocop/cop/correctors/percent_literal_corrector.rb +117 -0
- data/lib/rubocop/cop/correctors/punctuation_corrector.rb +29 -0
- data/lib/rubocop/cop/correctors/space_corrector.rb +46 -0
- data/lib/rubocop/cop/correctors/string_literal_corrector.rb +25 -0
- data/lib/rubocop/cop/correctors/unused_arg_corrector.rb +43 -0
- data/lib/rubocop/cop/force.rb +42 -0
- data/lib/rubocop/cop/gemspec/duplicated_assignment.rb +104 -0
- data/lib/rubocop/cop/gemspec/ordered_dependencies.rb +104 -0
- data/lib/rubocop/cop/gemspec/required_ruby_version.rb +85 -0
- data/lib/rubocop/cop/gemspec/ruby_version_globals_usage.rb +55 -0
- data/lib/rubocop/cop/generator.rb +223 -0
- data/lib/rubocop/cop/generator/configuration_injector.rb +66 -0
- data/lib/rubocop/cop/generator/require_file_injector.rb +78 -0
- data/lib/rubocop/cop/ignored_node.rb +36 -0
- data/lib/rubocop/cop/internal_affairs.rb +9 -0
- data/lib/rubocop/cop/internal_affairs/method_name_equal.rb +59 -0
- data/lib/rubocop/cop/internal_affairs/node_destructuring.rb +44 -0
- data/lib/rubocop/cop/internal_affairs/node_type_predicate.rb +44 -0
- data/lib/rubocop/cop/internal_affairs/offense_location_keyword.rb +54 -0
- data/lib/rubocop/cop/internal_affairs/redundant_location_argument.rb +48 -0
- data/lib/rubocop/cop/internal_affairs/redundant_message_argument.rb +73 -0
- data/lib/rubocop/cop/internal_affairs/useless_message_assertion.rb +52 -0
- data/lib/rubocop/cop/layout/access_modifier_indentation.rb +98 -0
- data/lib/rubocop/cop/layout/argument_alignment.rb +93 -0
- data/lib/rubocop/cop/layout/array_alignment.rb +82 -0
- data/lib/rubocop/cop/layout/assignment_indentation.rb +55 -0
- data/lib/rubocop/cop/layout/block_alignment.rb +244 -0
- data/lib/rubocop/cop/layout/block_end_newline.rb +64 -0
- data/lib/rubocop/cop/layout/case_indentation.rb +161 -0
- data/lib/rubocop/cop/layout/class_structure.rb +343 -0
- data/lib/rubocop/cop/layout/closing_heredoc_indentation.rb +126 -0
- data/lib/rubocop/cop/layout/closing_parenthesis_indentation.rb +203 -0
- data/lib/rubocop/cop/layout/comment_indentation.rb +141 -0
- data/lib/rubocop/cop/layout/condition_position.rb +66 -0
- data/lib/rubocop/cop/layout/def_end_alignment.rb +74 -0
- data/lib/rubocop/cop/layout/dot_position.rb +105 -0
- data/lib/rubocop/cop/layout/else_alignment.rb +142 -0
- data/lib/rubocop/cop/layout/empty_comment.rb +151 -0
- data/lib/rubocop/cop/layout/empty_line_after_guard_clause.rb +157 -0
- data/lib/rubocop/cop/layout/empty_line_after_magic_comment.rb +64 -0
- data/lib/rubocop/cop/layout/empty_line_between_defs.rb +152 -0
- data/lib/rubocop/cop/layout/empty_lines.rb +76 -0
- data/lib/rubocop/cop/layout/empty_lines_around_access_modifier.rb +211 -0
- data/lib/rubocop/cop/layout/empty_lines_around_arguments.rb +99 -0
- data/lib/rubocop/cop/layout/empty_lines_around_attribute_accessor.rb +126 -0
- data/lib/rubocop/cop/layout/empty_lines_around_begin_body.rb +45 -0
- data/lib/rubocop/cop/layout/empty_lines_around_block_body.rb +41 -0
- data/lib/rubocop/cop/layout/empty_lines_around_class_body.rb +88 -0
- data/lib/rubocop/cop/layout/empty_lines_around_exception_handling_keywords.rb +136 -0
- data/lib/rubocop/cop/layout/empty_lines_around_method_body.rb +45 -0
- data/lib/rubocop/cop/layout/empty_lines_around_module_body.rb +62 -0
- data/lib/rubocop/cop/layout/end_alignment.rb +189 -0
- data/lib/rubocop/cop/layout/end_of_line.rb +92 -0
- data/lib/rubocop/cop/layout/extra_spacing.rb +201 -0
- data/lib/rubocop/cop/layout/first_argument_indentation.rb +247 -0
- data/lib/rubocop/cop/layout/first_array_element_indentation.rb +171 -0
- data/lib/rubocop/cop/layout/first_array_element_line_break.rb +45 -0
- data/lib/rubocop/cop/layout/first_hash_element_indentation.rb +184 -0
- data/lib/rubocop/cop/layout/first_hash_element_line_break.rb +37 -0
- data/lib/rubocop/cop/layout/first_method_argument_line_break.rb +53 -0
- data/lib/rubocop/cop/layout/first_method_parameter_line_break.rb +46 -0
- data/lib/rubocop/cop/layout/first_parameter_indentation.rb +100 -0
- data/lib/rubocop/cop/layout/hash_alignment.rb +366 -0
- data/lib/rubocop/cop/layout/heredoc_argument_closing_parenthesis.rb +285 -0
- data/lib/rubocop/cop/layout/heredoc_indentation.rb +173 -0
- data/lib/rubocop/cop/layout/indentation_consistency.rb +202 -0
- data/lib/rubocop/cop/layout/indentation_style.rb +117 -0
- data/lib/rubocop/cop/layout/indentation_width.rb +362 -0
- data/lib/rubocop/cop/layout/initial_indentation.rb +59 -0
- data/lib/rubocop/cop/layout/leading_comment_space.rb +119 -0
- data/lib/rubocop/cop/layout/leading_empty_lines.rb +53 -0
- data/lib/rubocop/cop/layout/line_length.rb +280 -0
- data/lib/rubocop/cop/layout/multiline_array_brace_layout.rb +118 -0
- data/lib/rubocop/cop/layout/multiline_array_line_breaks.rb +39 -0
- data/lib/rubocop/cop/layout/multiline_assignment_layout.rb +95 -0
- data/lib/rubocop/cop/layout/multiline_block_layout.rb +155 -0
- data/lib/rubocop/cop/layout/multiline_hash_brace_layout.rb +118 -0
- data/lib/rubocop/cop/layout/multiline_hash_key_line_breaks.rb +50 -0
- data/lib/rubocop/cop/layout/multiline_method_argument_line_breaks.rb +52 -0
- data/lib/rubocop/cop/layout/multiline_method_call_brace_layout.rb +134 -0
- data/lib/rubocop/cop/layout/multiline_method_call_indentation.rb +220 -0
- data/lib/rubocop/cop/layout/multiline_method_definition_brace_layout.rb +131 -0
- data/lib/rubocop/cop/layout/multiline_operation_indentation.rb +123 -0
- data/lib/rubocop/cop/layout/parameter_alignment.rb +118 -0
- data/lib/rubocop/cop/layout/rescue_ensure_alignment.rb +191 -0
- data/lib/rubocop/cop/layout/space_after_colon.rb +47 -0
- data/lib/rubocop/cop/layout/space_after_comma.rb +35 -0
- data/lib/rubocop/cop/layout/space_after_method_name.rb +42 -0
- data/lib/rubocop/cop/layout/space_after_not.rb +40 -0
- data/lib/rubocop/cop/layout/space_after_semicolon.rb +32 -0
- data/lib/rubocop/cop/layout/space_around_block_parameters.rb +169 -0
- data/lib/rubocop/cop/layout/space_around_equals_in_parameter_default.rb +92 -0
- data/lib/rubocop/cop/layout/space_around_keyword.rb +244 -0
- data/lib/rubocop/cop/layout/space_around_method_call_operator.rb +131 -0
- data/lib/rubocop/cop/layout/space_around_operators.rb +242 -0
- data/lib/rubocop/cop/layout/space_before_block_braces.rb +136 -0
- data/lib/rubocop/cop/layout/space_before_comma.rb +31 -0
- data/lib/rubocop/cop/layout/space_before_comment.rb +33 -0
- data/lib/rubocop/cop/layout/space_before_first_arg.rb +75 -0
- data/lib/rubocop/cop/layout/space_before_semicolon.rb +27 -0
- data/lib/rubocop/cop/layout/space_in_lambda_literal.rb +82 -0
- data/lib/rubocop/cop/layout/space_inside_array_literal_brackets.rb +229 -0
- data/lib/rubocop/cop/layout/space_inside_array_percent_literal.rb +53 -0
- data/lib/rubocop/cop/layout/space_inside_block_braces.rb +248 -0
- data/lib/rubocop/cop/layout/space_inside_hash_literal_braces.rb +200 -0
- data/lib/rubocop/cop/layout/space_inside_parens.rb +113 -0
- data/lib/rubocop/cop/layout/space_inside_percent_literal_delimiters.rb +65 -0
- data/lib/rubocop/cop/layout/space_inside_range_literal.rb +63 -0
- data/lib/rubocop/cop/layout/space_inside_reference_brackets.rb +148 -0
- data/lib/rubocop/cop/layout/space_inside_string_interpolation.rb +65 -0
- data/lib/rubocop/cop/layout/trailing_empty_lines.rb +113 -0
- data/lib/rubocop/cop/layout/trailing_whitespace.rb +77 -0
- data/lib/rubocop/cop/lint/ambiguous_block_association.rb +62 -0
- data/lib/rubocop/cop/lint/ambiguous_operator.rb +96 -0
- data/lib/rubocop/cop/lint/ambiguous_regexp_literal.rb +57 -0
- data/lib/rubocop/cop/lint/assignment_in_condition.rb +97 -0
- data/lib/rubocop/cop/lint/big_decimal_new.rb +44 -0
- data/lib/rubocop/cop/lint/boolean_symbol.rb +50 -0
- data/lib/rubocop/cop/lint/circular_argument_reference.rb +72 -0
- data/lib/rubocop/cop/lint/debugger.rb +77 -0
- data/lib/rubocop/cop/lint/deprecated_class_methods.rb +111 -0
- data/lib/rubocop/cop/lint/deprecated_open_ssl_constant.rb +137 -0
- data/lib/rubocop/cop/lint/disjunctive_assignment_in_constructor.rb +81 -0
- data/lib/rubocop/cop/lint/duplicate_case_condition.rb +53 -0
- data/lib/rubocop/cop/lint/duplicate_hash_key.rb +38 -0
- data/lib/rubocop/cop/lint/duplicate_methods.rb +235 -0
- data/lib/rubocop/cop/lint/each_with_object_argument.rb +42 -0
- data/lib/rubocop/cop/lint/else_layout.rb +66 -0
- data/lib/rubocop/cop/lint/empty_ensure.rb +60 -0
- data/lib/rubocop/cop/lint/empty_expression.rb +42 -0
- data/lib/rubocop/cop/lint/empty_interpolation.rb +36 -0
- data/lib/rubocop/cop/lint/empty_when.rb +61 -0
- data/lib/rubocop/cop/lint/ensure_return.rb +63 -0
- data/lib/rubocop/cop/lint/erb_new_arguments.rb +162 -0
- data/lib/rubocop/cop/lint/flip_flop.rb +32 -0
- data/lib/rubocop/cop/lint/float_out_of_range.rb +35 -0
- data/lib/rubocop/cop/lint/format_parameter_mismatch.rb +159 -0
- data/lib/rubocop/cop/lint/heredoc_method_call_position.rb +156 -0
- data/lib/rubocop/cop/lint/implicit_string_concatenation.rb +101 -0
- data/lib/rubocop/cop/lint/ineffective_access_modifier.rb +127 -0
- data/lib/rubocop/cop/lint/inherit_exception.rb +100 -0
- data/lib/rubocop/cop/lint/interpolation_check.rb +40 -0
- data/lib/rubocop/cop/lint/literal_as_condition.rb +135 -0
- data/lib/rubocop/cop/lint/literal_in_interpolation.rb +98 -0
- data/lib/rubocop/cop/lint/loop.rb +65 -0
- data/lib/rubocop/cop/lint/missing_cop_enable_directive.rb +84 -0
- data/lib/rubocop/cop/lint/mixed_regexp_capture_types.rb +69 -0
- data/lib/rubocop/cop/lint/multiple_comparison.rb +48 -0
- data/lib/rubocop/cop/lint/nested_method_definition.rb +104 -0
- data/lib/rubocop/cop/lint/nested_percent_literal.rb +51 -0
- data/lib/rubocop/cop/lint/next_without_accumulator.rb +50 -0
- data/lib/rubocop/cop/lint/non_deterministic_require_order.rb +89 -0
- data/lib/rubocop/cop/lint/non_local_exit_from_iterator.rb +83 -0
- data/lib/rubocop/cop/lint/number_conversion.rb +81 -0
- data/lib/rubocop/cop/lint/ordered_magic_comments.rb +86 -0
- data/lib/rubocop/cop/lint/parentheses_as_grouped_expression.rb +86 -0
- data/lib/rubocop/cop/lint/percent_string_array.rb +71 -0
- data/lib/rubocop/cop/lint/percent_symbol_array.rb +69 -0
- data/lib/rubocop/cop/lint/raise_exception.rb +75 -0
- data/lib/rubocop/cop/lint/rand_one.rb +45 -0
- data/lib/rubocop/cop/lint/redundant_cop_disable_directive.rb +258 -0
- data/lib/rubocop/cop/lint/redundant_cop_enable_directive.rb +119 -0
- data/lib/rubocop/cop/lint/redundant_require_statement.rb +50 -0
- data/lib/rubocop/cop/lint/redundant_splat_expansion.rb +172 -0
- data/lib/rubocop/cop/lint/redundant_string_coercion.rb +59 -0
- data/lib/rubocop/cop/lint/redundant_with_index.rb +82 -0
- data/lib/rubocop/cop/lint/redundant_with_object.rb +83 -0
- data/lib/rubocop/cop/lint/regexp_as_condition.rb +29 -0
- data/lib/rubocop/cop/lint/require_parentheses.rb +66 -0
- data/lib/rubocop/cop/lint/rescue_exception.rb +46 -0
- data/lib/rubocop/cop/lint/rescue_type.rb +94 -0
- data/lib/rubocop/cop/lint/return_in_void_context.rb +74 -0
- data/lib/rubocop/cop/lint/safe_navigation_chain.rb +65 -0
- data/lib/rubocop/cop/lint/safe_navigation_consistency.rb +94 -0
- data/lib/rubocop/cop/lint/safe_navigation_with_empty.rb +38 -0
- data/lib/rubocop/cop/lint/script_permission.rb +70 -0
- data/lib/rubocop/cop/lint/send_with_mixin_argument.rb +91 -0
- data/lib/rubocop/cop/lint/shadowed_argument.rb +182 -0
- data/lib/rubocop/cop/lint/shadowed_exception.rb +178 -0
- data/lib/rubocop/cop/lint/shadowing_outer_local_variable.rb +53 -0
- data/lib/rubocop/cop/lint/struct_new_override.rb +58 -0
- data/lib/rubocop/cop/lint/suppressed_exception.rb +92 -0
- data/lib/rubocop/cop/lint/syntax.rb +57 -0
- data/lib/rubocop/cop/lint/to_json.rb +41 -0
- data/lib/rubocop/cop/lint/underscore_prefixed_variable_name.rb +82 -0
- data/lib/rubocop/cop/lint/unified_integer.rb +43 -0
- data/lib/rubocop/cop/lint/unreachable_code.rb +99 -0
- data/lib/rubocop/cop/lint/unused_block_argument.rb +165 -0
- data/lib/rubocop/cop/lint/unused_method_argument.rb +112 -0
- data/lib/rubocop/cop/lint/uri_escape_unescape.rb +76 -0
- data/lib/rubocop/cop/lint/uri_regexp.rb +73 -0
- data/lib/rubocop/cop/lint/useless_access_modifier.rb +284 -0
- data/lib/rubocop/cop/lint/useless_assignment.rb +130 -0
- data/lib/rubocop/cop/lint/useless_comparison.rb +28 -0
- data/lib/rubocop/cop/lint/useless_else_without_rescue.rb +54 -0
- data/lib/rubocop/cop/lint/useless_setter_call.rb +168 -0
- data/lib/rubocop/cop/lint/void.rb +151 -0
- data/lib/rubocop/cop/message_annotator.rb +129 -0
- data/lib/rubocop/cop/metrics/abc_size.rb +24 -0
- data/lib/rubocop/cop/metrics/block_length.rb +50 -0
- data/lib/rubocop/cop/metrics/block_nesting.rb +65 -0
- data/lib/rubocop/cop/metrics/class_length.rb +36 -0
- data/lib/rubocop/cop/metrics/cyclomatic_complexity.rb +32 -0
- data/lib/rubocop/cop/metrics/method_length.rb +36 -0
- data/lib/rubocop/cop/metrics/module_length.rb +36 -0
- data/lib/rubocop/cop/metrics/parameter_lists.rb +54 -0
- data/lib/rubocop/cop/metrics/perceived_complexity.rb +61 -0
- data/lib/rubocop/cop/metrics/utils/abc_size_calculator.rb +84 -0
- data/lib/rubocop/cop/migration/department_name.rb +85 -0
- data/lib/rubocop/cop/mixin/alignment.rb +72 -0
- data/lib/rubocop/cop/mixin/annotation_comment.rb +37 -0
- data/lib/rubocop/cop/mixin/array_min_size.rb +57 -0
- data/lib/rubocop/cop/mixin/array_syntax.rb +17 -0
- data/lib/rubocop/cop/mixin/check_assignment.rb +44 -0
- data/lib/rubocop/cop/mixin/check_line_breakable.rb +184 -0
- data/lib/rubocop/cop/mixin/classish_length.rb +37 -0
- data/lib/rubocop/cop/mixin/code_length.rb +38 -0
- data/lib/rubocop/cop/mixin/configurable_enforced_style.rb +100 -0
- data/lib/rubocop/cop/mixin/configurable_formatting.rb +45 -0
- data/lib/rubocop/cop/mixin/configurable_max.rb +23 -0
- data/lib/rubocop/cop/mixin/configurable_naming.rb +16 -0
- data/lib/rubocop/cop/mixin/configurable_numbering.rb +17 -0
- data/lib/rubocop/cop/mixin/def_node.rb +33 -0
- data/lib/rubocop/cop/mixin/documentation_comment.rb +52 -0
- data/lib/rubocop/cop/mixin/duplication.rb +46 -0
- data/lib/rubocop/cop/mixin/empty_lines_around_body.rb +172 -0
- data/lib/rubocop/cop/mixin/empty_parameter.rb +24 -0
- data/lib/rubocop/cop/mixin/end_keyword_alignment.rb +72 -0
- data/lib/rubocop/cop/mixin/enforce_superclass.rb +30 -0
- data/lib/rubocop/cop/mixin/first_element_line_break.rb +46 -0
- data/lib/rubocop/cop/mixin/frozen_string_literal.rb +62 -0
- data/lib/rubocop/cop/mixin/hash_alignment_styles.rb +147 -0
- data/lib/rubocop/cop/mixin/hash_transform_method.rb +178 -0
- data/lib/rubocop/cop/mixin/heredoc.rb +32 -0
- data/lib/rubocop/cop/mixin/ignored_methods.rb +19 -0
- data/lib/rubocop/cop/mixin/ignored_pattern.rb +29 -0
- data/lib/rubocop/cop/mixin/integer_node.rb +14 -0
- data/lib/rubocop/cop/mixin/interpolation.rb +27 -0
- data/lib/rubocop/cop/mixin/line_length_help.rb +89 -0
- data/lib/rubocop/cop/mixin/match_range.rb +26 -0
- data/lib/rubocop/cop/mixin/method_complexity.rb +62 -0
- data/lib/rubocop/cop/mixin/method_preference.rb +31 -0
- data/lib/rubocop/cop/mixin/min_body_length.rb +21 -0
- data/lib/rubocop/cop/mixin/multiline_element_indentation.rb +86 -0
- data/lib/rubocop/cop/mixin/multiline_element_line_breaks.rb +33 -0
- data/lib/rubocop/cop/mixin/multiline_expression_indentation.rb +255 -0
- data/lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb +141 -0
- data/lib/rubocop/cop/mixin/negative_conditional.rb +32 -0
- data/lib/rubocop/cop/mixin/nil_methods.rb +25 -0
- data/lib/rubocop/cop/mixin/on_normal_if_unless.rb +14 -0
- data/lib/rubocop/cop/mixin/ordered_gem_node.rb +56 -0
- data/lib/rubocop/cop/mixin/parentheses.rb +17 -0
- data/lib/rubocop/cop/mixin/parser_diagnostic.rb +37 -0
- data/lib/rubocop/cop/mixin/percent_array.rb +52 -0
- data/lib/rubocop/cop/mixin/percent_literal.rb +38 -0
- data/lib/rubocop/cop/mixin/preceding_following_alignment.rb +181 -0
- data/lib/rubocop/cop/mixin/preferred_delimiters.rb +53 -0
- data/lib/rubocop/cop/mixin/range_help.rb +117 -0
- data/lib/rubocop/cop/mixin/rational_literal.rb +18 -0
- data/lib/rubocop/cop/mixin/regexp_literal_help.rb +16 -0
- data/lib/rubocop/cop/mixin/rescue_node.rb +22 -0
- data/lib/rubocop/cop/mixin/safe_assignment.rb +23 -0
- data/lib/rubocop/cop/mixin/space_after_punctuation.rb +55 -0
- data/lib/rubocop/cop/mixin/space_before_punctuation.rb +49 -0
- data/lib/rubocop/cop/mixin/statement_modifier.rb +56 -0
- data/lib/rubocop/cop/mixin/string_help.rb +35 -0
- data/lib/rubocop/cop/mixin/string_literals_help.rb +23 -0
- data/lib/rubocop/cop/mixin/surrounding_space.rb +146 -0
- data/lib/rubocop/cop/mixin/target_ruby_version.rb +20 -0
- data/lib/rubocop/cop/mixin/too_many_lines.rb +35 -0
- data/lib/rubocop/cop/mixin/trailing_body.rb +26 -0
- data/lib/rubocop/cop/mixin/trailing_comma.rb +212 -0
- data/lib/rubocop/cop/mixin/uncommunicative_name.rb +111 -0
- data/lib/rubocop/cop/mixin/unused_argument.rb +33 -0
- data/lib/rubocop/cop/naming/accessor_method_name.rb +55 -0
- data/lib/rubocop/cop/naming/ascii_identifiers.rb +72 -0
- data/lib/rubocop/cop/naming/binary_operator_parameter_name.rb +43 -0
- data/lib/rubocop/cop/naming/block_parameter_name.rb +49 -0
- data/lib/rubocop/cop/naming/class_and_module_camel_case.rb +43 -0
- data/lib/rubocop/cop/naming/constant_name.rb +82 -0
- data/lib/rubocop/cop/naming/file_name.rb +225 -0
- data/lib/rubocop/cop/naming/heredoc_delimiter_case.rb +62 -0
- data/lib/rubocop/cop/naming/heredoc_delimiter_naming.rb +55 -0
- data/lib/rubocop/cop/naming/memoized_instance_variable_name.rb +171 -0
- data/lib/rubocop/cop/naming/method_name.rb +79 -0
- data/lib/rubocop/cop/naming/method_parameter_name.rb +58 -0
- data/lib/rubocop/cop/naming/predicate_name.rb +108 -0
- data/lib/rubocop/cop/naming/rescued_exceptions_variable_name.rb +112 -0
- data/lib/rubocop/cop/naming/variable_name.rb +52 -0
- data/lib/rubocop/cop/naming/variable_number.rb +61 -0
- data/lib/rubocop/cop/offense.rb +216 -0
- data/lib/rubocop/cop/registry.rb +276 -0
- data/lib/rubocop/cop/security/eval.rb +31 -0
- data/lib/rubocop/cop/security/json_load.rb +46 -0
- data/lib/rubocop/cop/security/marshal_load.rb +39 -0
- data/lib/rubocop/cop/security/open.rb +71 -0
- data/lib/rubocop/cop/security/yaml_load.rb +37 -0
- data/lib/rubocop/cop/severity.rb +75 -0
- data/lib/rubocop/cop/style/access_modifier_declarations.rb +132 -0
- data/lib/rubocop/cop/style/alias.rb +147 -0
- data/lib/rubocop/cop/style/and_or.rb +145 -0
- data/lib/rubocop/cop/style/array_join.rb +39 -0
- data/lib/rubocop/cop/style/ascii_comments.rb +61 -0
- data/lib/rubocop/cop/style/attr.rb +68 -0
- data/lib/rubocop/cop/style/auto_resource_cleanup.rb +51 -0
- data/lib/rubocop/cop/style/bare_percent_literals.rb +78 -0
- data/lib/rubocop/cop/style/begin_block.rb +22 -0
- data/lib/rubocop/cop/style/block_comments.rb +70 -0
- data/lib/rubocop/cop/style/block_delimiters.rb +384 -0
- data/lib/rubocop/cop/style/case_equality.rb +53 -0
- data/lib/rubocop/cop/style/character_literal.rb +53 -0
- data/lib/rubocop/cop/style/class_and_module_children.rb +151 -0
- data/lib/rubocop/cop/style/class_check.rb +59 -0
- data/lib/rubocop/cop/style/class_methods.rb +60 -0
- data/lib/rubocop/cop/style/class_vars.rb +48 -0
- data/lib/rubocop/cop/style/collection_methods.rb +79 -0
- data/lib/rubocop/cop/style/colon_method_call.rb +48 -0
- data/lib/rubocop/cop/style/colon_method_definition.rb +37 -0
- data/lib/rubocop/cop/style/command_literal.rb +187 -0
- data/lib/rubocop/cop/style/comment_annotation.rb +97 -0
- data/lib/rubocop/cop/style/commented_keyword.rb +73 -0
- data/lib/rubocop/cop/style/conditional_assignment.rb +666 -0
- data/lib/rubocop/cop/style/constant_visibility.rb +77 -0
- data/lib/rubocop/cop/style/copyright.rb +99 -0
- data/lib/rubocop/cop/style/date_time.rb +77 -0
- data/lib/rubocop/cop/style/def_with_parentheses.rb +57 -0
- data/lib/rubocop/cop/style/dir.rb +48 -0
- data/lib/rubocop/cop/style/disable_cops_within_source_code_directive.rb +49 -0
- data/lib/rubocop/cop/style/documentation.rb +135 -0
- data/lib/rubocop/cop/style/documentation_method.rb +125 -0
- data/lib/rubocop/cop/style/double_cop_disable_directive.rb +55 -0
- data/lib/rubocop/cop/style/double_negation.rb +72 -0
- data/lib/rubocop/cop/style/each_for_simple_loop.rb +58 -0
- data/lib/rubocop/cop/style/each_with_object.rb +110 -0
- data/lib/rubocop/cop/style/empty_block_parameter.rb +48 -0
- data/lib/rubocop/cop/style/empty_case_condition.rb +107 -0
- data/lib/rubocop/cop/style/empty_else.rb +175 -0
- data/lib/rubocop/cop/style/empty_lambda_parameter.rb +45 -0
- data/lib/rubocop/cop/style/empty_literal.rb +121 -0
- data/lib/rubocop/cop/style/empty_method.rb +111 -0
- data/lib/rubocop/cop/style/encoding.rb +56 -0
- data/lib/rubocop/cop/style/end_block.rb +31 -0
- data/lib/rubocop/cop/style/eval_with_location.rb +148 -0
- data/lib/rubocop/cop/style/even_odd.rb +58 -0
- data/lib/rubocop/cop/style/expand_path_arguments.rb +194 -0
- data/lib/rubocop/cop/style/exponential_notation.rb +119 -0
- data/lib/rubocop/cop/style/float_division.rb +94 -0
- data/lib/rubocop/cop/style/for.rb +88 -0
- data/lib/rubocop/cop/style/format_string.rb +127 -0
- data/lib/rubocop/cop/style/format_string_token.rb +120 -0
- data/lib/rubocop/cop/style/frozen_string_literal_comment.rb +234 -0
- data/lib/rubocop/cop/style/global_vars.rb +80 -0
- data/lib/rubocop/cop/style/guard_clause.rb +145 -0
- data/lib/rubocop/cop/style/hash_each_methods.rb +89 -0
- data/lib/rubocop/cop/style/hash_syntax.rb +221 -0
- data/lib/rubocop/cop/style/hash_transform_keys.rb +83 -0
- data/lib/rubocop/cop/style/hash_transform_values.rb +80 -0
- data/lib/rubocop/cop/style/identical_conditional_branches.rb +130 -0
- data/lib/rubocop/cop/style/if_inside_else.rb +87 -0
- data/lib/rubocop/cop/style/if_unless_modifier.rb +189 -0
- data/lib/rubocop/cop/style/if_unless_modifier_of_if_unless.rb +39 -0
- data/lib/rubocop/cop/style/if_with_semicolon.rb +46 -0
- data/lib/rubocop/cop/style/implicit_runtime_error.rb +32 -0
- data/lib/rubocop/cop/style/infinite_loop.rb +128 -0
- data/lib/rubocop/cop/style/inline_comment.rb +34 -0
- data/lib/rubocop/cop/style/inverse_methods.rb +197 -0
- data/lib/rubocop/cop/style/ip_addresses.rb +76 -0
- data/lib/rubocop/cop/style/lambda.rb +132 -0
- data/lib/rubocop/cop/style/lambda_call.rb +73 -0
- data/lib/rubocop/cop/style/line_end_concatenation.rb +125 -0
- data/lib/rubocop/cop/style/method_call_with_args_parentheses.rb +190 -0
- data/lib/rubocop/cop/style/method_call_with_args_parentheses/omit_parentheses.rb +169 -0
- data/lib/rubocop/cop/style/method_call_with_args_parentheses/require_parentheses.rb +52 -0
- data/lib/rubocop/cop/style/method_call_without_args_parentheses.rb +75 -0
- data/lib/rubocop/cop/style/method_called_on_do_end_block.rb +46 -0
- data/lib/rubocop/cop/style/method_def_parentheses.rb +166 -0
- data/lib/rubocop/cop/style/method_missing_super.rb +34 -0
- data/lib/rubocop/cop/style/min_max.rb +68 -0
- data/lib/rubocop/cop/style/missing_else.rb +180 -0
- data/lib/rubocop/cop/style/missing_respond_to_missing.rb +46 -0
- data/lib/rubocop/cop/style/mixin_grouping.rb +148 -0
- data/lib/rubocop/cop/style/mixin_usage.rb +90 -0
- data/lib/rubocop/cop/style/module_function.rb +150 -0
- data/lib/rubocop/cop/style/multiline_block_chain.rb +40 -0
- data/lib/rubocop/cop/style/multiline_if_modifier.rb +67 -0
- data/lib/rubocop/cop/style/multiline_if_then.rb +50 -0
- data/lib/rubocop/cop/style/multiline_memoization.rb +94 -0
- data/lib/rubocop/cop/style/multiline_method_signature.rb +61 -0
- data/lib/rubocop/cop/style/multiline_ternary_operator.rb +38 -0
- data/lib/rubocop/cop/style/multiline_when_then.rb +74 -0
- data/lib/rubocop/cop/style/multiple_comparison.rb +92 -0
- data/lib/rubocop/cop/style/mutable_constant.rb +172 -0
- data/lib/rubocop/cop/style/negated_if.rb +99 -0
- data/lib/rubocop/cop/style/negated_unless.rb +89 -0
- data/lib/rubocop/cop/style/negated_while.rb +48 -0
- data/lib/rubocop/cop/style/nested_modifier.rb +107 -0
- data/lib/rubocop/cop/style/nested_parenthesized_calls.rb +67 -0
- data/lib/rubocop/cop/style/nested_ternary_operator.rb +32 -0
- data/lib/rubocop/cop/style/next.rb +244 -0
- data/lib/rubocop/cop/style/nil_comparison.rb +75 -0
- data/lib/rubocop/cop/style/non_nil_check.rb +136 -0
- data/lib/rubocop/cop/style/not.rb +82 -0
- data/lib/rubocop/cop/style/numeric_literal_prefix.rb +124 -0
- data/lib/rubocop/cop/style/numeric_literals.rb +114 -0
- data/lib/rubocop/cop/style/numeric_predicate.rb +138 -0
- data/lib/rubocop/cop/style/one_line_conditional.rb +98 -0
- data/lib/rubocop/cop/style/option_hash.rb +55 -0
- data/lib/rubocop/cop/style/optional_arguments.rb +58 -0
- data/lib/rubocop/cop/style/or_assignment.rb +96 -0
- data/lib/rubocop/cop/style/parallel_assignment.rb +287 -0
- data/lib/rubocop/cop/style/parentheses_around_condition.rb +117 -0
- data/lib/rubocop/cop/style/percent_literal_delimiters.rb +127 -0
- data/lib/rubocop/cop/style/percent_q_literals.rb +73 -0
- data/lib/rubocop/cop/style/perl_backrefs.rb +38 -0
- data/lib/rubocop/cop/style/preferred_hash_methods.rb +75 -0
- data/lib/rubocop/cop/style/proc.rb +34 -0
- data/lib/rubocop/cop/style/raise_args.rb +145 -0
- data/lib/rubocop/cop/style/random_with_offset.rb +158 -0
- data/lib/rubocop/cop/style/redundant_begin.rb +91 -0
- data/lib/rubocop/cop/style/redundant_capital_w.rb +51 -0
- data/lib/rubocop/cop/style/redundant_condition.rb +124 -0
- data/lib/rubocop/cop/style/redundant_conditional.rb +97 -0
- data/lib/rubocop/cop/style/redundant_exception.rb +60 -0
- data/lib/rubocop/cop/style/redundant_freeze.rb +67 -0
- data/lib/rubocop/cop/style/redundant_interpolation.rb +98 -0
- data/lib/rubocop/cop/style/redundant_parentheses.rb +227 -0
- data/lib/rubocop/cop/style/redundant_percent_q.rb +112 -0
- data/lib/rubocop/cop/style/redundant_regexp_character_class.rb +89 -0
- data/lib/rubocop/cop/style/redundant_regexp_escape.rb +130 -0
- data/lib/rubocop/cop/style/redundant_return.rb +169 -0
- data/lib/rubocop/cop/style/redundant_self.rb +171 -0
- data/lib/rubocop/cop/style/redundant_sort.rb +165 -0
- data/lib/rubocop/cop/style/redundant_sort_by.rb +50 -0
- data/lib/rubocop/cop/style/regexp_literal.rb +228 -0
- data/lib/rubocop/cop/style/rescue_modifier.rb +73 -0
- data/lib/rubocop/cop/style/rescue_standard_error.rb +124 -0
- data/lib/rubocop/cop/style/return_nil.rb +89 -0
- data/lib/rubocop/cop/style/safe_navigation.rb +271 -0
- data/lib/rubocop/cop/style/sample.rb +144 -0
- data/lib/rubocop/cop/style/self_assignment.rb +97 -0
- data/lib/rubocop/cop/style/semicolon.rb +101 -0
- data/lib/rubocop/cop/style/send.rb +31 -0
- data/lib/rubocop/cop/style/signal_exception.rb +211 -0
- data/lib/rubocop/cop/style/single_line_block_params.rb +95 -0
- data/lib/rubocop/cop/style/single_line_methods.rb +83 -0
- data/lib/rubocop/cop/style/slicing_with_range.rb +39 -0
- data/lib/rubocop/cop/style/special_global_vars.rb +207 -0
- data/lib/rubocop/cop/style/stabby_lambda_parentheses.rb +83 -0
- data/lib/rubocop/cop/style/stderr_puts.rb +61 -0
- data/lib/rubocop/cop/style/string_hash_keys.rb +50 -0
- data/lib/rubocop/cop/style/string_literals.rb +129 -0
- data/lib/rubocop/cop/style/string_literals_in_interpolation.rb +49 -0
- data/lib/rubocop/cop/style/string_methods.rb +46 -0
- data/lib/rubocop/cop/style/strip.rb +46 -0
- data/lib/rubocop/cop/style/struct_inheritance.rb +39 -0
- data/lib/rubocop/cop/style/symbol_array.rb +119 -0
- data/lib/rubocop/cop/style/symbol_literal.rb +32 -0
- data/lib/rubocop/cop/style/symbol_proc.rb +110 -0
- data/lib/rubocop/cop/style/ternary_parentheses.rb +220 -0
- data/lib/rubocop/cop/style/trailing_body_on_class.rb +43 -0
- data/lib/rubocop/cop/style/trailing_body_on_method_definition.rb +54 -0
- data/lib/rubocop/cop/style/trailing_body_on_module.rb +43 -0
- data/lib/rubocop/cop/style/trailing_comma_in_arguments.rb +109 -0
- data/lib/rubocop/cop/style/trailing_comma_in_array_literal.rb +99 -0
- data/lib/rubocop/cop/style/trailing_comma_in_block_args.rb +88 -0
- data/lib/rubocop/cop/style/trailing_comma_in_hash_literal.rb +100 -0
- data/lib/rubocop/cop/style/trailing_method_end_statement.rb +91 -0
- data/lib/rubocop/cop/style/trailing_underscore_variable.rb +165 -0
- data/lib/rubocop/cop/style/trivial_accessors.rb +191 -0
- data/lib/rubocop/cop/style/unless_else.rb +55 -0
- data/lib/rubocop/cop/style/unpack_first.rb +61 -0
- data/lib/rubocop/cop/style/variable_interpolation.rb +48 -0
- data/lib/rubocop/cop/style/when_then.rb +37 -0
- data/lib/rubocop/cop/style/while_until_do.rb +59 -0
- data/lib/rubocop/cop/style/while_until_modifier.rb +61 -0
- data/lib/rubocop/cop/style/word_array.rb +102 -0
- data/lib/rubocop/cop/style/yoda_condition.rb +156 -0
- data/lib/rubocop/cop/style/zero_length_predicate.rb +117 -0
- data/lib/rubocop/cop/team.rb +240 -0
- data/lib/rubocop/cop/util.rb +151 -0
- data/lib/rubocop/cop/utils/format_string.rb +120 -0
- data/lib/rubocop/cop/variable_force.rb +463 -0
- data/lib/rubocop/cop/variable_force/assignment.rb +97 -0
- data/lib/rubocop/cop/variable_force/branch.rb +320 -0
- data/lib/rubocop/cop/variable_force/branchable.rb +23 -0
- data/lib/rubocop/cop/variable_force/reference.rb +49 -0
- data/lib/rubocop/cop/variable_force/scope.rb +110 -0
- data/lib/rubocop/cop/variable_force/variable.rb +114 -0
- data/lib/rubocop/cop/variable_force/variable_table.rb +129 -0
- data/lib/rubocop/core_ext/string.rb +23 -0
- data/lib/rubocop/error.rb +34 -0
- data/lib/rubocop/ext/processed_source.rb +18 -0
- data/lib/rubocop/file_finder.rb +42 -0
- data/lib/rubocop/formatter/auto_gen_config_formatter.rb +16 -0
- data/lib/rubocop/formatter/base_formatter.rb +119 -0
- data/lib/rubocop/formatter/clang_style_formatter.rb +57 -0
- data/lib/rubocop/formatter/colorizable.rb +41 -0
- data/lib/rubocop/formatter/disabled_config_formatter.rb +216 -0
- data/lib/rubocop/formatter/emacs_style_formatter.rb +37 -0
- data/lib/rubocop/formatter/file_list_formatter.rb +20 -0
- data/lib/rubocop/formatter/formatter_set.rb +104 -0
- data/lib/rubocop/formatter/fuubar_style_formatter.rb +80 -0
- data/lib/rubocop/formatter/html_formatter.rb +141 -0
- data/lib/rubocop/formatter/json_formatter.rb +81 -0
- data/lib/rubocop/formatter/junit_formatter.rb +84 -0
- data/lib/rubocop/formatter/offense_count_formatter.rb +74 -0
- data/lib/rubocop/formatter/pacman_formatter.rb +80 -0
- data/lib/rubocop/formatter/progress_formatter.rb +63 -0
- data/lib/rubocop/formatter/quiet_formatter.rb +13 -0
- data/lib/rubocop/formatter/simple_text_formatter.rb +138 -0
- data/lib/rubocop/formatter/tap_formatter.rb +82 -0
- data/lib/rubocop/formatter/text_util.rb +20 -0
- data/lib/rubocop/formatter/worst_offenders_formatter.rb +62 -0
- data/lib/rubocop/magic_comment.rb +214 -0
- data/lib/rubocop/name_similarity.rb +24 -0
- data/lib/rubocop/options.rb +481 -0
- data/lib/rubocop/path_util.rb +85 -0
- data/lib/rubocop/platform.rb +11 -0
- data/lib/rubocop/rake_task.rb +80 -0
- data/lib/rubocop/remote_config.rb +104 -0
- data/lib/rubocop/result_cache.rb +205 -0
- data/lib/rubocop/rspec/cop_helper.rb +71 -0
- data/lib/rubocop/rspec/expect_offense.rb +273 -0
- data/lib/rubocop/rspec/host_environment_simulation_helper.rb +28 -0
- data/lib/rubocop/rspec/shared_contexts.rb +129 -0
- data/lib/rubocop/rspec/support.rb +13 -0
- data/lib/rubocop/runner.rb +386 -0
- data/lib/rubocop/string_interpreter.rb +57 -0
- data/lib/rubocop/target_finder.rb +196 -0
- data/lib/rubocop/target_ruby.rb +154 -0
- data/lib/rubocop/version.rb +23 -0
- data/lib/rubocop/warning.rb +11 -0
- data/lib/rubocop/yaml_duplication_checker.rb +39 -0
- metadata +780 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module RuboCop
|
|
4
|
+
module Cop
|
|
5
|
+
module Bundler
|
|
6
|
+
# Gems should be alphabetically sorted within groups.
|
|
7
|
+
#
|
|
8
|
+
# @example
|
|
9
|
+
# # bad
|
|
10
|
+
# gem 'rubocop'
|
|
11
|
+
# gem 'rspec'
|
|
12
|
+
#
|
|
13
|
+
# # good
|
|
14
|
+
# gem 'rspec'
|
|
15
|
+
# gem 'rubocop'
|
|
16
|
+
#
|
|
17
|
+
# # good
|
|
18
|
+
# gem 'rubocop'
|
|
19
|
+
#
|
|
20
|
+
# gem 'rspec'
|
|
21
|
+
#
|
|
22
|
+
# # good only if TreatCommentsAsGroupSeparators is true
|
|
23
|
+
# # For code quality
|
|
24
|
+
# gem 'rubocop'
|
|
25
|
+
# # For tests
|
|
26
|
+
# gem 'rspec'
|
|
27
|
+
class OrderedGems < Cop
|
|
28
|
+
include ConfigurableEnforcedStyle
|
|
29
|
+
include OrderedGemNode
|
|
30
|
+
|
|
31
|
+
MSG = 'Gems should be sorted in an alphabetical order within their '\
|
|
32
|
+
'section of the Gemfile. '\
|
|
33
|
+
'Gem `%<previous>s` should appear before `%<current>s`.'
|
|
34
|
+
|
|
35
|
+
def investigate(processed_source)
|
|
36
|
+
return if processed_source.blank?
|
|
37
|
+
|
|
38
|
+
gem_declarations(processed_source.ast)
|
|
39
|
+
.each_cons(2) do |previous, current|
|
|
40
|
+
next unless consecutive_lines(previous, current)
|
|
41
|
+
next unless case_insensitive_out_of_order?(
|
|
42
|
+
gem_name(current),
|
|
43
|
+
gem_name(previous)
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
register_offense(previous, current)
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
def autocorrect(node)
|
|
51
|
+
OrderedGemCorrector.correct(
|
|
52
|
+
processed_source,
|
|
53
|
+
node,
|
|
54
|
+
previous_declaration(node),
|
|
55
|
+
treat_comments_as_separators
|
|
56
|
+
)
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
private
|
|
60
|
+
|
|
61
|
+
def previous_declaration(node)
|
|
62
|
+
declarations = gem_declarations(processed_source.ast)
|
|
63
|
+
node_index = declarations.map(&:location).find_index(node.location)
|
|
64
|
+
declarations.to_a[node_index - 1]
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
def_node_search :gem_declarations, <<~PATTERN
|
|
68
|
+
(:send nil? :gem str ...)
|
|
69
|
+
PATTERN
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
end
|
|
73
|
+
end
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module RuboCop
|
|
4
|
+
module Cop
|
|
5
|
+
# Commissioner class is responsible for processing the AST and delegating
|
|
6
|
+
# work to the specified cops.
|
|
7
|
+
class Commissioner
|
|
8
|
+
include RuboCop::AST::Traversal
|
|
9
|
+
|
|
10
|
+
attr_reader :errors
|
|
11
|
+
|
|
12
|
+
def initialize(cops, forces = [], options = {})
|
|
13
|
+
@cops = cops
|
|
14
|
+
@forces = forces
|
|
15
|
+
@options = options
|
|
16
|
+
@callbacks = {}
|
|
17
|
+
|
|
18
|
+
reset_errors
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
# Create methods like :on_send, :on_super, etc. They will be called
|
|
22
|
+
# during AST traversal and try to call corresponding methods on cops.
|
|
23
|
+
# A call to `super` is used
|
|
24
|
+
# to continue iterating over the children of a node.
|
|
25
|
+
# However, if we know that a certain node type (like `int`) never has
|
|
26
|
+
# child nodes, there is no reason to pay the cost of calling `super`.
|
|
27
|
+
Parser::Meta::NODE_TYPES.each do |node_type|
|
|
28
|
+
method_name = :"on_#{node_type}"
|
|
29
|
+
next unless method_defined?(method_name)
|
|
30
|
+
|
|
31
|
+
define_method(method_name) do |node|
|
|
32
|
+
trigger_responding_cops(method_name, node)
|
|
33
|
+
super(node) unless NO_CHILD_NODES.include?(node_type)
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def investigate(processed_source)
|
|
38
|
+
reset_errors
|
|
39
|
+
reset_callbacks
|
|
40
|
+
prepare(processed_source)
|
|
41
|
+
invoke_custom_processing(@cops, processed_source)
|
|
42
|
+
invoke_custom_processing(@forces, processed_source)
|
|
43
|
+
walk(processed_source.ast) unless processed_source.blank?
|
|
44
|
+
invoke_custom_post_walk_processing(@cops, processed_source)
|
|
45
|
+
@cops.flat_map(&:offenses)
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
private
|
|
49
|
+
|
|
50
|
+
def trigger_responding_cops(callback, node)
|
|
51
|
+
@callbacks[callback] ||= @cops.select do |cop|
|
|
52
|
+
cop.respond_to?(callback)
|
|
53
|
+
end
|
|
54
|
+
@callbacks[callback].each do |cop|
|
|
55
|
+
with_cop_error_handling(cop, node) do
|
|
56
|
+
cop.send(callback, node)
|
|
57
|
+
end
|
|
58
|
+
end
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
def reset_errors
|
|
62
|
+
@errors = []
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
def reset_callbacks
|
|
66
|
+
@callbacks.clear
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
# TODO: Bad design.
|
|
70
|
+
def prepare(processed_source)
|
|
71
|
+
@cops.each { |cop| cop.processed_source = processed_source }
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
# There are cops/forces that require their own custom processing.
|
|
75
|
+
# If they define the #investigate method, all input parameters passed
|
|
76
|
+
# to the commissioner will be passed to the cop too in order to do
|
|
77
|
+
# its own processing.
|
|
78
|
+
#
|
|
79
|
+
# These custom processors are invoked before the AST traversal,
|
|
80
|
+
# so they can build initial state that is later used by callbacks
|
|
81
|
+
# during the AST traversal.
|
|
82
|
+
def invoke_custom_processing(cops_or_forces, processed_source)
|
|
83
|
+
cops_or_forces.each do |cop|
|
|
84
|
+
next unless cop.respond_to?(:investigate)
|
|
85
|
+
|
|
86
|
+
with_cop_error_handling(cop) do
|
|
87
|
+
cop.investigate(processed_source)
|
|
88
|
+
end
|
|
89
|
+
end
|
|
90
|
+
end
|
|
91
|
+
|
|
92
|
+
# There are cops that require their own custom processing **after**
|
|
93
|
+
# the AST traversal. By performing the walk before invoking these
|
|
94
|
+
# custom processors, we allow these cops to build their own
|
|
95
|
+
# state during the primary AST traversal instead of performing their
|
|
96
|
+
# own AST traversals. Minimizing the number of walks is more efficient.
|
|
97
|
+
#
|
|
98
|
+
# If they define the #investigate_post_walk method, all input parameters
|
|
99
|
+
# passed to the commissioner will be passed to the cop too in order to do
|
|
100
|
+
# its own processing.
|
|
101
|
+
def invoke_custom_post_walk_processing(cops, processed_source)
|
|
102
|
+
cops.each do |cop|
|
|
103
|
+
next unless cop.respond_to?(:investigate_post_walk)
|
|
104
|
+
|
|
105
|
+
with_cop_error_handling(cop) do
|
|
106
|
+
cop.investigate_post_walk(processed_source)
|
|
107
|
+
end
|
|
108
|
+
end
|
|
109
|
+
end
|
|
110
|
+
|
|
111
|
+
# Allow blind rescues here, since we're absorbing and packaging or
|
|
112
|
+
# re-raising exceptions that can be raised from within the individual
|
|
113
|
+
# cops' `#investigate` methods.
|
|
114
|
+
def with_cop_error_handling(cop, node = nil)
|
|
115
|
+
yield
|
|
116
|
+
rescue StandardError => e
|
|
117
|
+
raise e if @options[:raise_error]
|
|
118
|
+
|
|
119
|
+
err = ErrorWithAnalyzedFileLocation.new(cause: e, node: node, cop: cop)
|
|
120
|
+
@errors << err
|
|
121
|
+
end
|
|
122
|
+
end
|
|
123
|
+
end
|
|
124
|
+
end
|
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require 'uri'
|
|
4
|
+
|
|
5
|
+
module RuboCop
|
|
6
|
+
module Cop
|
|
7
|
+
# A scaffold for concrete cops.
|
|
8
|
+
#
|
|
9
|
+
# The Cop class is meant to be extended.
|
|
10
|
+
#
|
|
11
|
+
# Cops track offenses and can autocorrect them on the fly.
|
|
12
|
+
#
|
|
13
|
+
# A commissioner object is responsible for traversing the AST and invoking
|
|
14
|
+
# the specific callbacks on each cop.
|
|
15
|
+
# If a cop needs to do its own processing of the AST or depends on
|
|
16
|
+
# something else, it should define the `#investigate` method and do
|
|
17
|
+
# the processing there.
|
|
18
|
+
#
|
|
19
|
+
# @example
|
|
20
|
+
#
|
|
21
|
+
# class CustomCop < Cop
|
|
22
|
+
# def investigate(processed_source)
|
|
23
|
+
# # Do custom processing
|
|
24
|
+
# end
|
|
25
|
+
# end
|
|
26
|
+
class Cop # rubocop:disable Metrics/ClassLength
|
|
27
|
+
extend RuboCop::AST::Sexp
|
|
28
|
+
extend NodePattern::Macros
|
|
29
|
+
include RuboCop::AST::Sexp
|
|
30
|
+
include Util
|
|
31
|
+
include IgnoredNode
|
|
32
|
+
include AutocorrectLogic
|
|
33
|
+
|
|
34
|
+
Correction = Struct.new(:lambda, :node, :cop) do
|
|
35
|
+
def call(corrector)
|
|
36
|
+
lambda.call(corrector)
|
|
37
|
+
rescue StandardError => e
|
|
38
|
+
raise ErrorWithAnalyzedFileLocation.new(
|
|
39
|
+
cause: e, node: node, cop: cop
|
|
40
|
+
)
|
|
41
|
+
end
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
attr_reader :config, :offenses, :corrections
|
|
45
|
+
attr_accessor :processed_source # TODO: Bad design.
|
|
46
|
+
|
|
47
|
+
def self.inherited(subclass)
|
|
48
|
+
Registry.global.enlist(subclass)
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
def self.exclude_from_registry
|
|
52
|
+
Registry.global.dismiss(self)
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
def self.badge
|
|
56
|
+
@badge ||= Badge.for(name)
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def self.cop_name
|
|
60
|
+
badge.to_s
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
def self.department
|
|
64
|
+
badge.department
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
def self.lint?
|
|
68
|
+
department == :Lint
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
# Returns true if the cop name or the cop namespace matches any of the
|
|
72
|
+
# given names.
|
|
73
|
+
def self.match?(given_names)
|
|
74
|
+
return false unless given_names
|
|
75
|
+
|
|
76
|
+
given_names.include?(cop_name) ||
|
|
77
|
+
given_names.include?(department.to_s)
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
# List of cops that should not try to autocorrect at the same
|
|
81
|
+
# time as this cop
|
|
82
|
+
#
|
|
83
|
+
# @return [Array<RuboCop::Cop::Cop>]
|
|
84
|
+
#
|
|
85
|
+
# @api public
|
|
86
|
+
def self.autocorrect_incompatible_with
|
|
87
|
+
[]
|
|
88
|
+
end
|
|
89
|
+
|
|
90
|
+
def initialize(config = nil, options = nil)
|
|
91
|
+
@config = config || Config.new
|
|
92
|
+
@options = options || { debug: false }
|
|
93
|
+
|
|
94
|
+
@offenses = []
|
|
95
|
+
@corrections = []
|
|
96
|
+
@corrected_nodes = {}
|
|
97
|
+
@corrected_nodes.compare_by_identity
|
|
98
|
+
@processed_source = nil
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
def join_force?(_force_class)
|
|
102
|
+
false
|
|
103
|
+
end
|
|
104
|
+
|
|
105
|
+
def cop_config
|
|
106
|
+
# Use department configuration as basis, but let individual cop
|
|
107
|
+
# configuration override.
|
|
108
|
+
@cop_config ||= @config.for_cop(self.class.department.to_s)
|
|
109
|
+
.merge(@config.for_cop(self))
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
def message(_node = nil)
|
|
113
|
+
self.class::MSG
|
|
114
|
+
end
|
|
115
|
+
|
|
116
|
+
def add_offense(node, location: :expression, message: nil, severity: nil)
|
|
117
|
+
loc = find_location(node, location)
|
|
118
|
+
|
|
119
|
+
return if duplicate_location?(loc)
|
|
120
|
+
|
|
121
|
+
severity = find_severity(node, severity)
|
|
122
|
+
message = find_message(node, message)
|
|
123
|
+
|
|
124
|
+
status = enabled_line?(loc.line) ? correct(node) : :disabled
|
|
125
|
+
|
|
126
|
+
@offenses << Offense.new(severity, loc, message, name, status)
|
|
127
|
+
yield if block_given? && status != :disabled
|
|
128
|
+
end
|
|
129
|
+
|
|
130
|
+
def find_location(node, loc)
|
|
131
|
+
# Location can be provided as a symbol, e.g.: `:keyword`
|
|
132
|
+
loc.is_a?(Symbol) ? node.loc.public_send(loc) : loc
|
|
133
|
+
end
|
|
134
|
+
|
|
135
|
+
def duplicate_location?(location)
|
|
136
|
+
@offenses.any? { |o| o.location == location }
|
|
137
|
+
end
|
|
138
|
+
|
|
139
|
+
def correct(node) # rubocop:disable Metrics/PerceivedComplexity, Metrics/MethodLength
|
|
140
|
+
reason = reason_to_not_correct(node)
|
|
141
|
+
return reason if reason
|
|
142
|
+
|
|
143
|
+
@corrected_nodes[node] = true
|
|
144
|
+
|
|
145
|
+
if support_autocorrect?
|
|
146
|
+
correction = autocorrect(node)
|
|
147
|
+
|
|
148
|
+
if correction
|
|
149
|
+
@corrections << Correction.new(correction, node, self)
|
|
150
|
+
:corrected
|
|
151
|
+
elsif disable_uncorrectable?
|
|
152
|
+
disable_uncorrectable(node)
|
|
153
|
+
:corrected_with_todo
|
|
154
|
+
else
|
|
155
|
+
:uncorrected
|
|
156
|
+
end
|
|
157
|
+
elsif disable_uncorrectable?
|
|
158
|
+
disable_uncorrectable(node)
|
|
159
|
+
:corrected_with_todo
|
|
160
|
+
end
|
|
161
|
+
end
|
|
162
|
+
|
|
163
|
+
def reason_to_not_correct(node)
|
|
164
|
+
return :unsupported unless correctable?
|
|
165
|
+
return :uncorrected unless autocorrect?
|
|
166
|
+
return :already_corrected if @corrected_nodes.key?(node)
|
|
167
|
+
|
|
168
|
+
nil
|
|
169
|
+
end
|
|
170
|
+
|
|
171
|
+
def disable_uncorrectable(node)
|
|
172
|
+
return unless node
|
|
173
|
+
|
|
174
|
+
@disabled_lines ||= {}
|
|
175
|
+
line = node.location.line
|
|
176
|
+
return if @disabled_lines.key?(line)
|
|
177
|
+
|
|
178
|
+
@disabled_lines[line] = true
|
|
179
|
+
@corrections << Correction.new(disable_offense(node), node, self)
|
|
180
|
+
end
|
|
181
|
+
|
|
182
|
+
def config_to_allow_offenses
|
|
183
|
+
Formatter::DisabledConfigFormatter
|
|
184
|
+
.config_to_allow_offenses[cop_name] ||= {}
|
|
185
|
+
end
|
|
186
|
+
|
|
187
|
+
def config_to_allow_offenses=(hash)
|
|
188
|
+
Formatter::DisabledConfigFormatter.config_to_allow_offenses[cop_name] =
|
|
189
|
+
hash
|
|
190
|
+
end
|
|
191
|
+
|
|
192
|
+
def target_ruby_version
|
|
193
|
+
@config.target_ruby_version
|
|
194
|
+
end
|
|
195
|
+
|
|
196
|
+
def target_rails_version
|
|
197
|
+
@config.target_rails_version
|
|
198
|
+
end
|
|
199
|
+
|
|
200
|
+
def parse(source, path = nil)
|
|
201
|
+
ProcessedSource.new(source, target_ruby_version, path)
|
|
202
|
+
end
|
|
203
|
+
|
|
204
|
+
def cop_name
|
|
205
|
+
@cop_name ||= self.class.cop_name
|
|
206
|
+
end
|
|
207
|
+
|
|
208
|
+
alias name cop_name
|
|
209
|
+
|
|
210
|
+
def relevant_file?(file)
|
|
211
|
+
file == RuboCop::AST::ProcessedSource::STRING_SOURCE_NAME ||
|
|
212
|
+
file_name_matches_any?(file, 'Include', true) &&
|
|
213
|
+
!file_name_matches_any?(file, 'Exclude', false)
|
|
214
|
+
end
|
|
215
|
+
|
|
216
|
+
def excluded_file?(file)
|
|
217
|
+
!relevant_file?(file)
|
|
218
|
+
end
|
|
219
|
+
|
|
220
|
+
# This method should be overridden when a cop's behavior depends
|
|
221
|
+
# on state that lives outside of these locations:
|
|
222
|
+
#
|
|
223
|
+
# (1) the file under inspection
|
|
224
|
+
# (2) the cop's source code
|
|
225
|
+
# (3) the config (eg a .rubocop.yml file)
|
|
226
|
+
#
|
|
227
|
+
# For example, some cops may want to look at other parts of
|
|
228
|
+
# the codebase being inspected to find violations. A cop may
|
|
229
|
+
# use the presence or absence of file `foo.rb` to determine
|
|
230
|
+
# whether a certain violation exists in `bar.rb`.
|
|
231
|
+
#
|
|
232
|
+
# Overriding this method allows the cop to indicate to RuboCop's
|
|
233
|
+
# ResultCache system when those external dependencies change,
|
|
234
|
+
# ie when the ResultCache should be invalidated.
|
|
235
|
+
def external_dependency_checksum
|
|
236
|
+
nil
|
|
237
|
+
end
|
|
238
|
+
|
|
239
|
+
### Deprecated registry access
|
|
240
|
+
|
|
241
|
+
# @deprecated Use Registry.global
|
|
242
|
+
def self.registry
|
|
243
|
+
Registry.global
|
|
244
|
+
end
|
|
245
|
+
|
|
246
|
+
# @deprecated Use Registry.all
|
|
247
|
+
def self.all
|
|
248
|
+
Registry.all
|
|
249
|
+
end
|
|
250
|
+
|
|
251
|
+
# @deprecated Use Registry.qualified_cop_name
|
|
252
|
+
def self.qualified_cop_name(name, origin)
|
|
253
|
+
Registry.qualified_cop_name(name, origin)
|
|
254
|
+
end
|
|
255
|
+
|
|
256
|
+
private
|
|
257
|
+
|
|
258
|
+
def find_message(node, message)
|
|
259
|
+
annotate(message || message(node))
|
|
260
|
+
end
|
|
261
|
+
|
|
262
|
+
def annotate(message)
|
|
263
|
+
RuboCop::Cop::MessageAnnotator.new(
|
|
264
|
+
config, cop_name, cop_config, @options
|
|
265
|
+
).annotate(message)
|
|
266
|
+
end
|
|
267
|
+
|
|
268
|
+
def file_name_matches_any?(file, parameter, default_result)
|
|
269
|
+
patterns = cop_config[parameter]
|
|
270
|
+
return default_result unless patterns
|
|
271
|
+
|
|
272
|
+
path = nil
|
|
273
|
+
patterns.any? do |pattern|
|
|
274
|
+
# Try to match the absolute path, as Exclude properties are absolute.
|
|
275
|
+
next true if match_path?(pattern, file)
|
|
276
|
+
|
|
277
|
+
# Try with relative path.
|
|
278
|
+
path ||= config.path_relative_to_config(file)
|
|
279
|
+
match_path?(pattern, path)
|
|
280
|
+
end
|
|
281
|
+
end
|
|
282
|
+
|
|
283
|
+
def enabled_line?(line_number)
|
|
284
|
+
return true if @options[:ignore_disable_comments] || !@processed_source
|
|
285
|
+
|
|
286
|
+
@processed_source.comment_config.cop_enabled_at_line?(self, line_number)
|
|
287
|
+
end
|
|
288
|
+
|
|
289
|
+
def find_severity(_node, severity)
|
|
290
|
+
custom_severity || severity || default_severity
|
|
291
|
+
end
|
|
292
|
+
|
|
293
|
+
def default_severity
|
|
294
|
+
self.class.lint? ? :warning : :convention
|
|
295
|
+
end
|
|
296
|
+
|
|
297
|
+
def custom_severity
|
|
298
|
+
severity = cop_config['Severity']
|
|
299
|
+
return unless severity
|
|
300
|
+
|
|
301
|
+
if Severity::NAMES.include?(severity.to_sym)
|
|
302
|
+
severity.to_sym
|
|
303
|
+
else
|
|
304
|
+
message = "Warning: Invalid severity '#{severity}'. " \
|
|
305
|
+
"Valid severities are #{Severity::NAMES.join(', ')}."
|
|
306
|
+
warn(Rainbow(message).red)
|
|
307
|
+
end
|
|
308
|
+
end
|
|
309
|
+
end
|
|
310
|
+
end
|
|
311
|
+
end
|