Class: ExtendedMarkdownFilter
- Inherits:
-
HTML::Pipeline::MarkdownFilter
- Object
- HTML::Pipeline::MarkdownFilter
- ExtendedMarkdownFilter
- Includes:
- Filters::PostFilter, Filters::PreFilter
- Defined in:
- lib/extended-markdown-filter.rb
Constant Summary collapse
- EMF_CURLY_TAGS =
%w(intro mac windows linux all tip warning error).join('|')
Class Method Summary collapse
Instance Method Summary collapse
- #call ⇒ Object
-
#initialize(text, context = nil, result = nil) ⇒ ExtendedMarkdownFilter
constructor
A new instance of ExtendedMarkdownFilter.
Methods included from Filters::PostFilter
#format_admonitions!, #format_intro!, #format_octicons!, #format_os_blocks!
Methods included from Filters::PreFilter
#format_command_line!, #format_helper!
Constructor Details
#initialize(text, context = nil, result = nil) ⇒ ExtendedMarkdownFilter
Returns a new instance of ExtendedMarkdownFilter.
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/extended-markdown-filter.rb', line 19 def initialize(text, context = nil, result = nil) if defined?(Jekyll) && context[:emf_use_blocks] require 'jekyll-override' end if context[:emf_use_blocks] text = self.class.convert_curly_to_bracket(text) end Filters.context = context # do preprocessing, then call HTML::Pipeline::Markdown format_command_line! text format_helper! text super text, context, result end |
Class Method Details
.convert_curly_to_bracket(text) ⇒ Object
37 38 39 40 41 42 43 44 |
# File 'lib/extended-markdown-filter.rb', line 37 def self.convert_curly_to_bracket(text) return text if text.nil? text = text.gsub(/\{\{\s*#(#{EMF_CURLY_TAGS})\s*\}\}/, '[[#\1]]') text = text.gsub(/\{\{\s*\/(#{EMF_CURLY_TAGS})\s*\}\}/, '[[/\1]]') text = text.gsub(/\{\{\s*(octicon-\S+\s*[^\}]+)\s*\}\}/, '[[\1]]') text end |
.should_jekyll_replace?(site) ⇒ Boolean
46 47 48 49 |
# File 'lib/extended-markdown-filter.rb', line 46 def self.should_jekyll_replace?(site) html_pipeline_context = site.site_payload["site"]["html_pipeline"] && site.site_payload["site"]["html_pipeline"]["context"] site.site_payload["site"]["markdown"] == "HTMLPipeline" && html_pipeline_context && site.site_payload["site"]["html_pipeline"]["context"][:emf_use_blocks] end |
Instance Method Details
#call ⇒ Object
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
# File 'lib/extended-markdown-filter.rb', line 51 def call # initialize HTML::Pipeline::Markdown, then do post-processing html = super format_intro! html format_os_blocks! html format_admonitions! html format_octicons! html doc = Nokogiri::HTML(html) doc.css(".command-line a").each do |node| node.replace Nokogiri::XML::Text.new(node.text, node.document) end doc.to_s end |