File: //usr/lib/ruby/2.7.0/rubygems/defaults.rb
# frozen_string_literal: true
module Gem
  DEFAULT_HOST = "https://rubygems.org".freeze
  @post_install_hooks ||= []
  @done_installing_hooks ||= []
  @post_uninstall_hooks ||= []
  @pre_uninstall_hooks  ||= []
  @pre_install_hooks    ||= []
  ##
  # An Array of the default sources that come with RubyGems
  def self.default_sources
    %w[https://rubygems.org/]
  end
  ##
  # Default spec directory path to be used if an alternate value is not
  # specified in the environment
  def self.default_spec_cache_dir
    File.join Gem.user_home, '.gem', 'specs'
  end
  ##
  # Default home directory path to be used if an alternate value is not
  # specified in the environment
  def self.default_dir
    path = if defined? RUBY_FRAMEWORK_VERSION
             [
               File.dirname(RbConfig::CONFIG['sitedir']),
               'Gems',
               RbConfig::CONFIG['ruby_version']
             ]
           else
             [
               RbConfig::CONFIG['rubylibprefix'],
               'gems',
               RbConfig::CONFIG['ruby_version']
             ]
           end
    @default_dir ||= File.join(*path)
  end
  ##
  # Returns binary extensions dir for specified RubyGems base dir or nil
  # if such directory cannot be determined.
  #
  # By default, the binary extensions are located side by side with their
  # Ruby counterparts, therefore nil is returned
  def self.default_ext_dir_for(base_dir)
    nil
  end
  ##
  # Paths where RubyGems' .rb files and bin files are installed
  def self.default_rubygems_dirs
    nil # default to standard layout
  end
  ##
  # Path to specification files of default gems.
  def self.default_specifications_dir
    File.join(Gem.default_dir, "specifications", "default")
  end
  ##
  # Path for gems in the user's home directory
  def self.user_dir
    parts = [Gem.user_home, '.gem', ruby_engine]
    parts << RbConfig::CONFIG['ruby_version'] unless RbConfig::CONFIG['ruby_version'].empty?
    File.join parts
  end
  ##
  # How String Gem paths should be split.  Overridable for esoteric platforms.
  def self.path_separator
    File::PATH_SEPARATOR
  end
  ##
  # Default gem load path
  def self.default_path
    path = []
    path << user_dir if user_home && File.exist?(user_home)
    path << default_dir
    path << vendor_dir if vendor_dir and File.directory? vendor_dir
    path
  end
  ##
  # Deduce Ruby's --program-prefix and --program-suffix from its install name
  def self.default_exec_format
    exec_format = RbConfig::CONFIG['ruby_install_name'].sub('ruby', '%s') rescue '%s'
    unless exec_format =~ /%s/
      raise Gem::Exception,
        "[BUG] invalid exec_format #{exec_format.inspect}, no %s"
    end
    exec_format
  end
  ##
  # The default directory for binaries
  def self.default_bindir
    if defined? RUBY_FRAMEWORK_VERSION  # mac framework support
      '/usr/bin'
    else # generic install
      RbConfig::CONFIG['bindir']
    end
  end
  def self.ruby_engine
    RUBY_ENGINE
  end
  ##
  # The default signing key path
  def self.default_key_path
    File.join Gem.user_home, ".gem", "gem-private_key.pem"
  end
  ##
  # The default signing certificate chain path
  def self.default_cert_path
    File.join Gem.user_home, ".gem", "gem-public_cert.pem"
  end
  ##
  # Install extensions into lib as well as into the extension directory.
  def self.install_extension_in_lib # :nodoc:
    true
  end
  ##
  # Directory where vendor gems are installed.
  def self.vendor_dir # :nodoc:
    if vendor_dir = ENV['GEM_VENDOR']
      return vendor_dir.dup
    end
    return nil unless RbConfig::CONFIG.key? 'vendordir'
    File.join RbConfig::CONFIG['vendordir'], 'gems',
              RbConfig::CONFIG['ruby_version']
  end
  ##
  # Default options for gem commands for Ruby packagers.
  #
  # The options here should be structured as an array of string "gem"
  # command names as keys and a string of the default options as values.
  #
  # Example:
  #
  # def self.operating_system_defaults
  #   {
  #       'install' => '--no-rdoc --no-ri --env-shebang',
  #       'update' => '--no-rdoc --no-ri --env-shebang'
  #   }
  # end
  def self.operating_system_defaults
    {}
  end
  ##
  # Default options for gem commands for Ruby implementers.
  #
  # The options here should be structured as an array of string "gem"
  # command names as keys and a string of the default options as values.
  #
  # Example:
  #
  # def self.platform_defaults
  #   {
  #       'install' => '--no-rdoc --no-ri --env-shebang',
  #       'update' => '--no-rdoc --no-ri --env-shebang'
  #   }
  # end
  def self.platform_defaults
    {}
  end
end