Merge pull request #1862 from alyssais/uses_include_optional
uses: fix recursive requirement resolution
This commit is contained in:
commit
1497dfaced
@ -58,15 +58,29 @@ module Homebrew
|
|||||||
Dependency.prune unless includes.include?("build?")
|
Dependency.prune unless includes.include?("build?")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
reqs = f.recursive_requirements do |dependent, req|
|
|
||||||
|
dep_formulae = deps.map do |dep|
|
||||||
|
begin
|
||||||
|
dep.to_formula
|
||||||
|
rescue
|
||||||
|
end
|
||||||
|
end.compact
|
||||||
|
|
||||||
|
reqs_by_formula = ([f] + dep_formulae).flat_map do |formula|
|
||||||
|
formula.requirements.map { |req| [formula, req] }
|
||||||
|
end
|
||||||
|
|
||||||
|
reqs_by_formula.reject! do |dependent, req|
|
||||||
if req.recommended?
|
if req.recommended?
|
||||||
Requirement.prune if ignores.include?("recommended?") || dependent.build.without?(req)
|
ignores.include?("recommended?") || dependent.build.without?(req)
|
||||||
elsif req.optional?
|
elsif req.optional?
|
||||||
Requirement.prune if !includes.include?("optional?") && !dependent.build.with?(req)
|
!includes.include?("optional?") && !dependent.build.with?(req)
|
||||||
elsif req.build?
|
elsif req.build?
|
||||||
Requirement.prune unless includes.include?("build?")
|
!includes.include?("build?")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
reqs = reqs_by_formula.map(&:last)
|
||||||
else
|
else
|
||||||
deps = f.deps.reject do |dep|
|
deps = f.deps.reject do |dep|
|
||||||
ignores.any? { |ignore| dep.send(ignore) } && !includes.any? { |include| dep.send(include) }
|
ignores.any? { |ignore| dep.send(ignore) } && !includes.any? { |include| dep.send(include) }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user