From cd57c1294de14a7c6210fd111f40f1ce1fac3288 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20Rodr=C3=ADguez?= Date: Thu, 27 Jun 2024 12:36:47 +0200 Subject: [rubygems/rubygems] Only remove current platform when added right before resolution If it has been explicitly added by `bundle lock --add-platform`, we don't want to remove it. https://github.com/rubygems/rubygems/commit/09cf921dd6 --- lib/bundler/definition.rb | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'lib') diff --git a/lib/bundler/definition.rb b/lib/bundler/definition.rb index 7ae9a8f8d2..d332fceb54 100644 --- a/lib/bundler/definition.rb +++ b/lib/bundler/definition.rb @@ -621,14 +621,19 @@ module Bundler end def start_resolution - @platforms |= [local_platform] if @most_specific_non_local_locked_ruby_platform + local_platform_needed_for_resolvability = @most_specific_non_local_locked_ruby_platform && !@platforms.include?(local_platform) + @platforms << local_platform if local_platform_needed_for_resolvability result = SpecSet.new(resolver.start) @resolved_bundler_version = result.find {|spec| spec.name == "bundler" }&.version if @most_specific_non_local_locked_ruby_platform - @platforms.delete(result.incomplete_for_platform?(dependencies, @most_specific_non_local_locked_ruby_platform) ? @most_specific_non_local_locked_ruby_platform : local_platform) + if result.incomplete_for_platform?(dependencies, @most_specific_non_local_locked_ruby_platform) + @platforms.delete(@most_specific_non_local_locked_ruby_platform) + elsif local_platform_needed_for_resolvability + @platforms.delete(local_platform) + end end @platforms = result.add_extra_platforms!(platforms) if should_add_extra_platforms? -- cgit v1.2.3