class Bundler::StubSpecification

Attributes

ignored[RW]
stub[RW]

Public Class Methods

from_stub(stub) click to toggle source
# File lib/bundler/stub_specification.rb, line 7
def self.from_stub(stub)
  return stub if stub.is_a?(Bundler::StubSpecification)
  spec = new(stub.name, stub.version, stub.platform, nil)
  spec.stub = stub
  spec
end

Public Instance Methods

activated() click to toggle source
# File lib/bundler/stub_specification.rb, line 42
def activated
  stub.activated
end
activated=(activated) click to toggle source
# File lib/bundler/stub_specification.rb, line 46
def activated=(activated)
  stub.instance_variable_set(:@activated, activated)
end
default_gem() click to toggle source
# File lib/bundler/stub_specification.rb, line 50
def default_gem
  stub.default_gem
end
full_gem_path() click to toggle source
# File lib/bundler/stub_specification.rb, line 54
def full_gem_path
  # deleted gems can have their stubs return nil, so in that case grab the
  # expired path from the full spec
  stub.full_gem_path || method_missing(:full_gem_path)
end
full_require_paths() click to toggle source
# File lib/bundler/stub_specification.rb, line 61
def full_require_paths
  stub.full_require_paths
end
load_paths() click to toggle source

This is what we do in bundler/rubygems_ext full_require_paths is always implemented in >= 2.2.0

# File lib/bundler/stub_specification.rb, line 67
def load_paths
  full_require_paths
end
loaded_from() click to toggle source
# File lib/bundler/stub_specification.rb, line 72
def loaded_from
  stub.loaded_from
end
matches_for_glob(glob) click to toggle source
# File lib/bundler/stub_specification.rb, line 77
def matches_for_glob(glob)
  stub.matches_for_glob(glob)
end
missing_extensions?() click to toggle source

This is defined directly to avoid having to load every installed spec

# File lib/bundler/stub_specification.rb, line 37
def missing_extensions?
  stub.missing_extensions?
end
raw_require_paths() click to toggle source
# File lib/bundler/stub_specification.rb, line 82
def raw_require_paths
  stub.raw_require_paths
end
source=(source) click to toggle source
Calls superclass method
# File lib/bundler/stub_specification.rb, line 19
def source=(source)
  super
  # Stub has no concept of source, which means that extension_dir may be wrong
  # This is the case for git-based gems. So, instead manually assign the extension dir
  return unless source.respond_to?(:extension_dir_name)
  path = File.join(stub.extensions_dir, source.extension_dir_name)
  stub.extension_dir = File.expand_path(path)
end
to_yaml() click to toggle source
# File lib/bundler/stub_specification.rb, line 29
def to_yaml
  _remote_specification.to_yaml
end

Private Instance Methods

_remote_specification() click to toggle source
# File lib/bundler/stub_specification.rb, line 88
def _remote_specification
  @_remote_specification ||= begin
    rs = stub.to_spec
    if rs.equal?(self) # happens when to_spec gets the spec from Gem.loaded_specs
      rs = Gem::Specification.load(loaded_from)
      Bundler.rubygems.stub_set_spec(stub, rs)
    end

    unless rs
      raise GemspecError, "The gemspec for #{full_name} at #{loaded_from}" \
        " was missing or broken. Try running `gem pristine #{name} -v #{version}`" \
        " to fix the cached spec."
    end

    rs.source = source

    rs
  end
end