rubygems-update 3.2.33 → 3.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (139) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +77 -4
  3. data/CONTRIBUTING.md +40 -10
  4. data/Manifest.txt +7 -5
  5. data/POLICIES.md +22 -8
  6. data/README.md +9 -7
  7. data/UPGRADING.md +5 -81
  8. data/bin/gem +1 -6
  9. data/bundler/CHANGELOG.md +47 -0
  10. data/bundler/exe/bundle +7 -8
  11. data/bundler/lib/bundler/.document +1 -0
  12. data/bundler/lib/bundler/build_metadata.rb +2 -2
  13. data/bundler/lib/bundler/cli/gem.rb +1 -1
  14. data/bundler/lib/bundler/cli/install.rb +2 -3
  15. data/bundler/lib/bundler/cli.rb +5 -0
  16. data/bundler/lib/bundler/definition.rb +14 -5
  17. data/bundler/lib/bundler/dependency.rb +5 -7
  18. data/bundler/lib/bundler/dsl.rb +0 -27
  19. data/bundler/lib/bundler/endpoint_specification.rb +0 -8
  20. data/bundler/lib/bundler/fetcher/compact_index.rb +9 -4
  21. data/bundler/lib/bundler/fetcher.rb +2 -5
  22. data/bundler/lib/bundler/injector.rb +10 -1
  23. data/bundler/lib/bundler/installer/gem_installer.rb +1 -6
  24. data/bundler/lib/bundler/installer.rb +1 -4
  25. data/bundler/lib/bundler/lockfile_parser.rb +10 -13
  26. data/bundler/lib/bundler/man/bundle-add.1 +9 -1
  27. data/bundler/lib/bundler/man/bundle-add.1.ronn +7 -1
  28. data/bundler/lib/bundler/man/bundle-config.1 +2 -2
  29. data/bundler/lib/bundler/man/bundle-config.1.ronn +3 -3
  30. data/bundler/lib/bundler/man/bundle-install.1 +1 -1
  31. data/bundler/lib/bundler/man/bundle-install.1.ronn +2 -2
  32. data/bundler/lib/bundler/man/bundle-update.1 +1 -1
  33. data/bundler/lib/bundler/man/bundle-update.1.ronn +2 -1
  34. data/bundler/lib/bundler/man/gemfile.5 +1 -1
  35. data/bundler/lib/bundler/man/gemfile.5.ronn +1 -1
  36. data/bundler/lib/bundler/plugin/installer.rb +1 -1
  37. data/bundler/lib/bundler/process_lock.rb +1 -1
  38. data/bundler/lib/bundler/psyched_yaml.rb +1 -13
  39. data/bundler/lib/bundler/resolver.rb +34 -29
  40. data/bundler/lib/bundler/rubygems_ext.rb +2 -0
  41. data/bundler/lib/bundler/rubygems_gem_installer.rb +1 -1
  42. data/bundler/lib/bundler/rubygems_integration.rb +11 -48
  43. data/bundler/lib/bundler/self_manager.rb +76 -0
  44. data/bundler/lib/bundler/settings.rb +1 -0
  45. data/bundler/lib/bundler/shared_helpers.rb +2 -9
  46. data/bundler/lib/bundler/source/metadata.rb +1 -1
  47. data/bundler/lib/bundler/templates/Executable.bundler +1 -1
  48. data/bundler/lib/bundler/templates/Gemfile +0 -2
  49. data/bundler/lib/bundler/templates/gems.rb +0 -3
  50. data/bundler/lib/bundler/templates/newgem/Rakefile.tt +10 -1
  51. data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +1 -1
  52. data/bundler/lib/bundler/templates/newgem/test/minitest/{newgem_test.rb.tt → test_newgem.rb.tt} +1 -1
  53. data/bundler/lib/bundler/ui/shell.rb +1 -1
  54. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +6 -6
  55. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +5 -3
  56. data/bundler/lib/bundler/vendor/thor/lib/thor/actions.rb +6 -2
  57. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +6 -0
  58. data/bundler/lib/bundler/vendor/thor/lib/thor/error.rb +9 -4
  59. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/options.rb +19 -1
  60. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +22 -4
  61. data/bundler/lib/bundler/vendor/thor/lib/thor/shell.rb +1 -1
  62. data/bundler/lib/bundler/vendor/thor/lib/thor/util.rb +1 -1
  63. data/bundler/lib/bundler/vendor/uri/lib/uri/common.rb +17 -80
  64. data/bundler/lib/bundler/vendor/uri/lib/uri/ftp.rb +0 -1
  65. data/bundler/lib/bundler/vendor/uri/lib/uri/generic.rb +5 -6
  66. data/bundler/lib/bundler/vendor/uri/lib/uri/http.rb +0 -1
  67. data/bundler/lib/bundler/vendor/uri/lib/uri/https.rb +0 -1
  68. data/bundler/lib/bundler/vendor/uri/lib/uri/ldap.rb +1 -1
  69. data/bundler/lib/bundler/vendor/uri/lib/uri/mailto.rb +0 -1
  70. data/bundler/lib/bundler/vendor/uri/lib/uri/rfc2396_parser.rb +1 -14
  71. data/bundler/lib/bundler/vendor/uri/lib/uri/rfc3986_parser.rb +1 -12
  72. data/bundler/lib/bundler/vendor/uri/lib/uri/version.rb +1 -1
  73. data/bundler/lib/bundler/vendor/uri/lib/uri/ws.rb +84 -0
  74. data/bundler/lib/bundler/vendor/uri/lib/uri/wss.rb +22 -0
  75. data/bundler/lib/bundler/vendor/uri/lib/uri.rb +0 -1
  76. data/bundler/lib/bundler/version.rb +1 -1
  77. data/bundler/lib/bundler.rb +9 -3
  78. data/hide_lib_for_update/note.txt +0 -4
  79. data/lib/rubygems/bundler_version_finder.rb +10 -42
  80. data/lib/rubygems/command_manager.rb +1 -1
  81. data/lib/rubygems/commands/install_command.rb +5 -2
  82. data/lib/rubygems/commands/server_command.rb +14 -77
  83. data/lib/rubygems/commands/setup_command.rb +4 -16
  84. data/lib/rubygems/commands/update_command.rb +9 -4
  85. data/lib/rubygems/defaults.rb +2 -20
  86. data/lib/rubygems/dependency.rb +7 -7
  87. data/lib/rubygems/deprecate.rb +53 -6
  88. data/lib/rubygems/errors.rb +0 -3
  89. data/lib/rubygems/exceptions.rb +30 -1
  90. data/lib/rubygems/ext/builder.rb +5 -3
  91. data/lib/rubygems/install_update_options.rb +11 -2
  92. data/lib/rubygems/installer.rb +11 -1
  93. data/lib/rubygems/name_tuple.rb +2 -3
  94. data/lib/rubygems/path_support.rb +1 -6
  95. data/lib/rubygems/platform.rb +4 -0
  96. data/lib/rubygems/remote_fetcher.rb +1 -1
  97. data/lib/rubygems/requirement.rb +1 -1
  98. data/lib/rubygems/resolver/installer_set.rb +1 -1
  99. data/lib/rubygems/security/policy.rb +1 -3
  100. data/lib/rubygems/security.rb +14 -7
  101. data/lib/rubygems/source.rb +3 -1
  102. data/lib/rubygems/spec_fetcher.rb +1 -1
  103. data/lib/rubygems/specification.rb +12 -16
  104. data/lib/rubygems/stub_specification.rb +1 -1
  105. data/lib/rubygems/text.rb +21 -20
  106. data/lib/rubygems/uninstaller.rb +4 -1
  107. data/lib/rubygems/unknown_command_spell_checker.rb +21 -0
  108. data/lib/rubygems/version.rb +2 -0
  109. data/lib/rubygems.rb +54 -55
  110. data/rubygems-update.gemspec +1 -1
  111. data/setup.rb +1 -6
  112. data/test/rubygems/helper.rb +20 -6
  113. data/test/rubygems/test_config.rb +2 -2
  114. data/test/rubygems/test_exit.rb +11 -0
  115. data/test/rubygems/test_gem.rb +46 -76
  116. data/test/rubygems/test_gem_bundler_version_finder.rb +22 -43
  117. data/test/rubygems/test_gem_command_manager.rb +16 -2
  118. data/test/rubygems/test_gem_commands_install_command.rb +33 -0
  119. data/test/rubygems/test_gem_commands_open_command.rb +1 -1
  120. data/test/rubygems/test_gem_commands_server_command.rb +4 -46
  121. data/test/rubygems/test_gem_commands_update_command.rb +2 -2
  122. data/test/rubygems/test_gem_dependency.rb +4 -8
  123. data/test/rubygems/test_gem_installer.rb +0 -27
  124. data/test/rubygems/test_gem_path_support.rb +2 -6
  125. data/test/rubygems/test_gem_remote_fetcher.rb +15 -0
  126. data/test/rubygems/test_gem_requirement.rb +0 -1
  127. data/test/rubygems/test_gem_security.rb +1 -1
  128. data/test/rubygems/test_gem_specification.rb +16 -25
  129. data/test/rubygems/test_gem_stream_ui.rb +1 -1
  130. data/test/rubygems/test_gem_text.rb +6 -0
  131. data/test/rubygems/test_kernel.rb +1 -13
  132. data/test/rubygems/test_project_sanity.rb +1 -1
  133. data/test/rubygems/test_require.rb +0 -32
  134. data/test/rubygems/test_rubygems.rb +23 -0
  135. metadata +10 -8
  136. data/bundler/lib/bundler/gemdeps.rb +0 -29
  137. data/lib/rubygems/server.rb +0 -882
  138. data/test/rubygems/bogussources.rb +0 -9
  139. data/test/rubygems/test_gem_server.rb +0 -608
@@ -12,8 +12,6 @@ class Gem::Commands::SetupCommand < Gem::Command
12
12
  ENV_PATHS = %w[/usr/bin/env /bin/env].freeze
13
13
 
14
14
  def initialize
15
- require 'tmpdir'
16
-
17
15
  super 'setup', 'Install RubyGems',
18
16
  :format_executable => false, :document => %w[ri],
19
17
  :force => true,
@@ -253,6 +251,8 @@ By default, this RubyGems will install gem as:
253
251
  Dir.chdir path do
254
252
  bin_file = "gem"
255
253
 
254
+ require 'tmpdir'
255
+
256
256
  dest_file = target_bin_path(bin_dir, bin_file)
257
257
  bin_tmp_file = File.join Dir.tmpdir, "#{bin_file}.#{$$}"
258
258
 
@@ -465,20 +465,8 @@ By default, this RubyGems will install gem as:
465
465
  lib_dir = RbConfig::CONFIG[site_or_vendor]
466
466
  bin_dir = RbConfig::CONFIG['bindir']
467
467
  else
468
- # Apple installed RubyGems into libdir, and RubyGems <= 1.1.0 gets
469
- # confused about installation location, so switch back to
470
- # sitelibdir/vendorlibdir.
471
- if defined?(APPLE_GEM_HOME) and
472
- # just in case Apple and RubyGems don't get this patched up proper.
473
- (prefix == RbConfig::CONFIG['libdir'] or
474
- # this one is important
475
- prefix == File.join(RbConfig::CONFIG['libdir'], 'ruby'))
476
- lib_dir = RbConfig::CONFIG[site_or_vendor]
477
- bin_dir = RbConfig::CONFIG['bindir']
478
- else
479
- lib_dir = File.join prefix, 'lib'
480
- bin_dir = File.join prefix, 'bin'
481
- end
468
+ lib_dir = File.join prefix, 'lib'
469
+ bin_dir = File.join prefix, 'bin'
482
470
  end
