mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rubygems: Update to RubyGems master 6a3d9f9. Changes include:
Compatibly renamed Gem::DependencyResolver to Gem::Resolver. Added support for git gems in gem.deps.rb and Gemfile. Fixed resolver bugs. * test/rubygems: ditto. * lib/rubygems/LICENSE.txt: Updated to license from RubyGems trunk. [ruby-trunk - Bug #9086] * lib/rubygems/commands/which_command.rb: RubyGems now indicates failure when any file is missing. [ruby-trunk - Bug #9004] * lib/rubygems/ext/builder: Extensions are now installed into the extension install directory and the first directory in the require path from the gem. This allows backwards compatibility with msgpack and other gems that calculate full require paths. [ruby-trunk - Bug #9106] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43714 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
e7ec3dad90
commit
a7fa4d5d9a
88 changed files with 1799 additions and 430 deletions
|
@ -28,7 +28,9 @@ class Gem::Source
|
|||
case other
|
||||
when Gem::Source::Installed,
|
||||
Gem::Source::Local,
|
||||
Gem::Source::SpecificFile then
|
||||
Gem::Source::SpecificFile,
|
||||
Gem::Source::Git,
|
||||
Gem::Source::Vendor then
|
||||
-1
|
||||
when Gem::Source then
|
||||
if !@uri
|
||||
|
@ -62,9 +64,9 @@ class Gem::Source
|
|||
fetcher = Gem::RemoteFetcher.fetcher
|
||||
fetcher.fetch_path bundler_api_uri, nil, true
|
||||
rescue Gem::RemoteFetcher::FetchError
|
||||
Gem::DependencyResolver::IndexSet.new self
|
||||
Gem::Resolver::IndexSet.new self
|
||||
else
|
||||
Gem::DependencyResolver::APISet.new bundler_api_uri
|
||||
Gem::Resolver::APISet.new bundler_api_uri
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -90,12 +92,15 @@ class Gem::Source
|
|||
end
|
||||
end
|
||||
|
||||
def fetch_spec(name)
|
||||
##
|
||||
# Fetches a specification for the given +name_tuple+.
|
||||
|
||||
def fetch_spec name_tuple
|
||||
fetcher = Gem::RemoteFetcher.fetcher
|
||||
|
||||
spec_file_name = name.spec_name
|
||||
spec_file_name = name_tuple.spec_name
|
||||
|
||||
uri = @uri + "#{Gem::MARSHAL_SPEC_DIR}#{spec_file_name}"
|
||||
uri = api_uri + "#{Gem::MARSHAL_SPEC_DIR}#{spec_file_name}"
|
||||
|
||||
cache_dir = cache_dir uri
|
||||
|
||||
|
@ -139,7 +144,7 @@ class Gem::Source
|
|||
file = FILES[type]
|
||||
fetcher = Gem::RemoteFetcher.fetcher
|
||||
file_name = "#{file}.#{Gem.marshal_version}"
|
||||
spec_path = @uri + "#{file_name}.gz"
|
||||
spec_path = api_uri + "#{file_name}.gz"
|
||||
cache_dir = cache_dir spec_path
|
||||
local_file = File.join(cache_dir, file_name)
|
||||
retried = false
|
||||
|
@ -163,18 +168,22 @@ class Gem::Source
|
|||
|
||||
def download(spec, dir=Dir.pwd)
|
||||
fetcher = Gem::RemoteFetcher.fetcher
|
||||
fetcher.download spec, @uri.to_s, dir
|
||||
fetcher.download spec, api_uri.to_s, dir
|
||||
end
|
||||
|
||||
def pretty_print q # :nodoc:
|
||||
q.group 2, '[Remote:', ']' do
|
||||
q.breakable
|
||||
q.text @uri.to_s
|
||||
if api = api_uri
|
||||
g.text api
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
require 'rubygems/source/git'
|
||||
require 'rubygems/source/installed'
|
||||
require 'rubygems/source/specific_file'
|
||||
require 'rubygems/source/local'
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue