class Gem::GemRunner

Run an instance of the gem program.

Gem::GemRunner is only intended for internal use by RubyGems itself. It does not form any public API and may change at any time for any reason.

If you would like to duplicate functionality of `gem` commands, use the classes they call directly.

Public Class Methods

new(options={}) click to toggle source
# File lib/rubygems/gem_runner.rb, line 27
def initialize(options={})
  # TODO: nuke these options
  @command_manager_class = options[:command_manager] || Gem::CommandManager
  @config_file_class = options[:config_file] || Gem::ConfigFile
end

Public Instance Methods

run(args) click to toggle source

Run the gem command with the following arguments.

# File lib/rubygems/gem_runner.rb, line 36
def run(args)
  if args.include?('--')
    # We need to preserve the original ARGV to use for passing gem options
    # to source gems.  If there is a -- in the line, strip all options after
    # it...its for the source building process.
    # TODO use slice!
    build_args = args[args.index("--") + 1...args.length]
    args = args[0...args.index("--")]
  end

  do_configuration args
  cmd = @command_manager_class.instance

  cmd.command_names.each do |command_name|
    config_args = Gem.configuration[command_name]
    config_args = case config_args
                  when String
                    config_args.split ' '
                  else
                    Array(config_args)
                  end
    Gem::Command.add_specific_extra_args command_name, config_args
  end

  cmd.run Gem.configuration.args, build_args
end

Private Instance Methods

do_configuration(args) click to toggle source
# File lib/rubygems/gem_runner.rb, line 65
def do_configuration(args)
  Gem.configuration = @config_file_class.new(args)
  Gem.use_paths Gem.configuration[:gemhome], Gem.configuration[:gempath]
  Gem::Command.extra_args = Gem.configuration[:gem]
end