class Gem::GemRunner
Führt eine Instanz des Gem-Programms aus.
Gem::GemRunner ist nur für die interne Verwendung von RubyGems selbst vorgesehen. Es bildet keine öffentliche API und kann sich jederzeit aus beliebigen Gründen ändern.
Wenn Sie die Funktionalität von „gem“-Befehlen duplizieren möchten, verwenden Sie die Klassen, die sie direkt aufrufen.
Öffentliche Klassenmethoden
Source
# File lib/rubygems/gem_runner.rb, line 22 def initialize @command_manager_class = Gem::CommandManager @config_file_class = Gem::ConfigFile end
Öffentliche Instanzmethoden
Source
# File lib/rubygems/gem_runner.rb, line 30 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 " " else Array(config_args) end Gem::Command.add_specific_extra_args command_name, config_args end cmd.run Gem.configuration.args, build_args end
Führt den Gem-Befehl mit den folgenden Argumenten aus.
Private Instanzmethoden
Source
# File lib/rubygems/gem_runner.rb, line 83 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
Source
# File lib/rubygems/gem_runner.rb, line 75 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