mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rdoc*: Updated to RDoc 4.0 (pre-release)
* bin/rdoc: ditto * test/rdoc: ditto * NEWS: Updated with RDoc 4.0 information git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37889 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
c72f0daa87
commit
1c279a7d27
233 changed files with 45019 additions and 5100 deletions
|
@ -1,5 +1,3 @@
|
|||
require 'rdoc/code_object'
|
||||
|
||||
##
|
||||
# A Module include in a class with \#include
|
||||
|
||||
|
@ -17,7 +15,7 @@ class RDoc::Include < RDoc::CodeObject
|
|||
super()
|
||||
@name = name
|
||||
self.comment = comment
|
||||
@module = nil # cache for module if found
|
||||
@module = nil # cache for module if found
|
||||
end
|
||||
|
||||
##
|
||||
|
@ -30,10 +28,11 @@ class RDoc::Include < RDoc::CodeObject
|
|||
end
|
||||
|
||||
def == other # :nodoc:
|
||||
self.class == other.class and
|
||||
self.name == other.name
|
||||
self.class === other and @name == other.name
|
||||
end
|
||||
|
||||
alias eql? ==
|
||||
|
||||
##
|
||||
# Full name based on #module
|
||||
|
||||
|
@ -42,6 +41,10 @@ class RDoc::Include < RDoc::CodeObject
|
|||
RDoc::ClassModule === m ? m.full_name : @name
|
||||
end
|
||||
|
||||
def hash # :nodoc:
|
||||
[@name, self.module].hash
|
||||
end
|
||||
|
||||
def inspect # :nodoc:
|
||||
"#<%s:0x%x %s.include %s>" % [
|
||||
self.class,
|
||||
|
@ -59,6 +62,13 @@ class RDoc::Include < RDoc::CodeObject
|
|||
# - if not found, look into the children of included modules,
|
||||
# in reverse inclusion order;
|
||||
# - if still not found, go up the hierarchy of names.
|
||||
#
|
||||
# This method has <code>O(n!)</code> behavior when the module calling
|
||||
# include is referencing nonexistent modules. Avoid calling #module until
|
||||
# after all the files are parsed. This behavior is due to ruby's constant
|
||||
# lookup behavior.
|
||||
#
|
||||
# As of the beginning of October, 2011, no gem includes nonexistent modules.
|
||||
|
||||
def module
|
||||
return @module if @module
|
||||
|
@ -66,7 +76,7 @@ class RDoc::Include < RDoc::CodeObject
|
|||
# search the current context
|
||||
return @name unless parent
|
||||
full_name = parent.child_name(@name)
|
||||
@module = RDoc::TopLevel.modules_hash[full_name]
|
||||
@module = @store.modules_hash[full_name]
|
||||
return @module if @module
|
||||
return @name if @name =~ /^::/
|
||||
|
||||
|
@ -76,22 +86,31 @@ class RDoc::Include < RDoc::CodeObject
|
|||
inc = i.module
|
||||
next if String === inc
|
||||
full_name = inc.child_name(@name)
|
||||
@module = RDoc::TopLevel.modules_hash[full_name]
|
||||
@module = @store.modules_hash[full_name]
|
||||
return @module if @module
|
||||
end
|
||||
|
||||
# go up the hierarchy of names
|
||||
p = parent.parent
|
||||
while p
|
||||
full_name = p.child_name(@name)
|
||||
@module = RDoc::TopLevel.modules_hash[full_name]
|
||||
up = parent.parent
|
||||
while up
|
||||
full_name = up.child_name(@name)
|
||||
@module = @store.modules_hash[full_name]
|
||||
return @module if @module
|
||||
p = p.parent
|
||||
up = up.parent
|
||||
end
|
||||
|
||||
@name
|
||||
end
|
||||
|
||||
##
|
||||
# Sets the store for this class or module and its contained code objects.
|
||||
|
||||
def store= store
|
||||
super
|
||||
|
||||
@file = @store.add_file @file.full_name if @file
|
||||
end
|
||||
|
||||
def to_s # :nodoc:
|
||||
"include #@name in: #{parent}"
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue