Class: RDoc::Context::Section
- Inherits:
-
Object
- Object
- RDoc::Context::Section
- Includes:
- Generator::Markup, Text
- Defined in:
- lib/rdoc/code_object/context/section.rb,
lib/rdoc/generator/markup.rb
Overview
A section of documentation like:
# :section: The title
# The body
Sections can be referenced multiple times and will be collapsed into a single section.
Constant Summary collapse
- MARSHAL_VERSION =
:nodoc:
0
Constants included from Text
Text::MARKUP_FORMAT, Text::SPACE_SEPARATED_LETTER_CLASS, Text::TO_HTML_CHARACTERS
Instance Attribute Summary collapse
-
#comment ⇒ Object
readonly
Section comment.
-
#comments ⇒ Object
readonly
Section comments.
-
#parent ⇒ Object
readonly
Context this Section lives in.
-
#title ⇒ Object
readonly
Section title.
Attributes included from Text
Instance Method Summary collapse
-
#==(other) ⇒ Object
(also: #eql?)
Sections are equal when they have the same #title.
-
#add_comment(comment) ⇒ Object
Adds
comment
to this section. -
#aref ⇒ Object
Anchor reference for linking to this section.
-
#extract_comment(comment) ⇒ Object
Extracts the comment for this section from the original comment block.
-
#hash ⇒ Object
:nodoc:.
-
#in_files ⇒ Object
The files comments in this section come from.
-
#initialize(parent, title, comment) ⇒ Section
constructor
Creates a new section with
title
andcomment
. -
#inspect ⇒ Object
:nodoc:.
-
#marshal_dump ⇒ Object
Serializes this Section.
-
#marshal_load(array) ⇒ Object
De-serializes this Section.
-
#parse ⇒ Object
Parses
comment_location
into an RDoc::Markup::Document composed of multiple RDoc::Markup::Documents with their file set. -
#plain_html ⇒ Object
The section’s title, or ‘Top Section’ if the title is nil.
-
#remove_comment(target_comment) ⇒ Object
Removes a comment from this section if it is from the same file as
comment
.
Methods included from Generator::Markup
#aref_to, #as_href, #canonical_url, #cvs_url, #description, #formatter
Methods included from Text
encode_fallback, #expand_tabs, #flush_left, #markup, #normalize_comment, #snippet, #strip_hashes, #strip_newlines, #strip_stars, #to_html, #wrap
Constructor Details
#initialize(parent, title, comment) ⇒ Section
Creates a new section with title
and comment
43 44 45 46 47 48 49 50 |
# File 'lib/rdoc/code_object/context/section.rb', line 43 def initialize(parent, title, comment) @parent = parent @title = title ? title.strip : title @comments = [] add_comment comment end |
Instance Attribute Details
#comment ⇒ Object (readonly)
Section comment
23 24 25 |
# File 'lib/rdoc/code_object/context/section.rb', line 23 def comment @comment end |
#comments ⇒ Object (readonly)
Section comments
28 29 30 |
# File 'lib/rdoc/code_object/context/section.rb', line 28 def comments @comments end |
#parent ⇒ Object (readonly)
Context this Section lives in
33 34 35 |
# File 'lib/rdoc/code_object/context/section.rb', line 33 def parent @parent end |
#title ⇒ Object (readonly)
Section title
38 39 40 |
# File 'lib/rdoc/code_object/context/section.rb', line 38 def title @title end |
Instance Method Details
#==(other) ⇒ Object Also known as: eql?
Sections are equal when they have the same #title
55 56 57 |
# File 'lib/rdoc/code_object/context/section.rb', line 55 def ==(other) self.class === other and @title == other.title end |
#add_comment(comment) ⇒ Object
Adds comment
to this section
64 65 66 67 68 69 70 |
# File 'lib/rdoc/code_object/context/section.rb', line 64 def add_comment(comment) comments = Array(comment) comments.each do |c| extracted_comment = extract_comment(c) @comments << extracted_comment unless extracted_comment.empty? end end |
#aref ⇒ Object
Anchor reference for linking to this section
75 76 77 78 79 |
# File 'lib/rdoc/code_object/context/section.rb', line 75 def aref title = @title || '[untitled]' CGI.escape(title).gsub('%', '-').sub(/^-/, '') end |
#extract_comment(comment) ⇒ Object
Extracts the comment for this section from the original comment block. If the first line contains :section:, strip it and use the rest. Otherwise remove lines up to the line containing :section:, and look for those lines again at the end and remove them. This lets us write
# :section: The title
# The body
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/rdoc/code_object/context/section.rb', line 90 def extract_comment(comment) case comment when nil RDoc::Comment.new '' when RDoc::Comment then if comment.text =~ /^#[ \t]*:section:.*\n/ then start = $` rest = $' comment.text = if start.empty? then rest else rest.sub(/#{start.chomp}\Z/, '') end end comment else raise TypeError, "unknown comment #{comment.inspect}" end end |
#hash ⇒ Object
:nodoc:
116 117 118 |
# File 'lib/rdoc/code_object/context/section.rb', line 116 def hash # :nodoc: @title.hash end |
#in_files ⇒ Object
The files comments in this section come from
123 124 125 |
# File 'lib/rdoc/code_object/context/section.rb', line 123 def in_files @comments.map(&:file) end |
#inspect ⇒ Object
:nodoc:
112 113 114 |
# File 'lib/rdoc/code_object/context/section.rb', line 112 def inspect # :nodoc: "#<%s:0x%x %p>" % [self.class, object_id, title] end |
#marshal_dump ⇒ Object
Serializes this Section. The title and parsed comment are saved, but not the section parent which must be restored manually.
131 132 133 134 135 136 137 |
# File 'lib/rdoc/code_object/context/section.rb', line 131 def marshal_dump [ MARSHAL_VERSION, @title, parse, ] end |
#marshal_load(array) ⇒ Object
De-serializes this Section. The section parent must be restored manually.
142 143 144 145 146 147 |
# File 'lib/rdoc/code_object/context/section.rb', line 142 def marshal_load(array) @parent = nil @title = array[1] @comments = array[2].parts.map { |doc| RDoc::Comment.from_document(doc) } end |
#parse ⇒ Object
Parses comment_location
into an RDoc::Markup::Document composed of multiple RDoc::Markup::Documents with their file set.
153 154 155 |
# File 'lib/rdoc/code_object/context/section.rb', line 153 def parse RDoc::Markup::Document.new(*@comments.map(&:parse)) end |
#plain_html ⇒ Object
The section’s title, or ‘Top Section’ if the title is nil.
This is used by the table of contents template so the name is silly.
162 163 164 |
# File 'lib/rdoc/code_object/context/section.rb', line 162 def plain_html @title || 'Top Section' end |
#remove_comment(target_comment) ⇒ Object
Removes a comment from this section if it is from the same file as comment
170 171 172 173 174 |
# File 'lib/rdoc/code_object/context/section.rb', line 170 def remove_comment(target_comment) @comments.delete_if do |stored_comment| stored_comment.file == target_comment.file end end |