Revert "uses: properly handle untapped formulae in recursive dependency expansion"
This commit is contained in:
parent
2aac904eac
commit
dc9819b86c
@ -47,49 +47,48 @@ module Homebrew
|
|||||||
|
|
||||||
uses = formulae.select do |f|
|
uses = formulae.select do |f|
|
||||||
used_formulae.all? do |ff|
|
used_formulae.all? do |ff|
|
||||||
if recursive
|
begin
|
||||||
deps = f.recursive_dependencies do |dependent, dep|
|
if recursive
|
||||||
if dep.recommended?
|
deps = f.recursive_dependencies do |dependent, dep|
|
||||||
Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
|
if dep.recommended?
|
||||||
elsif dep.optional?
|
Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
|
||||||
Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
|
elsif dep.optional?
|
||||||
elsif dep.build?
|
Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
|
||||||
Dependency.prune unless includes.include?("build?")
|
elsif dep.build?
|
||||||
|
Dependency.prune unless includes.include?("build?")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
reqs = f.recursive_requirements do |dependent, req|
|
||||||
|
if req.recommended?
|
||||||
|
Requirement.prune if ignores.include?("recommended?") || dependent.build.without?(req)
|
||||||
|
elsif req.optional?
|
||||||
|
Requirement.prune if !includes.include?("optional?") && !dependent.build.with?(req)
|
||||||
|
elsif req.build?
|
||||||
|
Requirement.prune unless includes.include?("build?")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
deps = f.deps.reject do |dep|
|
||||||
|
ignores.any? { |ignore| dep.send(ignore) } && !includes.any? { |include| dep.send(include) }
|
||||||
|
end
|
||||||
|
reqs = f.requirements.reject do |req|
|
||||||
|
ignores.any? { |ignore| req.send(ignore) } && !includes.any? { |include| req.send(include) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
next true if deps.any? do |dep|
|
||||||
|
begin
|
||||||
|
dep.to_formula.full_name == ff.full_name
|
||||||
|
rescue
|
||||||
|
dep.name == ff.name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# If a tap isn't installed, we can't find the dependencies of one
|
reqs.any? do |req|
|
||||||
# its formulae, and an exception will be thrown if we try.
|
req.name == ff.name || [ff.name, ff.full_name].include?(req.default_formula)
|
||||||
if dep.is_a?(TapDependency) && !dep.tap.installed?
|
|
||||||
Dependency.keep_but_prune_recursive_deps
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
reqs = f.recursive_requirements do |dependent, req|
|
rescue FormulaUnavailableError
|
||||||
if req.recommended?
|
# Silently ignore this case as we don't care about things used in
|
||||||
Requirement.prune if ignores.include?("recommended?") || dependent.build.without?(req)
|
# taps that aren't currently tapped.
|
||||||
elsif req.optional?
|
|
||||||
Requirement.prune if !includes.include?("optional?") && !dependent.build.with?(req)
|
|
||||||
elsif req.build?
|
|
||||||
Requirement.prune unless includes.include?("build?")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
else
|
|
||||||
deps = f.deps.reject do |dep|
|
|
||||||
ignores.any? { |ignore| dep.send(ignore) } && !includes.any? { |include| dep.send(include) }
|
|
||||||
end
|
|
||||||
reqs = f.requirements.reject do |req|
|
|
||||||
ignores.any? { |ignore| req.send(ignore) } && !includes.any? { |include| req.send(include) }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
next true if deps.any? do |dep|
|
|
||||||
begin
|
|
||||||
dep.to_formula.full_name == ff.full_name
|
|
||||||
rescue
|
|
||||||
dep.name == ff.name
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
reqs.any? do |req|
|
|
||||||
req.name == ff.name || [ff.name, ff.full_name].include?(req.default_formula)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -175,7 +175,7 @@ class TapDependency < Dependency
|
|||||||
attr_reader :tap
|
attr_reader :tap
|
||||||
|
|
||||||
def initialize(name, tags = [], env_proc = DEFAULT_ENV_PROC, option_names = [name.split("/").last])
|
def initialize(name, tags = [], env_proc = DEFAULT_ENV_PROC, option_names = [name.split("/").last])
|
||||||
@tap = Tap.fetch(name.rpartition("/").first)
|
@tap = name.rpartition("/").first
|
||||||
super(name, tags, env_proc, option_names)
|
super(name, tags, env_proc, option_names)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -118,11 +118,6 @@ class DependencyTests < Homebrew::TestCase
|
|||||||
end
|
end
|
||||||
|
|
||||||
class TapDependencyTests < Homebrew::TestCase
|
class TapDependencyTests < Homebrew::TestCase
|
||||||
def test_tap
|
|
||||||
dep = TapDependency.new("foo/bar/dog")
|
|
||||||
assert_equal Tap.new("foo", "bar"), dep.tap
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_option_names
|
def test_option_names
|
||||||
dep = TapDependency.new("foo/bar/dog")
|
dep = TapDependency.new("foo/bar/dog")
|
||||||
assert_equal %w[dog], dep.option_names
|
assert_equal %w[dog], dep.option_names
|
||||||
|
Loading…
x
Reference in New Issue
Block a user