class Gem::PathSupport

Gem::PathSupport facilitates the GEM_HOME and GEM_PATH environment settings to the rest of RubyGems.

Attributes

auto_user_install[R]

Whether ‘Gem.paths.home` defaulted to a user install or not.

home[R]

The default system path for managing Gems.

path[R]

Array of paths to search for Gems.

Public Class Methods

new(env) click to toggle source

Constructor. Takes a single argument which is to be treated like a hashtable, or defaults to ENV, the system environment.

# File rubygems/path_support.rb, line 30
def initialize(env)
  # Current implementation of @home, which is exposed as `Gem.paths.home`:
  # 1. If `env["GEM_HOME"]` is defined in the environment: `env["GEM_HOME"]`.
  # 2. If `Gem.default_dir` is writable: `Gem.default_dir`.
  # 3. Otherwise: `Gem.user_dir`.

  if env.key?("GEM_HOME")
    @home = normalize_home_dir(env["GEM_HOME"])
  elsif File.writable?(Gem.default_dir)
    @home = normalize_home_dir(Gem.default_dir)
  else
    # If `GEM_HOME` is not set AND we can't use `Gem.default_dir`,
    # default to a user installation and set `@auto_user_install`.
    @auto_user_install = true
    @home = normalize_home_dir(Gem.user_dir)
  end

  @path = split_gem_path env["GEM_PATH"], @home

  @spec_cache_dir = env["GEM_SPEC_CACHE"] || Gem.default_spec_cache_dir

  @spec_cache_dir = @spec_cache_dir.dup.tap(&Gem::UNTAINT)
end

Private Instance Methods

default_path() click to toggle source

Return the default Gem path

# File rubygems/path_support.rb, line 95
def default_path
  Gem.default_path + [@home]
end
expand(path) click to toggle source
# File rubygems/path_support.rb, line 99
def expand(path)
  if File.directory?(path)
    File.realpath(path)
  else
    path
  end
end
normalize_home_dir(home) click to toggle source
# File rubygems/path_support.rb, line 56
def normalize_home_dir(home)
  if File::ALT_SEPARATOR
    home = home.gsub(File::ALT_SEPARATOR, File::SEPARATOR)
  end

  expand(home)
end
split_gem_path(gpaths, home) click to toggle source

Split the Gem search path (as reported by Gem.path).

# File rubygems/path_support.rb, line 67
def split_gem_path(gpaths, home)
  # FIX: it should be [home, *path], not [*path, home]

  gem_path = []

  if gpaths
    gem_path = gpaths.split(Gem.path_separator)
    # Handle the path_separator being set to a regexp, which will cause
    # end_with? to error
    if /#{Gem.path_separator}\z/.match?(gpaths)
      gem_path += default_path
    end

    if File::ALT_SEPARATOR
      gem_path.map! do |this_path|
        this_path.gsub File::ALT_SEPARATOR, File::SEPARATOR
      end
    end

    gem_path << home
  else
    gem_path = default_path
  end

  gem_path.map {|path| expand(path) }.uniq
end