diff options
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | lib/rubygems/command_manager.rb | 7 |
2 files changed, 8 insertions, 4 deletions
@@ -1,4 +1,7 @@ -Wed Dec 30 17:45:53 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> +Wed Dec 30 17:49:47 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * lib/rubygems/command_manager.rb (Gem#load_and_instantiate): + rescue only NameError from const_get. * lib/rubygems/source_index.rb (Gem#load_specification): don't use RUBY_VERSION to branch. diff --git a/lib/rubygems/command_manager.rb b/lib/rubygems/command_manager.rb index 0a190161ca..cd1fd6b568 100644 --- a/lib/rubygems/command_manager.rb +++ b/lib/rubygems/command_manager.rb @@ -154,11 +154,12 @@ class Gem::CommandManager def load_and_instantiate(command_name) command_name = command_name.to_s + const_name = command_name.capitalize.gsub(/_(.)/) { $1.upcase } << "Command" + commands = Gem::Commands retried = false begin - const_name = command_name.capitalize.gsub(/_(.)/) { $1.upcase } - Gem::Commands.const_get("#{const_name}Command").new + commands.const_get(const_name) rescue NameError if retried then raise @@ -167,7 +168,7 @@ class Gem::CommandManager require "rubygems/commands/#{command_name}_command" retry end - end + end.new end end |