Namespace
Methods
- G
- I
- L
- N
- R
- S
- T
Included Modules
Attributes
[R] | dependencies |
Class Public methods
new(*deps)
Link
Instance Public methods
gem(name, *reqs)
Link
Declare that a gem of name name
with reqs
requirements is needed.
import(deps)
Link
Add deps
Gem::Depedency objects to the set.
install(options, &b)
Link
# File lib/rubygems/request_set.rb, line 119 def install(options, &b) if dir = options[:install_dir] return install_into(dir, false, &b) end cache_dir = options[:cache_dir] || Gem.dir specs = [] sorted_requests.each do |req| if req.installed? b.call req, nil if b next end path = req.download cache_dir inst = Gem::Installer.new path, options b.call req, inst if b specs << inst.install end specs end
install_into(dir, force=true, &b)
Link
# File lib/rubygems/request_set.rb, line 91 def install_into(dir, force=true, &b) existing = force ? [] : specs_in(dir) dir = File.expand_path dir installed = [] sorted_requests.each do |req| if existing.find { |s| s.full_name == req.spec.full_name } b.call req, nil if b next end path = req.download(dir) inst = Gem::Installer.new path, :install_dir => dir, :only_install_dir => true b.call req, inst if b inst.install installed << req end installed end
load_gemdeps(path)
Link
Load a dependency management file.
resolve(set=nil)
Link
Resolve the requested dependencies and return an Array of Specification objects to be activated.
resolve_current()
Link
Resolve the requested dependencies against the gems available via Gem.path and return an Array of Specification objects to be activated.
sorted_requests()
Link
specs()
Link
specs_in(dir)
Link
tsort_each_child(node)
Link
# File lib/rubygems/request_set.rb, line 65 def tsort_each_child(node) node.spec.dependencies.each do |dep| next if dep.type == :development match = @requests.find { |r| dep.match? r.spec.name, r.spec.version } if match begin yield match rescue TSort::Cyclic end else raise Gem::DependencyError, "Unresolved depedency found during sorting - #{dep}" end end end