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