483
471
 
484
472
  [prepend_destdir_if_present(lib_dir), prepend_destdir_if_present(bin_dir)]
@@ -19,9 +19,13 @@ class Gem::Commands::UpdateCommand < Gem::Command
19
19
  attr_reader :updated # :nodoc:
20
20
 
21
21
  def initialize
22
- super 'update', 'Update installed gems to the latest version',
23
- :document => %w[rdoc ri],
24
- :force => false
22
+ options = {
23
+ :force => false,
24
+ }
25
+
26
+ options.merge!(install_update_options)
27
+
28
+ super 'update', 'Update installed gems to the latest version', options
25
29
 
26
30
  add_install_update_options
27
31
 
@@ -51,7 +55,8 @@ class Gem::Commands::UpdateCommand < Gem::Command
51
55
  end
52
56
 
53
57
  def defaults_str # :nodoc:
54
- "--document --no-force --install-dir #{Gem.dir}"
58
+ "--no-force --install-dir #{Gem.dir}\n" +
59
+ install_update_defaults_str
55
60
  end
56
61
 
57
62
  def description # :nodoc:
@@ -34,21 +34,7 @@ module Gem
34
34
  # specified in the environment
35
35
 
36
36
  def self.default_dir
37
- path = if defined? RUBY_FRAMEWORK_VERSION
38
- [
39
- File.dirname(RbConfig::CONFIG['sitedir']),
40
- 'Gems',
41
- RbConfig::CONFIG['ruby_version'],
42
- ]
43
- else
44
- [
45
- RbConfig::CONFIG['rubylibprefix'],
46
- 'gems',
47
- RbConfig::CONFIG['ruby_version'],
48
- ]
49
- end
50
-
51
- @default_dir ||= File.join(*path)
37
+ @default_dir ||= File.join(RbConfig::CONFIG['rubylibprefix'], 'gems', RbConfig::CONFIG['ruby_version'])
52
38
  end
53
39
 
54
40
  ##
@@ -197,11 +183,7 @@ module Gem
197
183
  # The default directory for binaries
198
184
 
199
185
  def self.default_bindir
200
- if defined? RUBY_FRAMEWORK_VERSION # mac framework support
201
- '/usr/local/bin'
202
- else # generic install
203
- RbConfig::CONFIG['bindir']
204
- end
186
+ RbConfig::CONFIG['bindir']
205
187
  end
206
188
 
207
189
  def self.ruby_engine
@@ -277,7 +277,7 @@ class Gem::Dependency
277
277
  requirement.satisfied_by?(spec.version) && env_req.satisfied_by?(spec.version)
278
278
  end.map(&:to_spec)
279
279
 
280
- Gem::BundlerVersionFinder.filter!(matches) if filters_bundler?
280
+ Gem::BundlerVersionFinder.prioritize!(matches) if prioritizes_bundler?
281
281
 
282
282
  if platform_only
283
283
  matches.reject! do |spec|
@@ -295,7 +295,7 @@ class Gem::Dependency
295
295
  @requirement.specific?
296
296
  end
297
297
 
298
- def filters_bundler?
298
+ def prioritizes_bundler?
299
299
  name == "bundler".freeze && !specific?
300
300
  end
301
301
 
@@ -325,11 +325,11 @@ class Gem::Dependency
325
325
  active = matches.find {|spec| spec.activated? }
326
326
  return active if active
327
327
 
328
- return matches.first if prerelease?
329
-
330
- # Move prereleases to the end of the list for >= 0 requirements
331
- pre, matches = matches.partition {|spec| spec.version.prerelease? }
332
- matches += pre if requirement == Gem::Requirement.default
328
+ unless prerelease?
329
+ # Move prereleases to the end of the list for >= 0 requirements
330
+ pre, matches = matches.partition {|spec| spec.version.prerelease? }
331
+ matches += pre if requirement == Gem::Requirement.default
332
+ end
333
333
 
334
334
  matches.first
335
335
  end
@@ -1,23 +1,70 @@
1
1
  # frozen_string_literal: true
2
2
  ##
3
- # Provides a single method +deprecate+ to be used to declare when
4
- # something is going away.
3
+ # Provides 3 methods for declaring when something is going away.
4
+ #
5
+ # +deprecate(name, repl, year, month)+:
6
+ # Indicate something may be removed on/after a certain date.
7
+ #
8
+ # +rubygems_deprecate(name, replacement=:none)+:
9
+ # Indicate something will be removed in the next major RubyGems version,
10
+ # and (optionally) a replacement for it.
11
+ #
12
+ # +rubygems_deprecate_command+:
13
+ # Indicate a RubyGems command (in +lib/rubygems/commands/*.rb+) will be
14
+ # removed in the next RubyGems version.
15
+ #
16
+ # Also provides +skip_during+ for temporarily turning off deprecation warnings.
17
+ # This is intended to be used in the test suite, so deprecation warnings
18
+ # don't cause test failures if you need to make sure stderr is otherwise empty.
19
+ #
20
+ #
21
+ # Example usage of +deprecate+ and +rubygems_deprecate+:
5
22
  #
6
23
  # class Legacy
7
- # def self.klass_method
24
+ # def self.some_class_method
8
25
  # # ...
9
26
  # end
10
27
  #
11
- # def instance_method
28
+ # def some_instance_method
29
+ # # ...
30
+ # end
31
+ #
32
+ # def some_old_method
12
33
  # # ...
13
34
  # end
14
35
  #
15
36
  # extend Gem::Deprecate
16
- # deprecate :instance_method, "X.z", 2011, 4
37
+ # deprecate :some_instance_method, "X.z", 2011, 4
38
+ # rubygems_deprecate :some_old_method, "Modern#some_new_method"
17
39
  #
18
40
  # class << self
19
41
  # extend Gem::Deprecate
20
- # deprecate :klass_method, :none, 2011, 4
42
+ # deprecate :some_class_method, :none, 2011, 4
43
+ # end
44
+ # end
45
+ #
46
+ #
47
+ # Example usage of +rubygems_deprecate_command+:
48
+ #
49
+ # class Gem::Commands::QueryCommand < Gem::Command
50
+ # extend Gem::Deprecate
51
+ # rubygems_deprecate_command
52
+ #
53
+ # # ...
54
+ # end
55
+ #
56
+ #
57
+ # Example usage of +skip_during+:
58
+ #
59
+ # class TestSomething < Gem::Testcase
60
+ # def test_some_thing_with_deprecations
61
+ # Gem::Deprecate.skip_during do
62
+ # actual_stdout, actual_stderr = capture_output do
63
+ # Gem.something_deprecated
64
+ # end
65
+ # assert_empty actual_stdout
66
+ # assert_equal(expected, actual_stderr)
67
+ # end
21
68
  # end
