Class: RuboCop::Cop::FormulaAudit::Patches Private

Inherits:
RuboCop::Cop::FormulaCop show all
Extended by:
AutoCorrector
Defined in:
rubocops/patches.rb,
sorbet/rbi/dsl/rubo_cop/cop/formula_audit/patches.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.

TODO:

Many of these could be auto-corrected.

This cop audits patches in formulae.

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:



15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'rubocops/patches.rb', line 15

def audit_formula(formula_nodes)
  node = formula_nodes.node
  @full_source_content = source_buffer(node).source

  return if (body_node = formula_nodes.body_node).nil?

  external_patches = find_all_blocks(body_node, :patch)
  external_patches.each do |patch_block|
    url_node = find_every_method_call_by_name(patch_block, :url).first
    url_string = parameters(url_node).first
    patch_problems(url_string)
  end

  inline_patches = find_every_method_call_by_name(body_node, :patch)
  inline_patches.each { |patch| inline_patch_problems(patch) }

  if inline_patches.empty? && patch_end?
    offending_patch_end_node(node)
    add_offense(@offense_source_range, message: "patch is missing 'DATA'")
  end

  patches_node = find_method_def(body_node, :patches)
  return if patches_node.nil?

  legacy_patches = find_strings(patches_node)
  problem "Use the patch DSL instead of defining a 'patches' method"
  legacy_patches.each { |p| patch_problems(p) }
end

#patch_data?(node, *pattern, **kwargs, &block) ⇒ Boolean

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.

Parameters:

Returns:

  • (Boolean)


17
# File 'sorbet/rbi/dsl/rubo_cop/cop/formula_audit/patches.rbi', line 17

def patch_data?(node, *pattern, **kwargs, &block); end