Redcarpet语法突出显示

时间:2014-05-21 14:20:17

标签: ruby-on-rails ruby syntax-highlighting redcarpet

我试图通过Redcarpet工作

来获取语法突出显示

我的appliaction_helper.rb

module ApplicationHelper

  def markdown(text)
    render_options = {
        # will remove from the output HTML tags inputted by user
        filter_html:     true,
        # will insert <br /> tags in paragraphs where are newlines
        hard_wrap:       true,
        # hash for extra link options, for example 'nofollow'
        link_attributes: { rel: 'nofollow' },
        # Prettify
        prettify:        true
    }
    renderer = Redcarpet::Render::HTML.new(render_options)

    extensions = {
        #will parse links without need of enclosing them
        autolink:           true,
        # blocks delimited with 3 ` or ~ will be considered as code block.
        # No need to indent.  You can provide language name too.
        # ```ruby
        # block of code
        # ```
        fenced_code_blocks: true,
        # will ignore standard require for empty lines surrounding HTML blocks
        lax_spacing:        true,
        # will not generate emphasis inside of words, for example no_emph_no
        no_intra_emphasis:  true,
        # will parse strikethrough from ~~, for example: ~~bad~~
        strikethrough:      true,
        # will parse superscript after ^, you can wrap superscript in ()
        superscript:        true
        # will require a space after # in defining headers
        # space_after_headers: true
    }
    Redcarpet::Markdown.new(renderer, extensions).render(text).html_safe
  end

end

虽然输出显示在代码块(redcarpet)中:

enter image description here

我无法找到Syntax Highlighting

我刚进入Redcarpet,有人知道解决方案吗?

3 个答案:

答案 0 :(得分:9)

好的,我找到了 - &gt; Markdown and code syntax highlighting in Ruby on Rails (using RedCarpet and CodeRay)非常有效(与Coderay的一些自定义css一起)。

的Gemfile:

gem 'redcarpet', github: 'vmg/redcarpet'
gem 'coderay'

Application_helper.rb

class CodeRayify < Redcarpet::Render::HTML
  def block_code(code, language)
    CodeRay.scan(code, language).div
  end
end

def markdown(text)
  coderayified = CodeRayify.new(:filter_html => true, 
                                :hard_wrap => true)
  options = {
    :fenced_code_blocks => true,
    :no_intra_emphasis => true,
    :autolink => true,
    :strikethrough => true,
    :lax_html_blocks => true,
    :superscript => true
  }
  markdown_to_html = Redcarpet::Markdown.new(coderayified, options)
  markdown_to_html.render(text).html_safe
end

答案 1 :(得分:4)

以下是使用Rouge快速完成此操作的方法:

require 'redcarpet'
require 'rouge'
require 'rouge/plugins/redcarpet'

class HTML < Redcarpet::Render::HTML
  include Rouge::Plugins::Redcarpet # yep, that's it.
end

当然,这需要rouge {/ 1}}。

答案 2 :(得分:2)

我不认为Redcarpet可以做到这一点。在我的项目中,我遵循了关于Redcarpet的Railscasts剧集,该剧集也解决了语法高亮问题。它使用PygmentsAlbino

ASCIIcast版本的链接是here