[rubygems/rubygems] Simplify selecting specs with force_ruby_platform
set
https://github.com/rubygems/rubygems/commit/5f90a43635 Co-authored-by: Martin Emde <martin.emde@gmail.com>
This commit is contained in:
parent
a131ea39b7
commit
9f67118d7b
@ -48,6 +48,13 @@ module Bundler
|
||||
end
|
||||
module_function :select_best_platform_match
|
||||
|
||||
def force_ruby_platform(specs)
|
||||
matching = specs.select {|spec| spec.match_platform(Gem::Platform::RUBY) && spec.force_ruby_platform! }
|
||||
|
||||
sort_best_platform_match(matching, Gem::Platform::RUBY)
|
||||
end
|
||||
module_function :force_ruby_platform
|
||||
|
||||
def sort_best_platform_match(matching, platform)
|
||||
exact = matching.select {|spec| spec.platform == platform }
|
||||
return exact if exact.any?
|
||||
|
@ -133,6 +133,10 @@ module Bundler
|
||||
" #{source.revision[0..6]}"
|
||||
end
|
||||
|
||||
def force_ruby_platform!
|
||||
@force_ruby_platform = true
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def use_exact_resolved_specifications?
|
||||
|
@ -200,9 +200,11 @@ module Bundler
|
||||
|
||||
def specs_for_dependency(dep, platform)
|
||||
specs_for_name = lookup[dep.name]
|
||||
target_platform = dep.force_ruby_platform ? Gem::Platform::RUBY : (platform || Bundler.local_platform)
|
||||
matching_specs = GemHelpers.select_best_platform_match(specs_for_name, target_platform)
|
||||
matching_specs.each {|s| s.force_ruby_platform = true } if dep.force_ruby_platform
|
||||
matching_specs = if dep.force_ruby_platform
|
||||
GemHelpers.force_ruby_platform(specs_for_name)
|
||||
else
|
||||
GemHelpers.select_best_platform_match(specs_for_name, platform || Bundler.local_platform)
|
||||
end
|
||||
matching_specs.map!(&:materialize_for_installation).compact! if platform.nil?
|
||||
matching_specs
|
||||
end
|
||||
|
Loading…
x
Reference in New Issue
Block a user