diff options
author | dave <dave@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-01-07 04:05:25 +0000 |
---|---|---|
committer | dave <dave@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-01-07 04:05:25 +0000 |
commit | 6a194f195c7ff16dedf6d95fd90f37cb3c9de336 (patch) | |
tree | 5c986a39e53d0f57c58f143bb158697869d4096f /lib/rdoc/ri/ri_driver.rb | |
parent | 7f4ca79e6ca4b8ece270acb77aaf9a7ba3f88b4b (diff) | |
download | ruby-6a194f195c7ff16dedf6d95fd90f37cb3c9de336.tar.gz |
Fix problem with agreesive name matching (see ChangeLog)
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@5396 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rdoc/ri/ri_driver.rb')
-rw-r--r-- | lib/rdoc/ri/ri_driver.rb | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/lib/rdoc/ri/ri_driver.rb b/lib/rdoc/ri/ri_driver.rb index 0ca3b4c224..039a152c84 100644 --- a/lib/rdoc/ri/ri_driver.rb +++ b/lib/rdoc/ri/ri_driver.rb @@ -52,18 +52,18 @@ class RiDriver ###################################################################### - def report_class_stuff(requested_class_name, namespaces) + def report_class_stuff(namespaces) if namespaces.size == 1 klass = @ri_reader.get_class(namespaces[0]) @display.display_class_info(klass, @ri_reader) else - entries = namespaces.find_all {|m| m.full_name == requested_class_name} - if entries.size == 1 - klass = @ri_reader.get_class(entries[0]) - @display.display_class_info(klass, @ri_reader) - else +# entries = namespaces.find_all {|m| m.full_name == requested_class_name} +# if entries.size == 1 +# klass = @ri_reader.get_class(entries[0]) +# @display.display_class_info(klass, @ri_reader) +# else @display.display_class_list(namespaces) - end +# end end end @@ -81,9 +81,16 @@ class RiDriver raise RiError.new("Nothing known about #{arg}") end end - + + # at this point, if we have multiple possible namespaces, but one + # is an exact match for our requested class, prune down to just it + + full_class_name = desc.full_class_name + entries = namespaces.find_all {|m| m.full_name == full_class_name} + namespaces = entries if entries.size == 1 + if desc.method_name.nil? - report_class_stuff(desc.class_names.join('::'), namespaces) + report_class_stuff(namespaces) else methods = @ri_reader.find_methods(desc.method_name, desc.is_class_method, |