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

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

#can_lock?, #dependency_names_to_double_check, #double_check_for, #include?, #inspect, #path?, #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
# 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"] || Bundler.root

  if options["path"]
    @path = Pathname.new(options["path"])
    @path = expand(@path) unless @path.relative?
  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



75
76
77
# File 'lib/bundler/source/path.rb', line 75

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



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

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

Instance Method Details

#app_cache_dirnameObject



111
112
113
# File 'lib/bundler/source/path.rb', line 111

def app_cache_dirname
  name
end

#cache(spec, custom_path = nil) ⇒ Object



85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/bundler/source/path.rb', line 85

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



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

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

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

Returns:

  • (Boolean)


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

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

#expanded_original_pathObject



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

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

#hashObject



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

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

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



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

def install(spec, options = {})
  print_using_message "Using #{version_message(spec)} from #{self}"
  generate_bin(spec, :disable_extensions => true)
  nil # no post-install message
end

#local_specsObject



99
100
101
# File 'lib/bundler/source/path.rb', line 99

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

#remote!Object



38
39
40
41
# File 'lib/bundler/source/path.rb', line 38

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

#rootObject



115
116
117
# File 'lib/bundler/source/path.rb', line 115

def root
  Bundler.root
end

#specsObject



103
104
105
106
107
108
109
# File 'lib/bundler/source/path.rb', line 103

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

#to_lockObject



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

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



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

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