Class: RuboCop::Cop::FormulaAudit::StdNpmArgs Private
- Inherits:
-
RuboCop::Cop::FormulaCop
- Object
- Base
- RuboCop::Cop::FormulaCop
- RuboCop::Cop::FormulaAudit::StdNpmArgs
- Extended by:
- AutoCorrector
- Defined in:
- rubocops/lines.rb,
sorbet/rbi/dsl/rubo_cop/cop/formula_audit/std_npm_args.rbi
Overview
This class is part of a private API. This class may only be used in the Homebrew/brew repository. Third parties should avoid using this class if possible, as it may be removed or changed without warning.
This cop makes sure that formulae use std_npm_args
instead of older
local_npm_install_args
and std_npm_install_args
.
Instance Attribute Summary
Attributes inherited from RuboCop::Cop::FormulaCop
Instance Method Summary collapse
Methods inherited from RuboCop::Cop::FormulaCop
#audit_comments, #audit_urls, #caveats_strings, #dependency_name_hash_match?, #dependency_type_hash_match?, #depends_on?, #depends_on_name_type?, #formula_tap, #get_checksum_node, #on_class, #required_dependency?, #required_dependency_name?, #style_exceptions_dir, #tap_style_exception?, #versioned_formula?
Methods included from HelperFunctions
#block_method_called_in_block?, #block_size, #check_precedence, #class_name, #component_precedes?, #end_column, #expression_negated?, #find_all_blocks, #find_block, #find_blocks, #find_const, #find_every_func_call_by_name, #find_every_method_call_by_name, #find_instance_call, #find_instance_method_call, #find_method_calls_by_name, #find_method_def, #find_method_with_args, #find_node_method_by_name, #find_strings, #format_component, #line_number, #line_start_column, #method_called?, #method_called_ever?, #method_name, #node_equals?, #offending_node, #parameters, #parameters_passed?, #problem, #regex_match_group, #size, #source_buffer, #start_column, #string_content
Instance Method Details
#audit_formula(formula_nodes) ⇒ void
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
This method returns an undefined value.
223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 |
# File 'rubocops/lines.rb', line 223 def audit_formula(formula_nodes) return if (body_node = formula_nodes.body_node).nil? find_method_with_args(body_node, :local_npm_install_args) do problem "Use 'std_npm_args' instead of '#{@offensive_node.method_name}'." do |corrector| corrector.replace(@offensive_node.source_range, "std_npm_args(prefix: false)") end end find_method_with_args(body_node, :std_npm_install_args) do |method| problem "Use 'std_npm_args' instead of '#{@offensive_node.method_name}'." do |corrector| if (param = parameters(method).first.source) == "libexec" corrector.replace(@offensive_node.source_range, "std_npm_args") else corrector.replace(@offensive_node.source_range, "std_npm_args(prefix: #{param})") end end end find_every_method_call_by_name(body_node, :system).each do |method| first_param, second_param = parameters(method) next if !node_equals?(first_param, "npm") || !node_equals?(second_param, "install") || method.source.match(/(std_npm_args|local_npm_install_args|std_npm_install_args)/) offending_node(method) problem "Use `std_npm_args` for npm install" end end |