mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
98 lines
3.4 KiB
Ruby
98 lines
3.4 KiB
Ruby
# typed: strict
|
|
# frozen_string_literal: true
|
|
|
|
require "cask_dependent"
|
|
|
|
# Helper functions for dependencies.
|
|
module DependenciesHelpers
|
|
def args_includes_ignores(args)
|
|
includes = [:required?, :recommended?] # included by default
|
|
includes << :implicit? if args.include_implicit?
|
|
includes << :build? if args.include_build?
|
|
includes << :test? if args.include_test?
|
|
includes << :optional? if args.include_optional?
|
|
|
|
ignores = []
|
|
ignores << :recommended? if args.skip_recommended?
|
|
ignores << :satisfied? if args.missing?
|
|
|
|
[includes, ignores]
|
|
end
|
|
|
|
sig {
|
|
params(root_dependent: T.any(Formula, CaskDependent), includes: T::Array[Symbol], ignores: T::Array[Symbol])
|
|
.returns(T::Array[Dependency])
|
|
}
|
|
def recursive_dep_includes(root_dependent, includes, ignores)
|
|
# The use of T.unsafe is recommended by the Sorbet docs:
|
|
# https://sorbet.org/docs/overloads#multiple-methods-but-sharing-a-common-implementation
|
|
T.unsafe(recursive_includes(Dependency, root_dependent, includes, ignores))
|
|
end
|
|
|
|
sig {
|
|
params(root_dependent: T.any(Formula, CaskDependent), includes: T::Array[Symbol], ignores: T::Array[Symbol])
|
|
.returns(Requirements)
|
|
}
|
|
def recursive_req_includes(root_dependent, includes, ignores)
|
|
# The use of T.unsafe is recommended by the Sorbet docs:
|
|
# https://sorbet.org/docs/overloads#multiple-methods-but-sharing-a-common-implementation
|
|
T.unsafe(recursive_includes(Requirement, root_dependent, includes, ignores))
|
|
end
|
|
|
|
sig {
|
|
params(
|
|
klass: T.any(T.class_of(Dependency), T.class_of(Requirement)),
|
|
root_dependent: T.any(Formula, CaskDependent),
|
|
includes: T::Array[Symbol],
|
|
ignores: T::Array[Symbol],
|
|
).returns(T.any(T::Array[Dependency], Requirements))
|
|
}
|
|
def recursive_includes(klass, root_dependent, includes, ignores)
|
|
cache_key = "recursive_includes_#{includes}_#{ignores}"
|
|
|
|
klass.expand(root_dependent, cache_key:) do |dependent, dep|
|
|
klass.prune if ignores.any? { |ignore| dep.public_send(ignore) }
|
|
klass.prune if includes.none? do |include|
|
|
# Ignore indirect test dependencies
|
|
next if include == :test? && dependent != root_dependent
|
|
|
|
dep.public_send(include)
|
|
end
|
|
|
|
# If a tap isn't installed, we can't find the dependencies of one of
|
|
# its formulae and an exception will be thrown if we try.
|
|
Dependency.keep_but_prune_recursive_deps if klass == Dependency && dep.tap && !dep.tap.installed?
|
|
end
|
|
end
|
|
|
|
sig {
|
|
params(
|
|
dependables: T.any(Dependencies, Requirements, T::Array[Dependency], T::Array[Requirement]),
|
|
ignores: T::Array[Symbol],
|
|
includes: T::Array[Symbol],
|
|
).returns(T::Array[T.any(Dependency, Requirement)])
|
|
}
|
|
def select_includes(dependables, ignores, includes)
|
|
dependables.select do |dep|
|
|
next false if ignores.any? { |ignore| dep.public_send(ignore) }
|
|
|
|
includes.any? { |include| dep.public_send(include) }
|
|
end
|
|
end
|
|
|
|
sig {
|
|
params(formulae_or_casks: T::Array[T.any(Formula, Keg, Cask::Cask)])
|
|
.returns(T::Array[T.any(Formula, CaskDependent)])
|
|
}
|
|
def dependents(formulae_or_casks)
|
|
formulae_or_casks.map do |formula_or_cask|
|
|
case formula_or_cask
|
|
when Formula then formula_or_cask
|
|
when Cask::Cask then CaskDependent.new(formula_or_cask)
|
|
else
|
|
raise TypeError, "Unsupported type: #{formula_or_cask.class}"
|
|
end
|
|
end
|
|
end
|
|
end
|