aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlyssa Ross2017-01-15 17:40:51 +0000
committerAlyssa Ross2017-01-16 23:28:26 +0000
commit0b216798bb33e63e7b9da795925f610f93cc1e33 (patch)
treeefc29c29e6f5d40288b18c72631a6bb64f0984bc
parent10b8d27d118c5db7ce4293861cded28e8516e849 (diff)
downloadbrew-0b216798bb33e63e7b9da795925f610f93cc1e33.tar.bz2
Revert "Revert "uses: properly handle untapped fo…
…rmulae in recursive dependency expansion"" This reverts commit dc9819b86c60b5c6fd10373ff318d8ef60f97d52.
-rw-r--r--Library/Homebrew/cmd/uses.rb73
-rw-r--r--Library/Homebrew/dependency.rb2
-rw-r--r--Library/Homebrew/test/dependency_test.rb5
3 files changed, 43 insertions, 37 deletions
diff --git a/Library/Homebrew/cmd/uses.rb b/Library/Homebrew/cmd/uses.rb
index fb11a31a7..f9af36754 100644
--- a/Library/Homebrew/cmd/uses.rb
+++ b/Library/Homebrew/cmd/uses.rb
@@ -47,48 +47,49 @@ module Homebrew
uses = formulae.select do |f|
used_formulae.all? do |ff|
- begin
- if recursive
- deps = f.recursive_dependencies do |dependent, dep|
- if dep.recommended?
- Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
- elsif dep.optional?
- Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
- elsif dep.build?
- Dependency.prune unless includes.include?("build?")
- end
+ if recursive
+ deps = f.recursive_dependencies do |dependent, dep|
+ if dep.recommended?
+ Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
+ elsif dep.optional?
+ Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
+ elsif dep.build?
+ Dependency.prune unless includes.include?("build?")
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) }
+
+ # If a tap isn't installed, we can't find the dependencies of one
+ # its formulae, and an exception will be thrown if we try.
+ if dep.is_a?(TapDependency) && !dep.tap.installed?
+ Dependency.keep_but_prune_recursive_deps
end
end
- next true if deps.any? do |dep|
- begin
- dep.to_formula.full_name == ff.full_name
- rescue
- dep.name == ff.name
+ 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
-
- reqs.any? do |req|
- req.name == ff.name || [ff.name, ff.full_name].include?(req.default_formula)
+ 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
- rescue FormulaUnavailableError
- # Silently ignore this case as we don't care about things used in
- # taps that aren't currently tapped.
+ 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
diff --git a/Library/Homebrew/dependency.rb b/Library/Homebrew/dependency.rb
index 253ba4bee..4a452440a 100644
--- a/Library/Homebrew/dependency.rb
+++ b/Library/Homebrew/dependency.rb
@@ -175,7 +175,7 @@ class TapDependency < Dependency
attr_reader :tap
def initialize(name, tags = [], env_proc = DEFAULT_ENV_PROC, option_names = [name.split("/").last])
- @tap = name.rpartition("/").first
+ @tap = Tap.fetch(name.rpartition("/").first)
super(name, tags, env_proc, option_names)
end
diff --git a/Library/Homebrew/test/dependency_test.rb b/Library/Homebrew/test/dependency_test.rb
index 65255995e..134e91d13 100644
--- a/Library/Homebrew/test/dependency_test.rb
+++ b/Library/Homebrew/test/dependency_test.rb
@@ -118,6 +118,11 @@ class DependencyTests < Homebrew::TestCase
end
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
dep = TapDependency.new("foo/bar/dog")
assert_equal %w[dog], dep.option_names