1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
require "uri"
require "rubygems/spec_fetcher"
module Bundler
# Represents a lazily loaded gem specification, where the full specification
# is on the source server in rubygems' "quick" index. The proxy object is to
# be seeded with what we're given from the source's abbreviated index - the
# full specification will only be fetched when necesary.
class RemoteSpecification
include MatchPlatform
attr_reader :name, :version, :platform
attr_accessor :source
def initialize(name, version, platform, source_uri)
@name = name
@version = version
@platform = platform
@source_uri = source_uri
end
# Needed before installs, since the arch matters then and quick
# specs don't bother to include the arch in the platform string
def fetch_platform
@platform = _remote_specification.platform
end
def full_name
if platform == Gem::Platform::RUBY or platform.nil? then
"#{@name}-#{@version}"
else
"#{@name}-#{@version}-#{platform}"
end
end
# Because Rubyforge cannot be trusted to provide valid specifications
# once the remote gem is downloaded, the backend specification will
# be swapped out.
def __swap__(spec)
@specification = spec
end
private
def _remote_specification
@specification ||= begin
Gem::SpecFetcher.new.fetch_spec([@name, @version, @platform], URI(@source_uri.to_s))
end
end
def method_missing(method, *args, &blk)
if Gem::Specification.new.respond_to?(method)
_remote_specification.send(method, *args, &blk)
else
super
end
end
end
end
|