22
69
  # end
23
70
 
@@ -59,9 +59,6 @@ module Gem
59
59
  private
60
60
 
61
61
  def build_message
62
- if name == "bundler" && message = Gem::BundlerVersionFinder.missing_version_message
63
- return message
64
- end
65
62
  names = specs.map(&:full_name)
66
63
  "Could not find '#{name}' (#{requirement}) - did find: [#{names.join ','}]\n"
67
64
  end
@@ -1,6 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require_relative 'deprecate'
4
+ require_relative 'unknown_command_spell_checker'
4
5
 
5
6
  ##
6
7
  # Base exception class for RubyGems. All exception raised by RubyGems are a
@@ -9,6 +10,34 @@ class Gem::Exception < RuntimeError; end
9
10
 
10
11
  class Gem::CommandLineError < Gem::Exception; end
11
12
 
13
+ class Gem::UnknownCommandError < Gem::Exception
14
+ attr_reader :unknown_command
15
+
16
+ def initialize(unknown_command)
17
+ self.class.attach_correctable
18
+
19
+ @unknown_command = unknown_command
20
+ super("Unknown command #{unknown_command}")
21
+ end
22
+
23
+ def self.attach_correctable
24
+ return if defined?(@attached)
25
+
26
+ if defined?(DidYouMean::SPELL_CHECKERS) && defined?(DidYouMean::Correctable)
27
+ if DidYouMean.respond_to?(:correct_error)
28
+ DidYouMean.correct_error(Gem::UnknownCommandError, Gem::UnknownCommandSpellChecker)
29
+ else
30
+ DidYouMean::SPELL_CHECKERS['Gem::UnknownCommandError'] =
31
+ Gem::UnknownCommandSpellChecker
32
+
33
+ prepend DidYouMean::Correctable
34
+ end
35
+ end
36
+
37
+ @attached = true
38
+ end
39
+ end
40
+
12
41
  class Gem::DependencyError < Gem::Exception; end
13
42
 
14
43
  class Gem::DependencyRemovalException < Gem::Exception; end
@@ -200,7 +229,7 @@ class Gem::SystemExitException < SystemExit
200
229
  def initialize(exit_code)
201
230
  @exit_code = exit_code
202
231
 
203
- super "Exiting RubyGems with exit_code #{exit_code}"
232
+ super exit_code, "Exiting RubyGems with exit_code #{exit_code}"
204
233
  end
205
234
  end
206
235
 
@@ -64,14 +64,16 @@ class Gem::Ext::Builder
64
64
  require "open3"
65
65
  # Set $SOURCE_DATE_EPOCH for the subprocess.
66
66
  env = {'SOURCE_DATE_EPOCH' => Gem.source_date_epoch_string}
67
- output, status = Open3.capture2e(env, *command, :chdir => dir)
67
+ output, status = begin
68
+ Open3.capture2e(env, *command, :chdir => dir)
69
+ rescue => error
70
+ raise Gem::InstallError, "#{command_name || class_name} failed#{error.message}"
71
+ end
68
72
  if verbose
69
73
  puts output
70
74
  else
71
75
  results << output
72
76
  end
73
- rescue => error
74
- raise Gem::InstallError, "#{command_name || class_name} failed#{error.message}"
75
77
  ensure
76
78
  ENV['RUBYGEMS_GEMDEPS'] = rubygems_gemdeps
77
79
  end
@@ -181,10 +181,19 @@ module Gem::InstallUpdateOptions
181
181
  end
182
182
 
183
183
  ##
184
- # Default options for the gem install command.
184
+ # Default options for the gem install and update commands.
185
+
186
+ def install_update_options
187
+ {
188
+ :document => %w[ri],
189
+ }
190
+ end
191
+
192
+ ##
193
+ # Default description for the gem install and update commands.
185
194
 
186
195
  def install_update_defaults_str
187
- '--document=rdoc,ri --wrappers'
196
+ '--document=ri'
188
197
  end
189
198
 
190
199
  end
@@ -768,7 +768,7 @@ str = ARGV.first
768
768
  if str
769
769
  str = str.b[/\\A_(.*)_\\z/, 1]
770
770
  if str and Gem::Version.correct?(str)
771
- version = str
771
+ #{explicit_version_requirement(spec.name)}
772
772
  ARGV.shift
