mirror of
https://github.com/ruby/ruby.git
synced 2025-08-23 13:04:13 +02:00
* lib/rubygems: Update to RubyGems 2.1.3
Fixed installing platform gems Restored concurrent requires Fixed installing gems with extensions with --install-dir Fixed `gem fetch -v` to install the latest version Fixed installing gems with "./" in their files entries * test/rubygems/test_gem_package.rb: Tests for the above. * NEWS: Updated for RubyGems 2.1.3 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42938 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
85995e88d4
commit
1daa0b113d
110 changed files with 3493 additions and 4942 deletions
|
@ -52,47 +52,28 @@ class Gem::Commands::UpdateCommand < Gem::Command
|
|||
"--document --no-force --install-dir #{Gem.dir}"
|
||||
end
|
||||
|
||||
def description # :nodoc:
|
||||
<<-EOF
|
||||
The update command will update your gems to the latest version.
|
||||
|
||||
The update comamnd does not remove the previous version. Use the cleanup
|
||||
command to remove old versions.
|
||||
EOF
|
||||
end
|
||||
|
||||
def usage # :nodoc:
|
||||
"#{program_name} GEMNAME [GEMNAME ...]"
|
||||
end
|
||||
|
||||
def check_latest_rubygems version # :nodoc:
|
||||
if Gem.rubygems_version == version then
|
||||
say "Latest version currently installed. Aborting."
|
||||
terminate_interaction
|
||||
end
|
||||
|
||||
options[:user_install] = false
|
||||
end
|
||||
|
||||
def check_update_arguments # :nodoc:
|
||||
unless options[:args].empty? then
|
||||
alert_error "Gem names are not allowed with the --system option"
|
||||
terminate_interaction 1
|
||||
end
|
||||
end
|
||||
|
||||
def execute
|
||||
hig = {}
|
||||
|
||||
if options[:system] then
|
||||
update_rubygems
|
||||
return
|
||||
else
|
||||
say "Updating installed gems"
|
||||
|
||||
hig = {} # highest installed gems
|
||||
|
||||
Gem::Specification.each do |spec|
|
||||
if hig[spec.name].nil? or hig[spec.name].version < spec.version then
|
||||
hig[spec.name] = spec
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
say "Updating installed gems"
|
||||
|
||||
hig = highest_installed_gems
|
||||
|
||||
gems_to_update = which_to_update hig, options[:args].uniq
|
||||
|
||||
updated = update_gems gems_to_update
|
||||
|
@ -104,92 +85,6 @@ command to remove old versions.
|
|||
end
|
||||
end
|
||||
|
||||
def fetch_remote_gems spec # :nodoc:
|
||||
dependency = Gem::Dependency.new spec.name, "> #{spec.version}"
|
||||
dependency.prerelease = options[:prerelease]
|
||||
|
||||
fetcher = Gem::SpecFetcher.fetcher
|
||||
|
||||
spec_tuples, _ = fetcher.search_for_dependency dependency
|
||||
|
||||
spec_tuples
|
||||
end
|
||||
|
||||
def highest_installed_gems # :nodoc:
|
||||
hig = {} # highest installed gems
|
||||
|
||||
Gem::Specification.each do |spec|
|
||||
if hig[spec.name].nil? or hig[spec.name].version < spec.version then
|
||||
hig[spec.name] = spec
|
||||
end
|
||||
end
|
||||
|
||||
hig
|
||||
end
|
||||
|
||||
def highest_remote_version spec # :nodoc:
|
||||
spec_tuples = fetch_remote_gems spec
|
||||
|
||||
matching_gems = spec_tuples.select do |g,_|
|
||||
g.name == spec.name and g.match_platform?
|
||||
end
|
||||
|
||||
highest_remote_gem = matching_gems.sort_by { |g,_| g.version }.last
|
||||
|
||||
highest_remote_gem ||= [Gem::NameTuple.null]
|
||||
|
||||
highest_remote_gem.first.version
|
||||
end
|
||||
|
||||
def install_rubygems version # :nodoc:
|
||||
args = update_rubygems_arguments
|
||||
|
||||
update_dir = File.join Gem.dir, 'gems', "rubygems-update-#{version}"
|
||||
|
||||
Dir.chdir update_dir do
|
||||
say "Installing RubyGems #{version}"
|
||||
|
||||
# Make sure old rubygems isn't loaded
|
||||
old = ENV["RUBYOPT"]
|
||||
ENV.delete("RUBYOPT") if old
|
||||
installed = system Gem.ruby, 'setup.rb', *args
|
||||
say "RubyGems system software updated" if installed
|
||||
ENV["RUBYOPT"] = old if old
|
||||
end
|
||||
end
|
||||
|
||||
def rubygems_target_version
|
||||
version = options[:system]
|
||||
update_latest = version == true
|
||||
|
||||
if update_latest then
|
||||
version = Gem::Version.new Gem::VERSION
|
||||
requirement = Gem::Requirement.new ">= #{Gem::VERSION}"
|
||||
else
|
||||
version = Gem::Version.new version
|
||||
requirement = Gem::Requirement.new version
|
||||
end
|
||||
|
||||
rubygems_update = Gem::Specification.new
|
||||
rubygems_update.name = 'rubygems-update'
|
||||
rubygems_update.version = version
|
||||
|
||||
hig = {
|
||||
'rubygems-update' => rubygems_update
|
||||
}
|
||||
|
||||
gems_to_update = which_to_update hig, options[:args], :system
|
||||
_, up_ver = gems_to_update.first
|
||||
|
||||
target = if update_latest then
|
||||
up_ver
|
||||
else
|
||||
version
|
||||
end
|
||||
|
||||
return target, requirement
|
||||
end
|
||||
|
||||
def update_gem name, version = Gem::Requirement.default
|
||||
return if @updated.any? { |spec| spec.name == name }
|
||||
|
||||
|
@ -223,28 +118,74 @@ command to remove old versions.
|
|||
# Update RubyGems software to the latest version.
|
||||
|
||||
def update_rubygems
|
||||
check_update_arguments
|
||||
unless options[:args].empty? then
|
||||
alert_error "Gem names are not allowed with the --system option"
|
||||
terminate_interaction 1
|
||||
end
|
||||
|
||||
version, requirement = rubygems_target_version
|
||||
options[:user_install] = false
|
||||
|
||||
check_latest_rubygems version
|
||||
# TODO: rename version and other variable name conflicts
|
||||
# TODO: get rid of all this indirection on name and other BS
|
||||
|
||||
update_gem 'rubygems-update', version
|
||||
version = options[:system]
|
||||
if version == true then
|
||||
version = Gem::Version.new Gem::VERSION
|
||||
requirement = Gem::Requirement.new ">= #{Gem::VERSION}"
|
||||
else
|
||||
version = Gem::Version.new version
|
||||
requirement = Gem::Requirement.new version
|
||||
end
|
||||
|
||||
rubygems_update = Gem::Specification.new
|
||||
rubygems_update.name = 'rubygems-update'
|
||||
rubygems_update.version = version
|
||||
|
||||
hig = {
|
||||
'rubygems-update' => rubygems_update
|
||||
}
|
||||
|
||||
gems_to_update = which_to_update hig, options[:args], :system
|
||||
name, up_ver = gems_to_update.first
|
||||
current_ver = Gem.rubygems_version
|
||||
|
||||
target = if options[:system] == true then
|
||||
up_ver
|
||||
else
|
||||
version
|
||||
end
|
||||
|
||||
if current_ver == target then
|
||||
# if options[:system] != true and version == current_ver then
|
||||
say "Latest version currently installed. Aborting."
|
||||
terminate_interaction
|
||||
end
|
||||
|
||||
update_gem name, target
|
||||
|
||||
installed_gems = Gem::Specification.find_all_by_name 'rubygems-update', requirement
|
||||
version = installed_gems.last.version
|
||||
|
||||
install_rubygems version
|
||||
end
|
||||
|
||||
def update_rubygems_arguments # :nodoc:
|
||||
args = []
|
||||
args << '--prefix' << Gem.prefix if Gem.prefix
|
||||
# TODO use --document for >= 1.9 , --no-rdoc --no-ri < 1.9
|
||||
args << '--no-rdoc' unless options[:document].include? 'rdoc'
|
||||
args << '--no-ri' unless options[:document].include? 'ri'
|
||||
args << '--no-format-executable' if options[:no_format_executable]
|
||||
args
|
||||
|
||||
update_dir = File.join Gem.dir, 'gems', "rubygems-update-#{version}"
|
||||
|
||||
Dir.chdir update_dir do
|
||||
say "Installing RubyGems #{version}"
|
||||
setup_cmd = "#{Gem.ruby} setup.rb #{args.join ' '}"
|
||||
|
||||
# Make sure old rubygems isn't loaded
|
||||
old = ENV["RUBYOPT"]
|
||||
ENV.delete("RUBYOPT") if old
|
||||
installed = system setup_cmd
|
||||
say "RubyGems system software updated" if installed
|
||||
ENV["RUBYOPT"] = old if old
|
||||
end
|
||||
end
|
||||
|
||||
def which_to_update highest_installed_gems, gem_names, system = false
|
||||
|
@ -254,7 +195,21 @@ command to remove old versions.
|
|||
next if not gem_names.empty? and
|
||||
gem_names.all? { |name| /#{name}/ !~ l_spec.name }
|
||||
|
||||
highest_remote_ver = highest_remote_version l_spec
|
||||
dependency = Gem::Dependency.new l_spec.name, "> #{l_spec.version}"
|
||||
dependency.prerelease = options[:prerelease]
|
||||
|
||||
fetcher = Gem::SpecFetcher.fetcher
|
||||
|
||||
spec_tuples, _ = fetcher.search_for_dependency dependency
|
||||
|
||||
matching_gems = spec_tuples.select do |g,_|
|
||||
g.name == l_name and g.match_platform?
|
||||
end
|
||||
|
||||
highest_remote_gem = matching_gems.sort_by { |g,_| g.version }.last
|
||||
|
||||
highest_remote_gem ||= [Gem::NameTuple.null]
|
||||
highest_remote_ver = highest_remote_gem.first.version
|
||||
|
||||
if system or (l_spec.version < highest_remote_ver) then
|
||||
result << [l_spec.name, [l_spec.version, highest_remote_ver].max]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue