Class: RuboCop::Cop::FormulaAudit::NonPublicApiUsage Private

Inherits:
RuboCop::Cop::FormulaCop show all
Defined in:
rubocops/non_public_api_usage.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.

Ensures that formulae in official taps (homebrew-core, homebrew-cask) only use methods that are part of the public API (@api public) and do not call methods marked as @api private or @api internal.

The lists of internal/private methods are derived dynamically from @api annotations in the source files rather than hardcoded, so they stay in sync automatically.

Example

# bad - `tap` is @api internal
class Foo < Formula
  def install
    puts tap
  end
end

# good - `bin` is @api public
class Foo < Formula
  def install
    bin.install "foo"
  end
end

Constant Summary collapse

INTERNAL_MSG =

This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.

"Do not use `%<method>s` in official tap formulae; it is an internal API (`@api internal`)."
PRIVATE_MSG =

This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.

"Do not use `%<method>s` in official tap formulae; it is a private API (`@api private`)."

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?, #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, #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:



40
41
42
43
44
45
46
# File 'rubocops/non_public_api_usage.rb', line 40

def audit_formula(formula_nodes)
  return if ApiAnnotationHelper::OFFICIAL_TAPS.none?(formula_tap)
  return if (body_node = formula_nodes.body_node).nil?

  check_method_calls(body_node, internal_methods, INTERNAL_MSG)
  check_method_calls(body_node, private_methods, PRIVATE_MSG)
end