773
773
  end
774
774
  end
@@ -791,6 +791,16 @@ Gem.use_gemdeps
791
791
  TEXT
792
792
  end
793
793
 
794
+ def explicit_version_requirement(name)
795
+ code = "version = str"
796
+ return code unless name == "bundler"
797
+
798
+ code += <<-TEXT
799
+
800
+ ENV['BUNDLER_VERSION'] = str
801
+ TEXT
802
+ end
803
+
794
804
  ##
795
805
  # return the stub script text used to launch the true Ruby script
796
806
 
@@ -89,9 +89,8 @@ class Gem::NameTuple
89
89
  alias to_s inspect # :nodoc:
90
90
 
91
91
  def <=>(other)
92
- [@name, @version, @platform == Gem::Platform::RUBY ? -1 : 1] <=>
93
- [other.name, other.version,
94
- other.platform == Gem::Platform::RUBY ? -1 : 1]
92
+ [@name, @version, Gem::Platform.sort_priority(@platform)] <=>
93
+ [other.name, other.version, Gem::Platform.sort_priority(other.platform)]
95
94
  end
96
95
 
97
96
  include Comparable
@@ -72,12 +72,7 @@ class Gem::PathSupport
72
72
 
73
73
  # Return the default Gem path
74
74
  def default_path
75
- gem_path = Gem.default_path + [@home]
76
-
77
- if defined?(APPLE_GEM_HOME)
78
- gem_path << APPLE_GEM_HOME
79
- end
80
- gem_path
75
+ Gem.default_path + [@home]
81
76
  end
82
77
 
83
78
  def expand(path)
@@ -40,6 +40,10 @@ class Gem::Platform
40
40
  match_platforms?(platform, Gem.platforms)
41
41
  end
42
42
 
43
+ def self.sort_priority(platform)
44
+ platform == Gem::Platform::RUBY ? -1 : 1
45
+ end
46
+
43
47
  def self.installable?(spec)
44
48
  if spec.respond_to? :installable_platform?
45
49
  spec.installable_platform?
@@ -284,7 +284,7 @@ class Gem::RemoteFetcher
284
284
 
285
285
  data = fetch_path(uri, mtime)
286
286
 
287
- if data == nil # indicates the server returned 304 Not Modified
287
+ if data.nil? # indicates the server returned 304 Not Modified
288
288
  return Gem.read_binary(path)
289
289
  end
290
290
 
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
- require_relative "deprecate"
2
+ require_relative "version"
3
3
 
4
4
  ##
5
5
  # A Requirement is a set of one or more version restrictions. It supports a
@@ -71,7 +71,7 @@ class Gem::Resolver::InstallerSet < Gem::Resolver::Set
71
71
  end
72
72
 
73
73
  found = found.sort_by do |s|
74
- [s.version, s.platform == Gem::Platform::RUBY ? -1 : 1]
74
+ [s.version, Gem::Platform.sort_priority(s.platform)]
75
75
  end
76
76
 
77
77
  newest = found.last
@@ -115,11 +115,9 @@ class Gem::Security::Policy
115
115
  raise Gem::Security::Exception, 'missing key or signature'
116
116
  end
117
117
 
118
- public_key = Gem::Security.get_public_key(key)
119
-
120
118
  raise Gem::Security::Exception,
121
119
  "certificate #{signer.subject} does not match the signing key" unless
122
- signer.public_key.to_pem == public_key.to_pem
120
+ signer.check_private_key(key)
123
121
 
124
122
  true
125
123
  end
@@ -424,6 +424,8 @@ module Gem::Security
424
424
  # Gets the right public key from a PKey instance
425
425
 
426
426
  def self.get_public_key(key)
427
+ # Ruby 3.0 (Ruby/OpenSSL 2.2) or later
428
+ return OpenSSL::PKey.read(key.public_to_der) if key.respond_to?(:public_to_der)
427
429
  return key.public_key unless key.is_a?(OpenSSL::PKey::EC)
428
430
 
429
431
  ec_key = OpenSSL::PKey::EC.new(key.group.curve_name)
@@ -490,9 +492,13 @@ module Gem::Security
490
492
  when 'rsa'
491
493
  OpenSSL::PKey::RSA.new(RSA_DSA_KEY_LENGTH)
492
494
  when 'ec'
493
- domain_key = OpenSSL::PKey::EC.new(EC_NAME)
494
- domain_key.generate_key
495
- domain_key
495
+ if RUBY_VERSION >= "2.4.0"
496
+ OpenSSL::PKey::EC.generate(EC_NAME)
497
+ else
498
+ domain_key = OpenSSL::PKey::EC.new(EC_NAME)
499
+ domain_key.generate_key
500
+ domain_key
501
+ end
496
502
  else
