mirror of
https://github.com/ruby/ruby.git
synced 2025-08-23 13:04:13 +02:00
* lib/rubygems: Import RubyGems from master as of commit b165260
* test/rubygems: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42124 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
66cc0fa4ab
commit
4c2304f000
34 changed files with 1169 additions and 597 deletions
|
@ -37,103 +37,118 @@ class Gem::Commands::SourcesCommand < Gem::Command
|
|||
add_proxy_option
|
||||
end
|
||||
|
||||
def defaults_str
|
||||
'--list'
|
||||
def add_source source_uri # :nodoc:
|
||||
check_rubygems_https source_uri
|
||||
|
||||
source = Gem::Source.new source_uri
|
||||
|
||||
begin
|
||||
if Gem.sources.include? source_uri then
|
||||
say "source #{source_uri} already present in the cache"
|
||||
else
|
||||
source.load_specs :released
|
||||
Gem.sources << source
|
||||
Gem.configuration.write
|
||||
|
||||
say "#{source_uri} added to sources"
|
||||
end
|
||||
rescue URI::Error, ArgumentError
|
||||
say "#{source_uri} is not a URI"
|
||||
terminate_interaction 1
|
||||
rescue Gem::RemoteFetcher::FetchError => e
|
||||
say "Error fetching #{source_uri}:\n\t#{e.message}"
|
||||
terminate_interaction 1
|
||||
end
|
||||
end
|
||||
|
||||
def execute
|
||||
options[:list] = !(options[:add] ||
|
||||
options[:clear_all] ||
|
||||
options[:remove] ||
|
||||
options[:update])
|
||||
def check_rubygems_https source_uri # :nodoc:
|
||||
uri = URI source_uri
|
||||
|
||||
if options[:clear_all] then
|
||||
path = Gem.spec_cache_dir
|
||||
FileUtils.rm_rf path
|
||||
|
||||
unless File.exist? path then
|
||||
say "*** Removed specs cache ***"
|
||||
else
|
||||
unless File.writable? path then
|
||||
say "*** Unable to remove source cache (write protected) ***"
|
||||
else
|
||||
say "*** Unable to remove source cache ***"
|
||||
end
|
||||
|
||||
terminate_interaction 1
|
||||
end
|
||||
end
|
||||
|
||||
if source_uri = options[:add] then
|
||||
uri = URI source_uri
|
||||
|
||||
if uri.scheme and uri.scheme.downcase == 'http' and
|
||||
uri.host.downcase == 'rubygems.org' then
|
||||
question = <<-QUESTION.chomp
|
||||
if uri.scheme and uri.scheme.downcase == 'http' and
|
||||
uri.host.downcase == 'rubygems.org' then
|
||||
question = <<-QUESTION.chomp
|
||||
https://rubygems.org is recommended for security over #{uri}
|
||||
|
||||
Do you want to add this insecure source?
|
||||
QUESTION
|
||||
QUESTION
|
||||
|
||||
terminate_interaction 1 unless ask_yes_no question
|
||||
end
|
||||
|
||||
source = Gem::Source.new source_uri
|
||||
|
||||
begin
|
||||
if Gem.sources.include? source_uri then
|
||||
say "source #{source_uri} already present in the cache"
|
||||
else
|
||||
source.load_specs :released
|
||||
Gem.sources << source
|
||||
Gem.configuration.write
|
||||
|
||||
say "#{source_uri} added to sources"
|
||||
end
|
||||
rescue URI::Error, ArgumentError
|
||||
say "#{source_uri} is not a URI"
|
||||
terminate_interaction 1
|
||||
rescue Gem::RemoteFetcher::FetchError => e
|
||||
say "Error fetching #{source_uri}:\n\t#{e.message}"
|
||||
terminate_interaction 1
|
||||
end
|
||||
end
|
||||
|
||||
if options[:remove] then
|
||||
source_uri = options[:remove]
|
||||
|
||||
unless Gem.sources.include? source_uri then
|
||||
say "source #{source_uri} not present in cache"
|
||||
else
|
||||
Gem.sources.delete source_uri
|
||||
Gem.configuration.write
|
||||
|
||||
say "#{source_uri} removed from sources"
|
||||
end
|
||||
end
|
||||
|
||||
if options[:update] then
|
||||
Gem.sources.each_source do |src|
|
||||
src.load_specs :released
|
||||
src.load_specs :latest
|
||||
end
|
||||
|
||||
say "source cache successfully updated"
|
||||
end
|
||||
|
||||
if options[:list] then
|
||||
say "*** CURRENT SOURCES ***"
|
||||
say
|
||||
|
||||
Gem.sources.each do |src|
|
||||
say src
|
||||
end
|
||||
terminate_interaction 1 unless ask_yes_no question
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
def clear_all # :nodoc:
|
||||
path = Gem.spec_cache_dir
|
||||
FileUtils.rm_rf path
|
||||
|
||||
def remove_cache_file(desc, path)
|
||||
unless File.exist? path then
|
||||
say "*** Removed specs cache ***"
|
||||
else
|
||||
unless File.writable? path then
|
||||
say "*** Unable to remove source cache (write protected) ***"
|
||||
else
|
||||
say "*** Unable to remove source cache ***"
|
||||
end
|
||||
|
||||
terminate_interaction 1
|
||||
end
|
||||
end
|
||||
|
||||
def defaults_str # :nodoc:
|
||||
'--list'
|
||||
end
|
||||
|
||||
def list # :nodoc:
|
||||
say "*** CURRENT SOURCES ***"
|
||||
say
|
||||
|
||||
Gem.sources.each do |src|
|
||||
say src
|
||||
end
|
||||
end
|
||||
|
||||
def list? # :nodoc:
|
||||
!(options[:list] ||
|
||||
options[:add] ||
|
||||
options[:clear_all] ||
|
||||
options[:remove] ||
|
||||
options[:update])
|
||||
end
|
||||
|
||||
def execute
|
||||
clear_all if options[:clear_all]
|
||||
|
||||
source_uri = options[:add]
|
||||
add_source source_uri if source_uri
|
||||
|
||||
source_uri = options[:remove]
|
||||
remove_source source_uri if source_uri
|
||||
|
||||
update if options[:update]
|
||||
|
||||
list if list?
|
||||
end
|
||||
|
||||
def remove_source source_uri # :nodoc:
|
||||
unless Gem.sources.include? source_uri then
|
||||
say "source #{source_uri} not present in cache"
|
||||
else
|
||||
Gem.sources.delete source_uri
|
||||
Gem.configuration.write
|
||||
|
||||
say "#{source_uri} removed from sources"
|
||||
end
|
||||
end
|
||||
|
||||
def update # :nodoc:
|
||||
Gem.sources.each_source do |src|
|
||||
src.load_specs :released
|
||||
src.load_specs :latest
|
||||
end
|
||||
|
||||
say "source cache successfully updated"
|
||||
end
|
||||
|
||||
def remove_cache_file desc, path # :nodoc:
|
||||
FileUtils.rm_rf path
|
||||
|
||||
if not File.exist?(path) then
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue