forked from github/markup
-
Notifications
You must be signed in to change notification settings - Fork 0
/
markups.rb
40 lines (31 loc) · 1.2 KB
/
markups.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
require "github/markup/markdown"
markups << GitHub::Markup::Markdown.new
markup(:redcloth, /textile/) do |content|
RedCloth.new(content).to_html
end
markup('github/markup/rdoc', /rdoc/) do |content|
GitHub::Markup::RDoc.new(content).to_html
end
markup('org-ruby', /org/) do |content|
Orgmode::Parser.new(content).to_html
end
markup(:creole, /creole/) do |content|
Creole.creolize(content)
end
markup(:wikicloth, /mediawiki|wiki/) do |content|
WikiCloth::WikiCloth.new(:data => content).to_html(:noedit => true)
end
markup(:asciidoctor, /adoc|asc(iidoc)?/) do |content|
Asciidoctor.render(content, :safe => :secure, :attributes => %w(showtitle idprefix idseparator=- env=github env-github source-highlighter=html-pipeline))
end
command("python2 -S #{File.dirname(__FILE__)}/commands/rest2html", /re?st(\.txt)?/)
# pod2html is nice enough to generate a full-on HTML document for us,
# so we return the favor by ripping out the good parts.
#
# Any block passed to `command` will be handed the command's STDOUT for
# post processing.
command('/usr/bin/env perl -MPod::Simple::HTML -e Pod::Simple::HTML::go', /pod/) do |rendered|
if rendered =~ /<!-- start doc -->\s*(.+)\s*<!-- end doc -->/mi
$1
end
end