aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--commonmark.rb18
1 files changed, 16 insertions, 2 deletions
diff --git a/commonmark.rb b/commonmark.rb
index 7c9c6d2..4546845 100644
--- a/commonmark.rb
+++ b/commonmark.rb
@@ -23,10 +23,11 @@ module CMark
attach_function :cmark_node_previous, [:node], :node
attach_function :cmark_node_get_type, [:node], :node_type
attach_function :cmark_node_get_string_content, [:node], :string
+ attach_function :cmark_node_get_header_level, [:node], :int
end
class Node
- attr_accessor :type, :children, :string_content, :pointer
+ attr_accessor :type, :children, :string_content, :header_level
def initialize(pointer)
if pointer.null?
return nil
@@ -41,6 +42,7 @@ class Node
b = CMark::cmark_node_next(b)
end
@string_content = CMark::cmark_node_get_string_content(pointer)
+ @header_level = CMark::cmark_node_get_header_level(pointer)
if @type == :document
self.free
end
@@ -72,7 +74,7 @@ class Renderer
end
def out(arg)
- @stream.puts(arg)
+ @stream.write(arg)
end
def render(node)
@@ -84,6 +86,8 @@ class Renderer
end
when :paragraph
self.paragraph(node.children)
+ when :setext_header, :atx_header
+ self.header(node.header_level, node.children)
when :str
self.str(node.string_content)
else
@@ -95,6 +99,10 @@ class Renderer
children.each { |x| render(x) }
end
+ def header(level, children)
+ children.each { |x| render(x) }
+ end
+
def paragraph(children)
children.each { |x| render(x) }
end
@@ -105,6 +113,12 @@ class Renderer
end
class HtmlRenderer < Renderer
+ def header(level, children)
+ self.outf("<h%d>", level)
+ children.each { |x| render(x) }
+ self.outf("</h%d>\n", level)
+ end
+
def paragraph(children)
self.out("<p>")
children.each { |x| render(x) }