class Bundler::EndpointSpecification
used for Creating Specifications from the Gemcutter Endpoint
Attributes
checksum[R]
dependencies[RW]
locked_platform[RW]
name[R]
platform[R]
remote[RW]
version[R]
Public Class Methods
new(name, version, platform, spec_fetcher, dependencies, metadata = nil)
click to toggle source
Calls superclass method
# File bundler/endpoint_specification.rb, line 11 def initialize(name, version, platform, spec_fetcher, dependencies, metadata = nil) super() @name = name @version = Gem::Version.create version @platform = Gem::Platform.new(platform) @spec_fetcher = spec_fetcher @dependencies = dependencies.map {|dep, reqs| build_dependency(dep, reqs) } @loaded_from = nil @remote_specification = nil @locked_platform = nil parse_metadata(metadata) end
Public Instance Methods
__swap__(spec)
click to toggle source
# File bundler/endpoint_specification.rb, line 118 def __swap__(spec) SharedHelpers.ensure_same_dependencies(self, dependencies, spec.dependencies) @remote_specification = spec end
_local_specification()
click to toggle source
# File bundler/endpoint_specification.rb, line 111 def _local_specification return unless @loaded_from && File.exist?(local_specification_path) eval(File.read(local_specification_path), nil, local_specification_path).tap do |spec| spec.loaded_from = @loaded_from end end
bindir()
click to toggle source
needed for bundle clean
Calls superclass method
# File bundler/endpoint_specification.rb, line 68 def bindir if @remote_specification @remote_specification.bindir elsif _local_specification _local_specification.bindir else super end end
executables()
click to toggle source
needed for binstubs
Calls superclass method
# File bundler/endpoint_specification.rb, line 57 def executables if @remote_specification @remote_specification.executables elsif _local_specification _local_specification.executables else super end end
extensions()
click to toggle source
needed for “with native extensions” during install
Calls superclass method
# File bundler/endpoint_specification.rb, line 90 def extensions if @remote_specification @remote_specification.extensions elsif _local_specification _local_specification.extensions else super end end
fetch_platform()
click to toggle source
# File bundler/endpoint_specification.rb, line 30 def fetch_platform @platform end
insecurely_materialized?()
click to toggle source
# File bundler/endpoint_specification.rb, line 26 def insecurely_materialized? @locked_platform.to_s != @platform.to_s end
inspect()
click to toggle source
# File bundler/endpoint_specification.rb, line 123 def inspect "#<#{self.class} @name=\"#{name}\" (#{full_name.delete_prefix("#{name}-")})>" end
load_paths()
click to toggle source
needed for inline
Calls superclass method
Gem::Specification#load_paths
# File bundler/endpoint_specification.rb, line 47 def load_paths # remote specs aren't installed, and can't have load_paths if _local_specification _local_specification.load_paths else super end end
metadata()
click to toggle source
needed for ‘bundle fund`
Calls superclass method
# File bundler/endpoint_specification.rb, line 101 def metadata if @remote_specification @remote_specification.metadata elsif _local_specification _local_specification.metadata else super end end
post_install_message()
click to toggle source
needed for post_install_messages during install
Calls superclass method
# File bundler/endpoint_specification.rb, line 79 def post_install_message if @remote_specification @remote_specification.post_install_message elsif _local_specification _local_specification.post_install_message else super end end
require_paths()
click to toggle source
needed for standalone, load required_paths from local gemspec after the gem is installed
Calls superclass method
# File bundler/endpoint_specification.rb, line 36 def require_paths if @remote_specification @remote_specification.require_paths elsif _local_specification _local_specification.require_paths else super end end
Private Instance Methods
_remote_specification()
click to toggle source
# File bundler/endpoint_specification.rb, line 129 def _remote_specification @_remote_specification ||= @spec_fetcher.fetch_spec([@name, @version, @platform]) end
build_dependency(name, requirements)
click to toggle source
# File bundler/endpoint_specification.rb, line 163 def build_dependency(name, requirements) Gem::Dependency.new(name, requirements) end
local_specification_path()
click to toggle source
# File bundler/endpoint_specification.rb, line 133 def local_specification_path "#{base_dir}/specifications/#{full_name}.gemspec" end
parse_metadata(data)
click to toggle source
# File bundler/endpoint_specification.rb, line 137 def parse_metadata(data) unless data @required_ruby_version = nil @required_rubygems_version = nil return end data.each do |k, v| next unless v case k.to_s when "checksum" begin @checksum = Checksum.from_api(v.last, @spec_fetcher.uri) rescue ArgumentError => e raise ArgumentError, "Invalid checksum for #{full_name}: #{e.message}" end when "rubygems" @required_rubygems_version = Gem::Requirement.new(v) when "ruby" @required_ruby_version = Gem::Requirement.new(v) end end rescue StandardError => e raise GemspecError, "There was an error parsing the metadata for the gem #{name} (#{version}): #{e.class}\n#{e}\nThe metadata was #{data.inspect}" end