Class: Gem::DependencyInstaller
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Instance Chain: | |
| Inherits: | Object | 
| Defined in: | lib/rubygems/dependency_installer.rb | 
Overview
Installs a gem along with all its dependencies from local and remote gems.
Class Method Summary
- 
    
      .new(options = {})  ⇒ DependencyInstaller 
    
    constructor
    Creates a new installer instance. 
Instance Attribute Summary
- 
    
      #consider_local?  ⇒ Boolean 
    
    readonly
    Indicated, based on the requested domain, if local gems should be considered. 
- 
    
      #consider_remote?  ⇒ Boolean 
    
    readonly
    Indicated, based on the requested domain, if remote gems should be considered. 
- 
    
      #document  
    
    readonly
    Documentation types. 
- 
    
      #errors  
    
    readonly
    Errors from SpecFetcher while searching for remote specifications. 
- #installed_gems readonly
DefaultUserInteraction - Included
Instance Method Summary
- 
    
      #find_spec_by_name_and_version(gem_name, version = Gem::Requirement.default, prerelease = false)  
    
    Finds a spec and the source_uri it came from for gem gem_nameandversion.
- 
    
      #install(dep_or_name, version = Gem::Requirement.default)  
    
    Installs the gem dep_or_nameand all its dependencies.
UserInteraction - Included
| #alert | Displays an alert  | 
| #alert_error | Displays an error  | 
| #alert_warning | Displays a warning  | 
| #ask | Asks a  | 
| #ask_for_password | Asks for a password with a  | 
| #ask_yes_no | Asks a yes or no  | 
| #choose_from_list | Asks the user to answer  | 
| #say | Displays the given  | 
| #terminate_interaction | Terminates the RubyGems process with the given  | 
| #verbose | Calls  | 
DefaultUserInteraction - Included
Constructor Details
    .new(options = {})  ⇒ DependencyInstaller 
  
Creates a new installer instance.
Options are:
- :cache_dir
- 
Alternate repository path to store .gemfiles in.
- :domain
- 
:local,:remote, or:both.:localonly searches gems in the current directory. :remote searches only gems in Gem::sources. :both searches both.
- :env_shebang
- 
See Installer.new. 
- :force
- 
See Installer#install. 
- :format_executable
- 
See Gem::Installer#initialize.
- :ignore_dependencies
- 
Don't install any dependencies. 
- :install_dir
- 
See Installer#install. 
- :prerelease
- 
Allow prerelease versions. See #install. 
- :security_policy
- 
See Installer.new and Security. 
- :user_install
- 
See Installer.new 
- :wrappers
- 
See Installer.new 
- :build_args
- 
See Installer.new 
# File 'lib/rubygems/dependency_installer.rb', line 72
def initialize = {} @only_install_dir = !![:install_dir] @install_dir = [:install_dir] || Gem.dir @build_root = [:build_root] = DEFAULT_OPTIONS.merge @bin_dir = [:bin_dir] @dev_shallow = [:dev_shallow] @development = [:development] @document = [:document] @domain = [:domain] @env_shebang = [:env_shebang] @force = [:force] @format_executable = [:format_executable] @ignore_dependencies = [:ignore_dependencies] @prerelease = [:prerelease] @security_policy = [:security_policy] @user_install = [:user_install] @wrappers = [:wrappers] @build_args = [:build_args] @build_docs_in_background = [:build_docs_in_background] @install_as_default = [:install_as_default] # Indicates that we should not try to update any deps unless # we absolutely must. @minimal_deps = [:minimal_deps] @available = nil @installed_gems = [] @toplevel_specs = nil @cache_dir = [:cache_dir] || @install_dir @errors = [] end
Instance Attribute Details
    #consider_local?  ⇒ Boolean  (readonly)
  
Indicated, based on the requested domain, if local gems should be considered.
# File 'lib/rubygems/dependency_installer.rb', line 182
def consider_local? @domain == :both or @domain == :local end
    #consider_remote?  ⇒ Boolean  (readonly)
  
Indicated, based on the requested domain, if remote gems should be considered.
# File 'lib/rubygems/dependency_installer.rb', line 190
def consider_remote? @domain == :both or @domain == :remote end
#document (readonly)
Documentation types. For use by the Gem.done_installing hook
# File 'lib/rubygems/dependency_installer.rb', line 35
attr_reader :document
#errors (readonly)
Errors from SpecFetcher while searching for remote specifications
# File 'lib/rubygems/dependency_installer.rb', line 40
attr_reader :errors
#installed_gems (readonly)
[ GitHub ]# File 'lib/rubygems/dependency_installer.rb', line 51
attr_reader :installed_gems
Instance Method Details
#find_spec_by_name_and_version(gem_name, version = Gem::Requirement.default, prerelease = false)
Finds a spec and the source_uri it came from for gem gem_name and version.  Returns an Array of specs and sources required for installation of the gem.
# File 'lib/rubygems/dependency_installer.rb', line 264
def find_spec_by_name_and_version gem_name, version = Gem::Requirement.default, prerelease = false set = Gem::AvailableSet.new if consider_local? if gem_name =~ /\.gem$/ and File.file? gem_name then src = Gem::Source::SpecificFile.new(gem_name) set.add src.spec, src elsif gem_name =~ /\.gem$/ then Dir[gem_name].each do |name| begin src = Gem::Source::SpecificFile.new name set.add src.spec, src rescue Gem::Package::FormatError end end else local = Gem::Source::Local.new if s = local.find_gem(gem_name, version) set.add s, local end end end if set.empty? dep = Gem::Dependency.new gem_name, version dep.prerelease = true if prerelease set = find_gems_with_sources(dep, true) set.match_platform! end if set.empty? raise Gem::SpecificGemNotFoundException.new(gem_name, version, @errors) end @available = set end
#install(dep_or_name, version = Gem::Requirement.default)
Installs the gem dep_or_name and all its dependencies.  Returns an Array of installed gem specifications.
If the :prerelease option is set and there is a prerelease for dep_or_name the prerelease version will be installed.
Unless explicitly specified as a prerelease dependency, prerelease gems that dep_or_name depend on will not be installed.
If c-1.a depends on b-1 and a-1.a and there is a gem b-1.a available then c-1.a, b-1 and a-1.a will be installed. b-1.a will need to be installed separately.
# File 'lib/rubygems/dependency_installer.rb', line 372
def install dep_or_name, version = Gem::Requirement.default request_set = resolve_dependencies dep_or_name, version @installed_gems = [] = { :bin_dir => @bin_dir, :build_args => @build_args, :document => @document, :env_shebang => @env_shebang, :force => @force, :format_executable => @format_executable, :ignore_dependencies => @ignore_dependencies, :prerelease => @prerelease, :security_policy => @security_policy, :user_install => @user_install, :wrappers => @wrappers, :build_root => @build_root, :install_as_default => @install_as_default } [:install_dir] = @install_dir if @only_install_dir request_set.install do |_, installer| @installed_gems << installer.spec if installer end @installed_gems.sort! # Since this is currently only called for docs, we can be lazy and just say # it's documentation. Ideally the hook adder could decide whether to be in # the background or not, and what to call it. in_background "Installing documentation" do Gem.done_installing_hooks.each do |hook| hook.call self, @installed_gems end end unless Gem.done_installing_hooks.empty? @installed_gems end