diff options
Diffstat (limited to 'lib/rubygems/gem_runner.rb')
| -rw-r--r-- | lib/rubygems/gem_runner.rb | 48 |
1 files changed, 27 insertions, 21 deletions
diff --git a/lib/rubygems/gem_runner.rb b/lib/rubygems/gem_runner.rb index fec9e403da..e60cebd0cb 100644 --- a/lib/rubygems/gem_runner.rb +++ b/lib/rubygems/gem_runner.rb @@ -1,18 +1,13 @@ # frozen_string_literal: true + #-- # Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others. # All rights reserved. # See LICENSE.txt for permissions. #++ -require 'rubygems' -require 'rubygems/command_manager' -require 'rubygems/config_file' - -## -# Load additional plugins from $LOAD_PATH - -Gem.load_env_plugins rescue nil +require_relative "../rubygems" +require_relative "command_manager" ## # Run an instance of the gem program. @@ -24,31 +19,37 @@ Gem.load_env_plugins rescue nil # classes they call directly. class Gem::GemRunner - - def initialize(options={}) - # TODO: nuke these options - @command_manager_class = options[:command_manager] || Gem::CommandManager - @config_file_class = options[:config_file] || Gem::ConfigFile + def initialize + @command_manager_class = Gem::CommandManager + @config_file_class = Gem::ConfigFile end ## # Run the gem command with the following arguments. - def run args + def run(args) + validate_encoding args build_args = extract_build_args args do_configuration args + begin + Gem.load_env_plugins + rescue StandardError + nil + end + Gem.load_plugins + 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 ' ' + config_args.split " " else Array(config_args) - end + end Gem::Command.add_specific_extra_args command_name, config_args end @@ -59,8 +60,8 @@ class Gem::GemRunner # Separates the build arguments (those following <code>--</code>) from the # other arguments in the list. - def extract_build_args args # :nodoc: - return [] unless offset = args.index('--') + def extract_build_args(args) # :nodoc: + return [] unless offset = args.index("--") build_args = args.slice!(offset...args.length) @@ -71,12 +72,17 @@ class Gem::GemRunner private + def validate_encoding(args) + invalid_arg = args.find {|arg| !arg.valid_encoding? } + + if invalid_arg + raise Gem::OptionParser::InvalidArgument.new("'#{invalid_arg.scrub}' has invalid encoding") + end + end + 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 - end - -Gem.load_plugins |
