Merge pull request #3973 from MikeMcQuaid/dependencies-refactoring
Refactor dependencies usage
This commit is contained in:
commit
f39cfa9358
@ -44,9 +44,9 @@ class Build
|
|||||||
def expand_reqs
|
def expand_reqs
|
||||||
formula.recursive_requirements do |dependent, req|
|
formula.recursive_requirements do |dependent, req|
|
||||||
build = effective_build_options_for(dependent)
|
build = effective_build_options_for(dependent)
|
||||||
if (req.optional? || req.recommended?) && build.without?(req)
|
if req.prune_from_option?(build)
|
||||||
Requirement.prune
|
Requirement.prune
|
||||||
elsif req.build? && dependent != formula
|
elsif req.prune_if_build_and_not_dependent?(dependent, formula)
|
||||||
Requirement.prune
|
Requirement.prune
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -55,9 +55,9 @@ class Build
|
|||||||
def expand_deps
|
def expand_deps
|
||||||
formula.recursive_dependencies do |dependent, dep|
|
formula.recursive_dependencies do |dependent, dep|
|
||||||
build = effective_build_options_for(dependent)
|
build = effective_build_options_for(dependent)
|
||||||
if (dep.optional? || dep.recommended?) && build.without?(dep)
|
if dep.prune_from_option?(build)
|
||||||
Dependency.prune
|
Dependency.prune
|
||||||
elsif dep.build? && dependent != formula
|
elsif dep.prune_if_build_and_not_dependent?(dependent, formula)
|
||||||
Dependency.prune
|
Dependency.prune
|
||||||
elsif dep.build?
|
elsif dep.build?
|
||||||
Dependency.keep_but_prune_recursive_deps
|
Dependency.keep_but_prune_recursive_deps
|
||||||
|
|||||||
@ -121,59 +121,14 @@ module Homebrew
|
|||||||
end
|
end
|
||||||
|
|
||||||
def deps_for_formula(f, recursive = false)
|
def deps_for_formula(f, recursive = false)
|
||||||
includes = []
|
includes, ignores = argv_includes_ignores(ARGV)
|
||||||
ignores = []
|
|
||||||
if ARGV.include?("--include-build")
|
|
||||||
includes << "build?"
|
|
||||||
else
|
|
||||||
ignores << "build?"
|
|
||||||
end
|
|
||||||
if ARGV.include?("--include-test")
|
|
||||||
includes << "test?"
|
|
||||||
else
|
|
||||||
ignores << "test?"
|
|
||||||
end
|
|
||||||
if ARGV.include?("--include-optional")
|
|
||||||
includes << "optional?"
|
|
||||||
else
|
|
||||||
ignores << "optional?"
|
|
||||||
end
|
|
||||||
ignores << "recommended?" if ARGV.include?("--skip-recommended")
|
|
||||||
|
|
||||||
if recursive
|
if recursive
|
||||||
deps = f.recursive_dependencies do |dependent, dep|
|
deps = recursive_includes(Dependency, f, includes, ignores)
|
||||||
if dep.recommended?
|
reqs = recursive_includes(Requirement, f, includes, ignores)
|
||||||
Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
|
|
||||||
elsif dep.test?
|
|
||||||
if includes.include?("test?")
|
|
||||||
Dependency.keep_but_prune_recursive_deps
|
|
||||||
else
|
else
|
||||||
Dependency.prune
|
deps = reject_ignores(f.deps, ignores, includes)
|
||||||
end
|
reqs = reject_ignores(f.requirements, ignores, includes)
|
||||||
elsif dep.optional?
|
|
||||||
Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
|
|
||||||
elsif dep.build?
|
|
||||||
Dependency.prune unless includes.include?("build?")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
reqs = f.recursive_requirements do |dependent, req|
|
|
||||||
if req.recommended?
|
|
||||||
Requirement.prune if ignores.include?("recommended?") || dependent.build.without?(req)
|
|
||||||
elsif req.test?
|
|
||||||
Requirement.prune unless includes.include?("test?")
|
|
||||||
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.none? { |include| dep.send(include) }
|
|
||||||
end
|
|
||||||
reqs = f.requirements.reject do |req|
|
|
||||||
ignores.any? { |ignore| req.send(ignore) } && includes.none? { |include| req.send(include) }
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
deps + reqs.to_a
|
deps + reqs.to_a
|
||||||
|
|||||||
@ -42,51 +42,14 @@ module Homebrew
|
|||||||
|
|
||||||
formulae = ARGV.include?("--installed") ? Formula.installed : Formula
|
formulae = ARGV.include?("--installed") ? Formula.installed : Formula
|
||||||
recursive = ARGV.flag? "--recursive"
|
recursive = ARGV.flag? "--recursive"
|
||||||
includes = []
|
|
||||||
ignores = []
|
includes, ignores = argv_includes_ignores(ARGV)
|
||||||
if ARGV.include? "--include-build"
|
|
||||||
includes << "build?"
|
|
||||||
else
|
|
||||||
ignores << "build?"
|
|
||||||
end
|
|
||||||
if ARGV.include? "--include-test"
|
|
||||||
includes << "test?"
|
|
||||||
else
|
|
||||||
ignores << "test?"
|
|
||||||
end
|
|
||||||
if ARGV.include? "--include-optional"
|
|
||||||
includes << "optional?"
|
|
||||||
else
|
|
||||||
ignores << "optional?"
|
|
||||||
end
|
|
||||||
ignores << "recommended?" if ARGV.include? "--skip-recommended"
|
|
||||||
|
|
||||||
uses = formulae.select do |f|
|
uses = formulae.select do |f|
|
||||||
used_formulae.all? do |ff|
|
used_formulae.all? do |ff|
|
||||||
begin
|
begin
|
||||||
if recursive
|
if recursive
|
||||||
deps = f.recursive_dependencies do |dependent, dep|
|
deps = recursive_includes(Dependency, f, includes, ignores)
|
||||||
if dep.recommended?
|
|
||||||
Dependency.prune if ignores.include?("recommended?") || dependent.build.without?(dep)
|
|
||||||
elsif dep.test?
|
|
||||||
if includes.include?("test?")
|
|
||||||
Dependency.keep_but_prune_recursive_deps
|
|
||||||
else
|
|
||||||
Dependency.prune
|
|
||||||
end
|
|
||||||
elsif dep.optional?
|
|
||||||
Dependency.prune if !includes.include?("optional?") && !dependent.build.with?(dep)
|
|
||||||
elsif dep.build?
|
|
||||||
Dependency.prune unless includes.include?("build?")
|
|
||||||
end
|
|
||||||
|
|
||||||
# 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
|
|
||||||
|
|
||||||
dep_formulae = deps.flat_map do |dep|
|
dep_formulae = deps.flat_map do |dep|
|
||||||
begin
|
begin
|
||||||
dep.to_formula
|
dep.to_formula
|
||||||
@ -103,7 +66,7 @@ module Homebrew
|
|||||||
if req.recommended?
|
if req.recommended?
|
||||||
ignores.include?("recommended?") || dependent.build.without?(req)
|
ignores.include?("recommended?") || dependent.build.without?(req)
|
||||||
elsif req.test?
|
elsif req.test?
|
||||||
Requirement.prune unless includes.include?("test?")
|
!includes.include?("test?")
|
||||||
elsif req.optional?
|
elsif req.optional?
|
||||||
!includes.include?("optional?") && !dependent.build.with?(req)
|
!includes.include?("optional?") && !dependent.build.with?(req)
|
||||||
elsif req.build?
|
elsif req.build?
|
||||||
@ -113,13 +76,10 @@ module Homebrew
|
|||||||
|
|
||||||
reqs = reqs_by_formula.map(&:last)
|
reqs = reqs_by_formula.map(&:last)
|
||||||
else
|
else
|
||||||
deps = f.deps.reject do |dep|
|
deps = reject_ignores(f.deps, ignores, includes)
|
||||||
ignores.any? { |ignore| dep.send(ignore) } && includes.none? { |include| dep.send(include) }
|
reqs = reject_ignores(f.requirements, ignores, includes)
|
||||||
end
|
|
||||||
reqs = f.requirements.reject do |req|
|
|
||||||
ignores.any? { |ignore| req.send(ignore) } && includes.none? { |include| req.send(include) }
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
next true if deps.any? do |dep|
|
next true if deps.any? do |dep|
|
||||||
begin
|
begin
|
||||||
dep.to_formula.full_name == ff.full_name
|
dep.to_formula.full_name == ff.full_name
|
||||||
|
|||||||
@ -32,4 +32,15 @@ module Dependable
|
|||||||
def options
|
def options
|
||||||
Options.create(option_tags)
|
Options.create(option_tags)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def prune_from_option?(build)
|
||||||
|
return if !optional? && !recommended?
|
||||||
|
build.without?(self)
|
||||||
|
end
|
||||||
|
|
||||||
|
def prune_if_build_and_not_dependent?(dependent, formula = nil)
|
||||||
|
return false unless build?
|
||||||
|
return dependent.installed? unless formula
|
||||||
|
dependent != formula
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -52,3 +52,81 @@ class Requirements < DelegateClass(Set)
|
|||||||
"#<#{self.class.name}: {#{to_a.join(", ")}}>"
|
"#<#{self.class.name}: {#{to_a.join(", ")}}>"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
module Homebrew
|
||||||
|
module_function
|
||||||
|
|
||||||
|
def argv_includes_ignores(argv)
|
||||||
|
includes = []
|
||||||
|
ignores = []
|
||||||
|
|
||||||
|
if argv.include? "--include-build"
|
||||||
|
includes << "build?"
|
||||||
|
else
|
||||||
|
ignores << "build?"
|
||||||
|
end
|
||||||
|
|
||||||
|
if argv.include? "--include-test"
|
||||||
|
includes << "test?"
|
||||||
|
else
|
||||||
|
ignores << "test?"
|
||||||
|
end
|
||||||
|
|
||||||
|
if argv.include? "--include-optional"
|
||||||
|
includes << "optional?"
|
||||||
|
else
|
||||||
|
ignores << "optional?"
|
||||||
|
end
|
||||||
|
|
||||||
|
ignores << "recommended?" if ARGV.include? "--skip-recommended"
|
||||||
|
|
||||||
|
[includes, ignores]
|
||||||
|
end
|
||||||
|
|
||||||
|
def recursive_includes(klass, formula, includes, ignores)
|
||||||
|
type = if klass == Dependency
|
||||||
|
:dependencies
|
||||||
|
elsif klass == Requirement
|
||||||
|
:requirements
|
||||||
|
else
|
||||||
|
raise ArgumentError, "Invalid class argument: #{klass}"
|
||||||
|
end
|
||||||
|
|
||||||
|
formula.send("recursive_#{type}") do |dependent, dep|
|
||||||
|
if dep.recommended?
|
||||||
|
if ignores.include?("recommended?") || dependent.build.without?(dep)
|
||||||
|
klass.prune
|
||||||
|
end
|
||||||
|
elsif dep.test?
|
||||||
|
if includes.include?("test?")
|
||||||
|
if type == :dependencies
|
||||||
|
Dependency.keep_but_prune_recursive_deps
|
||||||
|
end
|
||||||
|
else
|
||||||
|
klass.prune
|
||||||
|
end
|
||||||
|
elsif dep.optional?
|
||||||
|
if !includes.include?("optional?") && !dependent.build.with?(dep)
|
||||||
|
klass.prune
|
||||||
|
end
|
||||||
|
elsif dep.build?
|
||||||
|
klass.prune unless includes.include?("build?")
|
||||||
|
end
|
||||||
|
|
||||||
|
# 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 type == :dependencies &&
|
||||||
|
dep.is_a?(TapDependency) &&
|
||||||
|
!dep.tap.installed?
|
||||||
|
Dependency.keep_but_prune_recursive_deps
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def reject_ignores(dependables, ignores, includes)
|
||||||
|
dependables.reject do |dep|
|
||||||
|
next false unless ignores.any? { |ignore| dep.send(ignore) }
|
||||||
|
includes.none? { |include| dep.send(include) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|||||||
@ -439,7 +439,7 @@ class FormulaInstaller
|
|||||||
build = effective_build_options_for(dependent)
|
build = effective_build_options_for(dependent)
|
||||||
install_bottle_for_dependent = install_bottle_for?(dependent, build)
|
install_bottle_for_dependent = install_bottle_for?(dependent, build)
|
||||||
|
|
||||||
if (req.optional? || req.recommended?) && build.without?(req)
|
if req.prune_from_option?(build)
|
||||||
Requirement.prune
|
Requirement.prune
|
||||||
elsif req.satisfied?
|
elsif req.satisfied?
|
||||||
Requirement.prune
|
Requirement.prune
|
||||||
@ -469,13 +469,13 @@ class FormulaInstaller
|
|||||||
inherited_options.fetch(dependent.name, []),
|
inherited_options.fetch(dependent.name, []),
|
||||||
)
|
)
|
||||||
|
|
||||||
if (dep.optional? || dep.recommended?) && build.without?(dep)
|
if dep.prune_from_option?(build)
|
||||||
Dependency.prune
|
Dependency.prune
|
||||||
elsif include_test? && dep.test? && !dep.installed?
|
elsif include_test? && dep.test? && !dep.installed?
|
||||||
Dependency.keep_but_prune_recursive_deps
|
Dependency.keep_but_prune_recursive_deps
|
||||||
elsif dep.build? && install_bottle_for?(dependent, build)
|
elsif dep.build? && install_bottle_for?(dependent, build)
|
||||||
Dependency.prune
|
Dependency.prune
|
||||||
elsif dep.build? && dependent.installed?
|
elsif dep.prune_if_build_and_not_dependent?(dependent)
|
||||||
Dependency.prune
|
Dependency.prune
|
||||||
elsif dep.satisfied?(inherited_options[dep.name])
|
elsif dep.satisfied?(inherited_options[dep.name])
|
||||||
Dependency.skip
|
Dependency.skip
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user