Sha256: 2970e7b3036ed4064d92831896270edfbe568c77b78f3779132b3f5338abcb30

Contents?: true

Size: 1.28 KB

Versions: 6

Compression:

Stored size: 1.28 KB

Contents

HTML::Pipeline.require_dependency('commonmarker', 'MarkdownFilter')

module HTML
  class Pipeline
    # HTML Filter that converts Markdown text into HTML and converts into a
    # DocumentFragment. This is different from most filters in that it can take a
    # non-HTML as input. It must be used as the first filter in a pipeline.
    #
    # Context options:
    #   :gfm      => false    Disable GFM line-end processing
    #   :commonmarker_extensions => [ :table, :strikethrough,
    #      :tagfilter, :autolink ] Common marker extensions to include
    #
    # This filter does not write any additional information to the context hash.
    class MarkdownFilter < TextFilter
      def initialize(text, context = nil, result = nil)
        super text, context, result
        @text = @text.delete "\r"
      end

      # Convert Markdown to HTML using the best available implementation
      # and convert into a DocumentFragment.
      def call
        options = [:GITHUB_PRE_LANG]
        options << :HARDBREAKS if context[:gfm] != false
        extensions = context.fetch(
          :commonmarker_extensions,
          %i[table strikethrough tagfilter autolink]
        )
        html = CommonMarker.render_html(@text, options, extensions)
        html.rstrip!
        html
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
html-pipeline-2.8.4 lib/html/pipeline/markdown_filter.rb
html-pipeline-2.8.3 lib/html/pipeline/markdown_filter.rb
html-pipeline-2.8.2 lib/html/pipeline/markdown_filter.rb
html-pipeline-2.8.1 lib/html/pipeline/markdown_filter.rb
html-pipeline-2.8.0 lib/html/pipeline/markdown_filter.rb
html-pipeline-2.7.2 lib/html/pipeline/markdown_filter.rb