Class: RuboCop::Cop::FormulaAudit::StdNpmArgs Private

Inherits:
RuboCop::Cop::FormulaCop show all
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

#file_path

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.

Parameters:



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