497
503
  raise Gem::Security::Exception,
498
504
  "#{algorithm} algorithm not found. RSA, DSA, and EC algorithms are supported."
@@ -510,9 +516,10 @@ module Gem::Security
510
516
 
511
517
  dcs = dcs.split '.'
512
518
 
513
- name = "CN=#{cn}/#{dcs.map {|dc| "DC=#{dc}" }.join '/'}"
514
-
515
- OpenSSL::X509::Name.parse name
519
+ OpenSSL::X509::Name.new([
520
+ ["CN", cn],
521
+ *dcs.map {|dc| ["DC", dc] },
522
+ ])
516
523
  end
517
524
 
518
525
  ##
@@ -526,7 +533,7 @@ module Gem::Security
526
533
  raise Gem::Security::Exception,
527
534
  "incorrect signing key for re-signing " +
528
535
  "#{expired_certificate.subject}" unless
529
- expired_certificate.public_key.to_pem == get_public_key(private_key).to_pem
536
+ expired_certificate.check_private_key(private_key)
530
537
 
531
538
  unless expired_certificate.subject.to_s ==
532
539
  expired_certificate.issuer.to_s
@@ -35,6 +35,7 @@ class Gem::Source
35
35
  end
36
36
 
37
37
  @uri = uri
38
+ @update_cache = nil
38
39
  end
39
40
 
40
41
  ##
@@ -118,7 +119,8 @@ class Gem::Source
118
119
  # Returns true when it is possible and safe to update the cache directory.
119
120
 
120
121
  def update_cache?
121
- @update_cache ||=
122
+ return @update_cache unless @update_cache.nil?
123
+ @update_cache =
122
124
  begin
123
125
  File.stat(Gem.user_home).uid == Process.uid
124
126
  rescue Errno::ENOENT
@@ -121,7 +121,7 @@ class Gem::SpecFetcher
121
121
  end
122
122
  end
123
123
 
124
- tuples = tuples.sort_by {|x| x[0] }
124
+ tuples = tuples.sort_by {|x| x[0].version }
125
125
 
126
126
  return [tuples, errors]
127
127
  end
@@ -9,6 +9,8 @@
9
9
  require_relative 'deprecate'
10
10
  require_relative 'basic_specification'
11
11
  require_relative 'stub_specification'
12
+ require_relative 'platform'
13
+ require_relative 'requirement'
12
14
  require_relative 'specification_policy'
13
15
  require_relative 'util/list'
14
16
 
@@ -179,18 +181,14 @@ class Gem::Specification < Gem::BasicSpecification
179
181
  end
180
182
 
181
183
  def self.clear_specs # :nodoc:
182
- @@all_specs_mutex.synchronize do
183
- @@all = nil
184
- @@stubs = nil
185
- @@stubs_by_name = {}
186
- @@spec_with_requirable_file = {}
187
- @@active_stub_with_requirable_file = {}
188
- end
184
+ @@all = nil
185
+ @@stubs = nil
186
+ @@stubs_by_name = {}
187
+ @@spec_with_requirable_file = {}
188
+ @@active_stub_with_requirable_file = {}
189
189
  end
190
190
  private_class_method :clear_specs
191
191
 
192
- @@all_specs_mutex = Thread::Mutex.new
193
-
194
192
  clear_specs
195
193
 
196
194
  # Sentinel object to represent "not found" stubs
@@ -758,7 +756,7 @@ class Gem::Specification < Gem::BasicSpecification
758
756
  attr_accessor :specification_version
759
757
 
760
758
  def self._all # :nodoc:
761
- @@all_specs_mutex.synchronize { @@all ||= Gem.loaded_specs.values | stubs.map(&:to_spec) }
759
+ @@all ||= Gem.loaded_specs.values | stubs.map(&:to_spec)
762
760
  end
763
761
 
764
762
  def self.clear_load_cache # :nodoc:
@@ -861,7 +859,7 @@ class Gem::Specification < Gem::BasicSpecification
861
859
  next names if names.nonzero?
862
860
  versions = b.version <=> a.version
863
861
  next versions if versions.nonzero?
864
- b.platform == Gem::Platform::RUBY ? -1 : 1
862
+ Gem::Platform.sort_priority(b.platform)
865
863
  end
866
864
  end
867
865
 
@@ -997,7 +995,6 @@ class Gem::Specification < Gem::BasicSpecification
997
995
  def self.find_by_path(path)
