Class: Bundler::Source::Path

Inherits:
Bundler::Source show all
Defined in:
lib/bundler/source/path.rb,
lib/bundler/source/path/installer.rb

Direct Known Subclasses

Gemspec, Git

Defined Under Namespace

Classes: Installer

Constant Summary collapse

DEFAULT_GLOB =
"{,*,*/*}.gemspec".freeze

Instance Attribute Summary collapse

Attributes inherited from Bundler::Source

#dependency_names

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Bundler::Source

#add_dependency_names, #can_lock?, #dependency_names_to_double_check, #double_check_for, #extension_cache_path, #identifier, #include?, #inspect, #local!, #local_only!, #path?, #spec_names, #unmet_deps, #version_message

Constructor Details

#initialize(options) ⇒ Path

Returns a new instance of Path.


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
# File 'lib/bundler/source/path.rb', line 16

def initialize(options)
  @options = options.dup
  @glob = options["glob"] || DEFAULT_GLOB

  @allow_cached = false
  @allow_remote = false

  @root_path = options["root_path"] || root

  if options["path"]
    @path = Pathname.new(options["path"])
    expanded_path = expand(@path)
    @path = if @path.relative?
      expanded_path.relative_path_from(root_path.expand_path)
    else
      expanded_path
    end
  end

  @name    = options["name"]
  @version = options["version"]

  # Stores the original path. If at any point we move to the
  # cached directory, we still have the original path to copy from.
  @original_path = @path
end

Instance Attribute Details

#nameObject


80
81
82
# File 'lib/bundler/source/path.rb', line 80

def name
  File.basename(expanded_path.to_s)
end

#optionsObject (readonly)

Returns the value of attribute options.


8
9
10
# File 'lib/bundler/source/path.rb', line 8

def options
  @options
end

#pathObject (readonly)

Returns the value of attribute path.


8
9
10
# File 'lib/bundler/source/path.rb', line 8

def path
  @path
end

#root_pathObject (readonly)

Returns the value of attribute root_path.


8
9
10
# File 'lib/bundler/source/path.rb', line 8

def root_path
  @root_path
end

#versionObject

Returns the value of attribute version.


10
11
12
# File 'lib/bundler/source/path.rb', line 10

def version
  @version
end

Class Method Details

.from_lock(options) ⇒ Object


53
54
55
# File 'lib/bundler/source/path.rb', line 53

def self.from_lock(options)
  new(options.merge("path" => options.delete("remote")))
end

Instance Method Details

#app_cache_dirnameObject


118
119
120
# File 'lib/bundler/source/path.rb', line 118

def app_cache_dirname
  name
end

#cache(spec, custom_path = nil) ⇒ Object


92
93
94
95
96
97
98
99
100
101
102
103
104
# File 'lib/bundler/source/path.rb', line 92

def cache(spec, custom_path = nil)
  app_cache_path = app_cache_path(custom_path)
  return unless Bundler.feature_flag.cache_all?
  return if expand(@original_path).to_s.index(root_path.to_s + "/") == 0

  unless @original_path.exist?
    raise GemNotFound, "Can't cache gem #{version_message(spec)} because #{self} is missing!"
  end

  FileUtils.rm_rf(app_cache_path)
  FileUtils.cp_r("#{@original_path}/.", app_cache_path)
  FileUtils.touch(app_cache_path.join(".bundlecache"))
end

#cached!Object


48
49
50
51
# File 'lib/bundler/source/path.rb', line 48

def cached!
  @local_specs = nil
  @allow_cached = true
end

#eql?(other) ⇒ Boolean Also known as: ==

Returns:

  • (Boolean)

72
73
74
75
76
# File 'lib/bundler/source/path.rb', line 72

def eql?(other)
  return unless other.class == self.class
  expanded_original_path == other.expanded_original_path &&
    version == other.version
end

#expanded_original_pathObject


126
127
128
# File 'lib/bundler/source/path.rb', line 126

def expanded_original_path
  @expanded_original_path ||= expand(original_path)
end

#hashObject


68
69
70
# File 'lib/bundler/source/path.rb', line 68

def hash
  [self.class, expanded_path, version].hash
end

#install(spec, options = {}) ⇒ Object


84
85
86
87
88
89
90
# File 'lib/bundler/source/path.rb', line 84

def install(spec, options = {})
  using_message = "Using #{version_message(spec)} from #{self}"
  using_message += " and installing its executables" unless spec.executables.empty?
  print_using_message using_message
  generate_bin(spec, :disable_extensions => true)
  nil # no post-install message
end

#local_specsObject


106
107
108
# File 'lib/bundler/source/path.rb', line 106

def local_specs(*)
  @local_specs ||= load_spec_files
end

#remote!Object


43
44
45
46
# File 'lib/bundler/source/path.rb', line 43

def remote!
  @local_specs = nil
  @allow_remote = true
end

#rootObject


122
123
124
# File 'lib/bundler/source/path.rb', line 122

def root
  Bundler.root
end

#specsObject


110
111
112
113
114
115
116
# File 'lib/bundler/source/path.rb', line 110

def specs
  if has_app_cache?
    @path = app_cache_path
    @expanded_path = nil # Invalidate
  end
  local_specs
end

#to_lockObject


57
58
59
60
61
62
# File 'lib/bundler/source/path.rb', line 57

def to_lock
  out = String.new("PATH\n")
  out << "  remote: #{lockfile_path}\n"
  out << "  glob: #{@glob}\n" unless @glob == DEFAULT_GLOB
  out << "  specs:\n"
end

#to_sObject


64
65
66
# File 'lib/bundler/source/path.rb', line 64

def to_s
  "source at `#{@path}`"
end