Class: RDoc::Markup::ToRdoc
| Relationships & Source Files | |
| Extension / Inclusion / Inheritance Descendants | |
|
Subclasses:
|
|
| Super Chains via Extension / Inclusion / Inheritance | |
|
Class Chain:
self,
Formatter
|
|
|
Instance Chain:
self,
Formatter
|
|
| Inherits: |
RDoc::Markup::Formatter
|
| Defined in: | lib/rdoc/markup/to_rdoc.rb |
Overview
Outputs RDoc markup as ::RDoc::RDoc markup! (mostly)
Constant Summary
-
DEFAULT_HEADINGS =
# File 'lib/rdoc/markup/to_rdoc.rb', line 6{ 1 => ['= ', ''], 2 => ['== ', ''], 3 => ['=== ', ''], 4 => ['==== ', ''], 5 => ['===== ', ''], 6 => ['====== ', ''] }
Class Method Summary
-
.new(markup = nil) ⇒ ToRdoc
constructor
Creates a new formatter that will output (mostly) RDoc markup.
Formatter - Inherited
| .gen_relative_url | Converts a target url to one that is relative to a given path. |
| .new | Creates a new |
Instance Attribute Summary
-
#indent
rw
Current indent amount for output in characters.
-
#list_index
readonly
Stack of current list indexes for alphabetic and numeric lists.
-
#list_type
readonly
Stack of list types.
-
#list_width
readonly
Stack of list widths for indentation.
-
#prefix
readonly
Prefix for the next list item.
-
#res
readonly
Output accumulator.
-
#width
rw
Output width in characters.
Instance Method Summary
-
#accept_blank_line(blank_line)
Adds
blank_lineto the output. -
#accept_block_quote(block_quote)
Adds
paragraphto the output. -
#accept_heading(heading)
Adds
headingto the output. -
#accept_indented_paragraph(paragraph)
Adds
paragraphto the output. -
#accept_list_end(list)
Finishes consumption of
list -
#accept_list_item_end(list_item)
Finishes consumption of
list_item -
#accept_list_item_start(list_item)
Prepares the visitor for consuming
list_item -
#accept_list_start(list)
Prepares the visitor for consuming
list -
#accept_paragraph(paragraph)
Adds
paragraphto the output. -
#accept_raw(raw)
Adds
rawto the output. -
#accept_rule(rule)
Adds
ruleto the output. -
#accept_table(header, body, aligns)
Adds
tableto the output. -
#accept_verbatim(verbatim)
Outputs
verbatimindented 2 columns. - #add_text(text)
-
#attributes(text)
Applies attribute-specific markup to
textusingInlineParser - #calculate_text_width(text)
- #emit_inline(text)
-
#end_accepting
Returns the generated output.
- #handle_BOLD(target)
- #handle_BOLD_WORD(word)
- #handle_EM(target)
- #handle_EM_WORD(word)
- #handle_HARD_BREAK
- #handle_inline(text, initial_attributes = [])
- #handle_PLAIN_TEXT(text)
- #handle_REGEXP_HANDLING_TEXT(text)
-
#handle_regexp_SUPPRESSED_CROSSREF(text)
Removes preceding \ from the suppressed crossref
target - #handle_STRIKE(target)
- #handle_TIDYLINK(label_part, url)
- #handle_TT(code)
- #off(attr)
- #on(attr)
-
#start_accepting
Prepares the visitor for text generation.
-
#use_prefix
Adds the stored #prefix to the output and clears it.
-
#wrap(text)
Wraps
textto #width
Formatter - Inherited
| #accept_document | Adds |
| #add_regexp_handling_RDOCLINK | Adds a regexp handling for links of the form rdoc-…: |
| #annotate | Allows |
| #apply_regexp_handling | Applies regexp handling to |
| #convert | Marks up |
| #convert_string | Converts a string to be fancier if desired. |
| #handle_BOLD | Called when processing bold nodes while traversing inline nodes from handle_inline. |
| #handle_BOLD_WORD | Called when processing bold word nodes while traversing inline nodes from handle_inline. |
| #handle_EM | Called when processing emphasis nodes while traversing inline nodes from handle_inline. |
| #handle_EM_WORD | Called when processing emphasis word nodes while traversing inline nodes from handle_inline. |
| #handle_HARD_BREAK | Called when processing a hard break while traversing inline nodes from handle_inline. |
| #handle_inline | Parses inline |
| #handle_PLAIN_TEXT | Called when processing plain text while traversing inline nodes from handle_inline. |
| #handle_REGEXP_HANDLING_TEXT | Called when processing regexp-handling-processed text while traversing inline nodes from handle_inline. |
| #handle_STRIKE | Called when processing strike nodes while traversing inline nodes from handle_inline. |
| #handle_TEXT | Called when processing text node while traversing inline nodes from handle_inline. |
| #handle_TIDYLINK | Called when processing tidylink nodes while traversing inline nodes from handle_inline. |
| #handle_TT | Called when processing tt nodes while traversing inline nodes from handle_inline. |
| #ignore | Use ignore in your subclass to ignore the content of a node. |
| #parse_url | Extracts and a scheme, url and an anchor id from |
| #traverse_inline_nodes | Traverses |
| #tt? | Is |
Constructor Details
.new(markup = nil) ⇒ ToRdoc
Creates a new formatter that will output (mostly) RDoc markup
# File 'lib/rdoc/markup/to_rdoc.rb', line 55
def initialize(markup = nil) super nil, markup @markup.add_regexp_handling(/\\\S/, :SUPPRESSED_CROSSREF) @width = 78 @headings = DEFAULT_HEADINGS.dup @hard_break = "\n" end
Instance Attribute Details
#indent (rw)
Current indent amount for output in characters
# File 'lib/rdoc/markup/to_rdoc.rb', line 20
attr_accessor :indent
#list_index (readonly)
Stack of current list indexes for alphabetic and numeric lists
# File 'lib/rdoc/markup/to_rdoc.rb', line 30
attr_reader :list_index
#list_type (readonly)
Stack of list types
# File 'lib/rdoc/markup/to_rdoc.rb', line 35
attr_reader :list_type
#list_width (readonly)
Stack of list widths for indentation
# File 'lib/rdoc/markup/to_rdoc.rb', line 40
attr_reader :list_width
#prefix (readonly)
Prefix for the next list item. See #use_prefix
# File 'lib/rdoc/markup/to_rdoc.rb', line 45
attr_reader :prefix
#res (readonly)
Output accumulator
# File 'lib/rdoc/markup/to_rdoc.rb', line 50
attr_reader :res
#width (rw)
Output width in characters
# File 'lib/rdoc/markup/to_rdoc.rb', line 25
attr_accessor :width
Instance Method Details
#accept_blank_line(blank_line)
Adds blank_line to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 68
def accept_blank_line(blank_line) @res << "\n" end
#accept_block_quote(block_quote)
Adds paragraph to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 75
def accept_block_quote(block_quote) @indent += 2 block_quote.parts.each do |part| @prefix = '> ' part.accept self end @indent -= 2 end
#accept_heading(heading)
Adds heading to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 90
def accept_heading(heading) use_prefix or @res << ' ' * @indent @res << @headings[heading.level][0] @res << attributes(heading.text) @res << @headings[heading.level][1] @res << "\n" end
#accept_indented_paragraph(paragraph)
Adds paragraph to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 202
def accept_indented_paragraph(paragraph) @indent += paragraph.indent text = paragraph.text @hard_break wrap attributes text @indent -= paragraph.indent end
#accept_list_end(list)
Finishes consumption of list
# File 'lib/rdoc/markup/to_rdoc.rb', line 101
def accept_list_end(list) @list_index.pop @list_type.pop @list_width.pop end
#accept_list_item_end(list_item)
Finishes consumption of list_item
# File 'lib/rdoc/markup/to_rdoc.rb', line 110
def accept_list_item_end(list_item) width = case @list_type.last when :BULLET then 2 when :NOTE, :LABEL then if @prefix then @res << @prefix.strip @prefix = nil end @res << "\n" 2 else bullet = @list_index.last.to_s @list_index[-1] = @list_index.last.succ bullet.length + 2 end @indent -= width end
#accept_list_item_start(list_item)
Prepares the visitor for consuming list_item
# File 'lib/rdoc/markup/to_rdoc.rb', line 134
def accept_list_item_start(list_item) type = @list_type.last case type when :NOTE, :LABEL then stripped_labels = Array(list_item.label).map do |label| attributes(label).strip end bullets = case type when :NOTE stripped_labels.map { |b| "#{b}::" } when :LABEL stripped_labels.map { |b| "[#{b}]" } end bullets = bullets.join("\n") bullets << "\n" unless stripped_labels.empty? @prefix = ' ' * @indent @indent += 2 @prefix << bullets + (' ' * @indent) else bullet = type == :BULLET ? '*' : @list_index.last.to_s + '.' @prefix = (' ' * @indent) + bullet.ljust(bullet.length + 1) width = bullet.length + 1 @indent += width end end
#accept_list_start(list)
Prepares the visitor for consuming list
# File 'lib/rdoc/markup/to_rdoc.rb', line 167
def accept_list_start(list) case list.type when :BULLET then @list_index << nil @list_width << 1 when :LABEL, :NOTE then @list_index << nil @list_width << 2 when :LALPHA then @list_index << 'a' @list_width << list.items.length.to_s.length when :NUMBER then @list_index << 1 @list_width << list.items.length.to_s.length when :UALPHA then @list_index << 'A' @list_width << list.items.length.to_s.length else raise RDoc::Error, "invalid list type #{list.type}" end @list_type << list.type end
#accept_paragraph(paragraph)
Adds paragraph to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 194
def accept_paragraph(paragraph) text = paragraph.text @hard_break wrap attributes text end
#accept_raw(raw)
Adds raw to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 212
def accept_raw(raw) @res << raw.parts.join("\n") end
#accept_rule(rule)
Adds rule to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 219
def accept_rule(rule) use_prefix or @res << ' ' * @indent @res << '-' * (@width - @indent) @res << "\n" end
#accept_table(header, body, aligns)
Adds table to the output
# File 'lib/rdoc/markup/to_rdoc.rb', line 242
def accept_table(header, body, aligns) header = header.map { |h| attributes h } body = body.map { |row| row.map { |t| attributes t } } widths = header.zip(*body).map do |cols| cols.compact.map { |col| calculate_text_width(col) }.max end aligns = aligns.map do |a| case a when nil, :center :center when :left :ljust when :right :rjust end end @res << header.zip(widths, aligns).map do |h, w, a| extra_width = h.size - calculate_text_width(h) h.__send__(a, w + extra_width) end.join("|").rstrip << "\n" @res << widths.map {|w| "-" * w }.join("|") << "\n" body.each do |row| @res << widths.zip(aligns).each_with_index.map do |(w, a), i| t = row[i] || "" extra_width = t.size - calculate_text_width(t) t.__send__(a, w + extra_width) end.join("|").rstrip << "\n" end end
#accept_verbatim(verbatim)
Outputs verbatim indented 2 columns
#add_text(text)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 347
def add_text(text) emit_inline(text) end
#attributes(text)
Applies attribute-specific markup to text using InlineParser
# File 'lib/rdoc/markup/to_rdoc.rb', line 358
def attributes(text) handle_inline(text) end
#calculate_text_width(text)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 272
def calculate_text_width(text) text.size end
#emit_inline(text)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 351
def emit_inline(text) @inline_output << text end
#end_accepting
Returns the generated output
# File 'lib/rdoc/markup/to_rdoc.rb', line 365
def end_accepting @res.join end
#handle_BOLD(target)
[ GitHub ]#handle_BOLD_WORD(word)
[ GitHub ]#handle_EM(target)
[ GitHub ]#handle_EM_WORD(word)
[ GitHub ]#handle_HARD_BREAK
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 320
def handle_HARD_BREAK add_text("\n") end
#handle_inline(text, initial_attributes = [])
[ GitHub ]#handle_PLAIN_TEXT(text)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 276
def handle_PLAIN_TEXT(text) add_text(text) end
#handle_REGEXP_HANDLING_TEXT(text)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 280
def handle_REGEXP_HANDLING_TEXT(text) add_text(text) end
#handle_regexp_SUPPRESSED_CROSSREF(text)
Removes preceding \ from the suppressed crossref target
# File 'lib/rdoc/markup/to_rdoc.rb', line 372
def handle_regexp_SUPPRESSED_CROSSREF(text) text.sub('\\', '') end
#handle_STRIKE(target)
[ GitHub ]#handle_TIDYLINK(label_part, url)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 324
def handle_TIDYLINK(label_part, url) super add_text("( #{url} )") end
#handle_TT(code)
[ GitHub ]#off(attr)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 342
def off(attr) @attributes[attr] -= 1 @attributes.delete(attr) if @attributes[attr] == 0 end
#on(attr)
[ GitHub ]# File 'lib/rdoc/markup/to_rdoc.rb', line 338
def on(attr) @attributes[attr] += 1 end
#start_accepting
Prepares the visitor for text generation
# File 'lib/rdoc/markup/to_rdoc.rb', line 379
def start_accepting @res = [""] @indent = 0 @prefix = nil @list_index = [] @list_type = [] @list_width = [] end
#use_prefix
Adds the stored #prefix to the output and clears it. Lists generate a prefix for later consumption.
#wrap(text)
Wraps text to #width
# File 'lib/rdoc/markup/to_rdoc.rb', line 403
def wrap(text) return unless text && !text.empty? text_len = @width - @indent text_len = 20 if text_len < 20 next_prefix = ' ' * @indent prefix = @prefix || next_prefix @prefix = nil text.scan(/\G(?:([^ \n]{#{text_len}})(?=[^ \n])|(.{1,#{text_len}})(?:[ \n]|\z))/) do @res << prefix << ($1 || $2) << "\n" prefix = next_prefix end end