mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
1c279a7d27
* 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
134 lines
2.5 KiB
Ruby
134 lines
2.5 KiB
Ruby
# :markup: markdown
|
|
|
|
##
|
|
# Outputs parsed markup as Markdown
|
|
|
|
class RDoc::Markup::ToMarkdown < RDoc::Markup::ToRdoc
|
|
|
|
##
|
|
# Creates a new formatter that will output Markdown format text
|
|
|
|
def initialize markup = nil
|
|
super
|
|
|
|
@headings[1] = ['# ', '']
|
|
@headings[2] = ['## ', '']
|
|
@headings[3] = ['### ', '']
|
|
@headings[4] = ['#### ', '']
|
|
@headings[5] = ['##### ', '']
|
|
@headings[6] = ['###### ', '']
|
|
|
|
@hard_break = " \n"
|
|
end
|
|
|
|
##
|
|
# Maps attributes to HTML sequences
|
|
|
|
def init_tags
|
|
add_tag :BOLD, '**', '**'
|
|
add_tag :EM, '*', '*'
|
|
add_tag :TT, '`', '`'
|
|
end
|
|
|
|
##
|
|
# Adds a newline to the output
|
|
|
|
def handle_special_HARD_BREAK special
|
|
" \n"
|
|
end
|
|
|
|
##
|
|
# Finishes consumption of `list`
|
|
|
|
def accept_list_end list
|
|
@res << "\n"
|
|
|
|
super
|
|
end
|
|
|
|
##
|
|
# Finishes consumption of `list_item`
|
|
|
|
def accept_list_item_end list_item
|
|
width = case @list_type.last
|
|
when :BULLET then
|
|
4
|
|
when :NOTE, :LABEL then
|
|
use_prefix
|
|
|
|
4
|
|
else
|
|
@list_index[-1] = @list_index.last.succ
|
|
4
|
|
end
|
|
|
|
@indent -= width
|
|
end
|
|
|
|
##
|
|
# Prepares the visitor for consuming `list_item`
|
|
|
|
def accept_list_item_start list_item
|
|
type = @list_type.last
|
|
|
|
case type
|
|
when :NOTE, :LABEL then
|
|
bullets = Array(list_item.label).map do |label|
|
|
attributes(label).strip
|
|
end.join "\n"
|
|
|
|
bullets << "\n:"
|
|
|
|
@prefix = ' ' * @indent
|
|
@indent += 4
|
|
@prefix << bullets + (' ' * (@indent - 1))
|
|
else
|
|
bullet = type == :BULLET ? '*' : @list_index.last.to_s + '.'
|
|
@prefix = (' ' * @indent) + bullet.ljust(4)
|
|
|
|
@indent += 4
|
|
end
|
|
end
|
|
|
|
##
|
|
# Prepares the visitor for consuming `list`
|
|
|
|
def accept_list_start list
|
|
case list.type
|
|
when :BULLET, :LABEL, :NOTE then
|
|
@list_index << nil
|
|
when :LALPHA, :NUMBER, :UALPHA then
|
|
@list_index << 1
|
|
else
|
|
raise RDoc::Error, "invalid list type #{list.type}"
|
|
end
|
|
|
|
@list_width << 4
|
|
@list_type << list.type
|
|
end
|
|
|
|
##
|
|
# Adds `rule` to the output
|
|
|
|
def accept_rule rule
|
|
use_prefix or @res << ' ' * @indent
|
|
@res << '-' * 3
|
|
@res << "\n"
|
|
end
|
|
|
|
##
|
|
# Outputs `verbatim` indented 4 columns
|
|
|
|
def accept_verbatim verbatim
|
|
indent = ' ' * (@indent + 4)
|
|
|
|
verbatim.parts.each do |part|
|
|
@res << indent unless part == "\n"
|
|
@res << part
|
|
end
|
|
|
|
@res << "\n" unless @res =~ /\n\z/
|
|
end
|
|
|
|
end
|
|
|