998
996
  path = path.dup.freeze
999
997
  spec = @@spec_with_requirable_file[path] ||= (stubs.find do |s|
1000
- next unless Gem::BundlerVersionFinder.compatible?(s)
1001
998
  s.contains_requirable_file? path
1002
999
  end || NOT_FOUND)
1003
1000
  spec.to_spec
@@ -1010,7 +1007,6 @@ class Gem::Specification < Gem::BasicSpecification
1010
1007
  def self.find_inactive_by_path(path)
1011
1008
  stub = stubs.find do |s|
1012
1009
  next if s.activated?
1013
- next unless Gem::BundlerVersionFinder.compatible?(s)
1014
1010
  s.contains_requirable_file? path
1015
1011
  end
1016
1012
  stub && stub.to_spec
@@ -1086,7 +1082,7 @@ class Gem::Specification < Gem::BasicSpecification
1086
1082
  # +prerelease+ is true.
1087
1083
 
1088
1084
  def self.latest_specs(prerelease = false)
1089
- _latest_specs Gem::Specification._all, prerelease
1085
+ _latest_specs Gem::Specification.stubs, prerelease
1090
1086
  end
1091
1087
 
1092
1088
  ##
@@ -1120,7 +1116,7 @@ class Gem::Specification < Gem::BasicSpecification
1120
1116
  file = file.dup.tap(&Gem::UNTAINT)
1121
1117
  return unless File.file?(file)
1122
1118
 
1123
- code = File.read file, :mode => 'r:UTF-8:-'
1119
+ code = Gem.open_with_flock(file, 'r:UTF-8:-', &:read)
1124
1120
 
1125
1121
  code.tap(&Gem::UNTAINT)
1126
1122
 
@@ -2335,7 +2331,7 @@ class Gem::Specification < Gem::BasicSpecification
2335
2331
  # Returns an object you can use to sort specifications in #sort_by.
2336
2332
 
2337
2333
  def sort_obj
2338
- [@name, @version, @new_platform == Gem::Platform::RUBY ? -1 : 1]
2334
+ [@name, @version, Gem::Platform.sort_priority(@new_platform)]
2339
2335
  end
2340
2336
 
2341
2337
  ##
@@ -110,7 +110,7 @@ class Gem::StubSpecification < Gem::BasicSpecification
110
110
  begin
111
111
  saved_lineno = $.
112
112
 
113
- File.open loaded_from, OPEN_MODE do |file|
113
+ Gem.open_with_flock loaded_from, OPEN_MODE do |file|
114
114
  begin
115
115
  file.readline # discard encoding line
116
116
  stubline = file.readline.chomp
data/lib/rubygems/text.rb CHANGED
@@ -49,37 +49,38 @@ module Gem::Text
49
49
  end
50
50
  end
51
51
 
52
- # This code is based directly on the Text gem implementation
53
52
  # Returns a value representing the "cost" of transforming str1 into str2
53
+ # Vendored version of DidYouMean::Levenshtein.distance from the ruby/did_you_mean gem @ 1.4.0
54
+ # https://git.io/JJgZI
54
55
  def levenshtein_distance(str1, str2)
55
- s = str1
56
- t = str2
57
- n = s.length
58
- m = t.length
59
-
60
- return m if (0 == n)
61
- return n if (0 == m)
56
+ n = str1.length
57
+ m = str2.length
58
+ return m if n.zero?
59
+ return n if m.zero?
62
60
 
63
61
  d = (0..m).to_a
64
62
  x = nil
65
63
 
66
- str1.each_char.each_with_index do |char1,i|
67
- e = i + 1
64
+ # to avoid duplicating an enumerable object, create it outside of the loop
65
+ str2_codepoints = str2.codepoints
68
66
 
69
- str2.each_char.each_with_index do |char2,j|
70
- cost = (char1 == char2) ? 0 : 1
67
+ str1.each_codepoint.with_index(1) do |char1, i|
68
+ j = 0
69
+ while j < m
70
+ cost = (char1 == str2_codepoints[j]) ? 0 : 1
71
71
  x = min3(
72
- d[j + 1] + 1, # insertion
73
- e + 1, # deletion
74
- d[j] + cost # substitution
75
- )
76
- d[j] = e
77
- e = x
72
+ d[j + 1] + 1, # insertion
73
+ i + 1, # deletion
74
+ d[j] + cost # substitution
75
+ )
76
+ d[j] = i
77
+ i = x
78
+
79
+ j += 1
78
80
  end
79
-
80
81
  d[m] = x
81
82
  end
82
83
 
83
- return x
84
+ x
84
85
  end
85
86
  end