Class: Makeup::Markup
- Inherits:
-
Object
- Object
- Makeup::Markup
- Defined in:
- lib/makeup/markup.rb
Class Method Summary collapse
Instance Method Summary collapse
- #highlight_code_blocks(path, markup) ⇒ Object
-
#initialize(options = {}) ⇒ Markup
constructor
A new instance of Markup.
- #render(path, content) ⇒ Object
- #sanitize(html) ⇒ Object
Constructor Details
#initialize(options = {}) ⇒ Markup
Returns a new instance of Markup.
53 54 55 56 |
# File 'lib/makeup/markup.rb', line 53 def initialize( = {}) @markup_class_name = [:markup_class_name] || "prettyprint" @highlighter = [:highlighter] || NoopHighlighter.new end |
Class Method Details
.can_render?(path) ⇒ Boolean
75 76 77 |
# File 'lib/makeup/markup.rb', line 75 def self.can_render?(path) GitHub::Markup.can_render?(path) end |
.markups ⇒ Object
79 80 81 |
# File 'lib/makeup/markup.rb', line 79 def self.markups GitHubMarkupAccessor.markups end |
Instance Method Details
#highlight_code_blocks(path, markup) ⇒ Object
67 68 69 70 71 72 73 |
# File 'lib/makeup/markup.rb', line 67 def highlight_code_blocks(path, markup) return markup unless path =~ /\.(md|mkdn?|mdwn|mdown|markdown)$/ CodeBlockParser.parse(markup) do |lexer, code| hb = @highlighter.highlight(path, code, { :lexer => lexer }) "<pre class=\"#{hb.lexer} #{@markup_class_name}\">#{hb.code}</pre>" end end |
#render(path, content) ⇒ Object
58 59 60 61 |
# File 'lib/makeup/markup.rb', line 58 def render(path, content) content = highlight_code_blocks(path, content) sanitize(GitHub::Markup.render(path, content)) end |
#sanitize(html) ⇒ Object
63 64 65 |
# File 'lib/makeup/markup.rb', line 63 def sanitize(html) Loofah.fragment(html).scrub!(:prune).to_s end |