class Asciidoctor::SyntaxHighlighter::RougeAdapter

Public Class Methods

new(*args) click to toggle source
Calls superclass method Asciidoctor::SyntaxHighlighter::new
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 6
def initialize *args
  super
  @requires_stylesheet = @style = nil
end

Public Instance Methods

create_formatter(node, source, lang, opts) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 74
def create_formatter node, source, lang, opts
  formatter = opts[:css_mode] == :class ?
    (::Rouge::Formatters::HTML.new inline_theme: @style) :
    (::Rouge::Formatters::HTMLInline.new (::Rouge::Theme.find @style).new)
  if (highlight_lines = opts[:highlight_lines])
    formatter = RougeExt::Formatters::HTMLLineHighlighter.new formatter, lines: highlight_lines
  end
  opts[:number_lines] ? (RougeExt::Formatters::HTMLTable.new formatter, start_line: opts[:start_line_number]) : formatter
end
create_lexer(node, source, lang, opts) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 60
def create_lexer node, source, lang, opts
  if lang.include? '?'
    # NOTE cgi-style options only properly supported in Rouge >= 2.1
    if (lexer = ::Rouge::Lexer.find_fancy lang)
      unless lexer.tag != 'php' || (node.option? 'mixed') || ((lexer_opts = lexer.options).key? 'start_inline')
        lexer = lexer.class.new lexer_opts.merge 'start_inline' => true
      end
    end
  elsif (lexer = ::Rouge::Lexer.find lang)
    lexer = lexer.tag == 'php' && !(node.option? 'mixed') ? (lexer.new start_inline: true) : lexer.new
  end if lang
  lexer || ::Rouge::Lexers::PlainText.new
end
docinfo(location, doc, opts) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 42
  def docinfo location, doc, opts
    if opts[:linkcss]
      %(<link rel="stylesheet" href="#{doc.normalize_web_path (stylesheet_basename @style), (doc.attr 'stylesdir', ''), false}"#{opts[:self_closing_tag_slash]}>)
    else
      %(<style>
#{read_stylesheet @style}
</style>)
    end
  end
docinfo?(location) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 38
def docinfo? location
  @requires_stylesheet && location == :head
end
format(node, lang, opts) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 28
def format node, lang, opts
  if (query_idx = lang && (lang.index '?'))
    lang = lang.slice 0, query_idx
  end
  if opts[:css_mode] != :class && (@style = (style = opts[:style]) && (style_available? style) || DEFAULT_STYLE) && (pre_style_attr_val = base_style @style)
    opts[:transform] = proc {|pre| pre['style'] = pre_style_attr_val }
  end
  super
end
highlight(node, source, lang, opts) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 15
def highlight node, source, lang, opts
  @style ||= (style = opts[:style]) && (style_available? style) || DEFAULT_STYLE
  @requires_stylesheet = true if opts[:css_mode] == :class
  lexer = create_lexer node, source, lang, opts
  formatter = create_formatter node, source, lang, opts
  highlighted = formatter.format lexer.lex source
  if opts[:number_lines] && opts[:callouts]
    [highlighted, (idx = highlighted.index CodeCellStartTagCs) ? idx + CodeCellStartTagCs.length : nil]
  else
    highlighted
  end
end
highlight?() click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 11
def highlight?
  library_available?
end
write_stylesheet(doc, to_dir) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 56
def write_stylesheet doc, to_dir
  ::File.write (::File.join to_dir, (stylesheet_basename @style)), (read_stylesheet @style), mode: FILE_WRITE_MODE
end
write_stylesheet?(doc) click to toggle source
# File lib/asciidoctor/syntax_highlighter/rouge.rb, line 52
def write_stylesheet? doc
  @requires_stylesheet
end