Base class for the RDoc
code tree.
We contain the common stuff for contexts (which are containers) and other elements (methods, attributes and so on)
Here’s the tree of the CodeObject
subclasses:
- C
- D
- E
- F
- I
- N
- O
- P
- R
- S
Attributes
[R] | comment | Our comment |
[R] | document_children | Do we document our children? |
[R] | document_self | Do we document ourselves? |
[R] | done_documenting | Are we done documenting (ie, did we come across a :enddoc:)? |
[R] | file | Which file this code object was defined in |
[R] | force_documentation | Force documentation of this |
[RW] | line | Line in |
[R] | metadata |
|
[W] | parent | Sets the parent |
[R] | received_nodoc | Did we ever receive a |
[W] | section |
|
[R] | store | The |
[RW] | viewer | We are the model of the code, but we know that at some point we will be worked on by viewers. By implementing the Viewable protocol, viewers can associated themselves with these objects. |
Class Public methods
new() Link
Creates a new CodeObject
that will document itself and its children
# File ruby/lib/rdoc/code_object.rb, line 102 def initialize @metadata = {} @comment = '' @parent = nil @parent_name = nil # for loading @parent_class = nil # for loading @section = nil @section_title = nil # for loading @file = nil @full_name = nil @store = nil @track_visibility = true initialize_visibility end
Instance Public methods
comment=(comment) Link
Replaces our comment with comment
, unless it is empty.
# File ruby/lib/rdoc/code_object.rb, line 135 def comment=(comment) @comment = case comment when NilClass then '' when RDoc::Markup::Document then comment when RDoc::Comment then comment.normalize else if comment and not comment.empty? then normalize_comment comment else # HACK correct fix is to have #initialize create @comment # with the correct encoding if String === @comment and @comment.empty? then @comment = RDoc::Encoding.change_encoding @comment, comment.encoding end @comment end end end
display?() Link
Should this CodeObject
be displayed in output?
A code object should be displayed if:
-
The item didn’t have a nodoc or wasn’t in a container that had nodoc
-
The item wasn’t ignored
-
The item has documentation and was not suppressed
document_children=(document_children) Link
Enables or disables documentation of this CodeObject’s children unless it has been turned off by :enddoc:
document_self=(document_self) Link
Enables or disables documentation of this CodeObject
unless it has been turned off by :enddoc:. If the argument is nil
it means the documentation is turned off by :nodoc:
.
documented?() Link
Does this object have a comment with content or is received_nodoc
true?
done_documenting=(value) Link
Turns documentation on/off, and turns on/off document_self
and document_children
.
Once documentation has been turned off (by :enddoc:
), the object will refuse to turn document_self
or document_children
on, so :doc:
and :start_doc:
directives will have no effect in the current file.
each_parent() Link
Yields each parent of this CodeObject
. See also RDoc::ClassModule#each_ancestor
file_name() Link
File
name where this CodeObject
was found.
See also RDoc::Context#in_files
force_documentation=(value) Link
Force the documentation of this object unless documentation has been turned off by :enddoc:
full_name=(full_name) Link
Sets the full_name overriding any computed full name.
Set
to nil
to clear RDoc’s cached value
ignore() Link
Use this to ignore a CodeObject
and all its children until found again (record_location
is called). An ignored item will not be displayed in documentation.
See github issue #55
The ignored status is temporary in order to allow implementation details to be hidden. At the end of processing a file RDoc
allows all classes and modules to add new documentation to previously created classes.
If a class was ignored (via stopdoc) then reopened later with additional documentation it should be displayed. If a class was ignored and never reopened it should not be displayed. The ignore flag allows this to occur.
options() Link
The options instance from the store this CodeObject
is attached to, or a default options instance if the CodeObject
is not attached.
This is used by Text#snippet
parent() Link
Our parent CodeObject
. The parent may be missing for classes loaded from legacy RI data stores.
# File ruby/lib/rdoc/code_object.rb, line 309 def parent return @parent if @parent return nil unless @parent_name if @parent_class == RDoc::TopLevel then @parent = @store.add_file @parent_name else @parent = @store.find_class_or_module @parent_name return @parent if @parent begin @parent = @store.load_class @parent_name rescue RDoc::Store::MissingFileError nil end end end
parent_name() Link
Name of our parent
record_location(top_level) Link
Records the RDoc::TopLevel
(file) where this code object was defined
section() Link
The section this CodeObject
is in. Sections allow grouping of constants, attributes and methods inside a class or module.
start_doc() Link
Enable capture of documentation unless documentation has been turned off by :enddoc:
stop_doc() Link
Disable capture of documentation
store=(store) Link
Sets the store
that contains this CodeObject
suppress() Link
Use this to suppress a CodeObject
and all its children until the next file it is seen in or documentation is discovered. A suppressed item with documentation will be displayed while an ignored item with documentation may not be displayed.