Class: Homebrew::TapAuditor Private

Inherits:
Object show all
Defined in:
tap_auditor.rb

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.

Auditor for checking common violations in Taps.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(tap, strict:) ⇒ 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.

Parameters:

  • tap (Tap)
  • strict (Boolean, nil)


11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'tap_auditor.rb', line 11

def initialize(tap, strict:)
  Homebrew.with_no_api_env do
    tap.clear_cache if Homebrew::EnvConfig.automatically_set_no_install_from_api?
    @name                      = tap.name
    @path                      = tap.path
    @tap_audit_exceptions      = tap.audit_exceptions
    @tap_style_exceptions      = tap.style_exceptions
    @tap_pypi_formula_mappings = tap.pypi_formula_mappings
    @tap_autobump              = tap.autobump
    @problems                  = []

    @cask_tokens = tap.cask_tokens.map do |cask_token|
      cask_token.split("/").last
    end
    @formula_aliases = tap.aliases.map do |formula_alias|
      formula_alias.split("/").last
    end
    @formula_renames = tap.formula_renames
    @formula_names = tap.formula_names.map do |formula_name|
      formula_name.split("/").last
    end
  end
end

Instance Attribute Details

#cask_tokensObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def cask_tokens
  @cask_tokens
end

#formula_aliasesObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def formula_aliases
  @formula_aliases
end

#formula_namesObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def formula_names
  @formula_names
end

#formula_renamesObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def formula_renames
  @formula_renames
end

#nameObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def name
  @name
end

#pathObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def path
  @path
end

#problemsObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def problems
  @problems
end

#tap_audit_exceptionsObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def tap_audit_exceptions
  @tap_audit_exceptions
end

#tap_pypi_formula_mappingsObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def tap_pypi_formula_mappings
  @tap_pypi_formula_mappings
end

#tap_style_exceptionsObject (readonly)

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.



7
8
9
# File 'tap_auditor.rb', line 7

def tap_style_exceptions
  @tap_style_exceptions
end

Instance Method Details

#auditvoid

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.



36
37
38
39
40
# File 'tap_auditor.rb', line 36

def audit
  audit_json_files
  audit_tap_formula_lists
  audit_aliases_renames_duplicates
end

#audit_aliases_renames_duplicatesvoid

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.



62
63
64
65
66
67
# File 'tap_auditor.rb', line 62

def audit_aliases_renames_duplicates
  duplicates = formula_aliases & formula_renames.keys
  return if duplicates.none?

  problem "The following should either be an alias or a rename, not both: #{duplicates.to_sentence}"
end

#audit_json_filesvoid

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.



43
44
45
46
47
48
49
50
# File 'tap_auditor.rb', line 43

def audit_json_files
  json_patterns = Tap::HOMEBREW_TAP_JSON_FILES.map { |pattern| @path/pattern }
  Pathname.glob(json_patterns).each do |file|
    JSON.parse file.read
  rescue JSON::ParserError
    problem "#{file.to_s.delete_prefix("#{@path}/")} contains invalid JSON"
  end
end

#audit_tap_formula_listsvoid

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.



53
54
55
56
57
58
59
# File 'tap_auditor.rb', line 53

def audit_tap_formula_lists
  check_formula_list_directory "audit_exceptions", @tap_audit_exceptions
  check_formula_list_directory "style_exceptions", @tap_style_exceptions
  check_formula_list "pypi_formula_mappings", @tap_pypi_formula_mappings
  check_formula_list ".github/autobump.txt", @tap_autobump
  check_formula_list "formula_renames", @formula_renames.values
end

#problem(message) ⇒ 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:



70
71
72
# File 'tap_auditor.rb', line 70

def problem(message)
  @problems << ({ message:, location: nil, corrected: false })
end