Class: Bundler::Installer
- Inherits:
-
Environment
- Object
- Environment
- Bundler::Installer
- Defined in:
- lib/bundler/installer.rb
Instance Attribute Summary
Attributes inherited from Environment
Class Method Summary collapse
Instance Method Summary collapse
Methods inherited from Environment
#current_dependencies, #dependencies, #index, #initialize, #inspect, #lock, #requested_specs, #specs, #update
Constructor Details
This class inherits a constructor from Bundler::Environment
Class Method Details
Instance Method Details
#run(options) ⇒ Object
12 13 14 15 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 42 43 44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/bundler/installer.rb', line 12 def run() # Create the BUNDLE_PATH directory begin Bundler.bundle_path.mkpath unless Bundler.bundle_path.exist? rescue Errno::EEXIST raise PathError, "Could not install to path `#{Bundler.settings[:path]}` " + "because of an invalid symlink. Remove the symlink so the directory can be created." end if Bundler.settings[:frozen] @definition.ensure_equivalent_gemfile_and_lockfile([:deployment]) end if dependencies.empty? Bundler.ui.warn "The Gemfile specifies no dependencies" return end if Bundler.default_lockfile.exist? && !["update"] begin tmpdef = Definition.build(Bundler.default_gemfile, Bundler.default_lockfile, nil) local = true unless tmpdef.new_platform? || tmpdef.missing_specs.any? rescue BundlerError end end # Since we are installing, we can resolve the definition # using remote specs unless local ["local"] ? @definition.resolve_with_cache! : @definition.resolve_remotely! end # Must install gems in the order that the resolver provides # as dependencies might actually affect the installation of # the gem. specs.each do |spec| install_gem_from_spec(spec) end lock end |