Sha256: 7e3e44b79d2cf0737cd9a303c721c04c741e841179e8ee07cdb92ec18f5e0949

Contents?: true

Size: 1.38 KB

Versions: 48

Compression:

Stored size: 1.38 KB

Contents

# -*- coding: utf-8 -*- #
# frozen_string_literal: true

# stdlib
require 'cgi'

module Rouge
  module Formatters
    # Transforms a token stream into HTML output.
    class HTMLLegacy < Formatter
      tag 'html_legacy'

      # @option opts [String] :css_class ('highlight')
      # @option opts [true/false] :line_numbers (false)
      # @option opts [Rouge::CSSTheme] :inline_theme (nil)
      # @option opts [true/false] :wrap (true)
      #
      # Initialize with options.
      #
      # If `:inline_theme` is given, then instead of rendering the
      # tokens as <span> tags with CSS classes, the styles according to
      # the given theme will be inlined in "style" attributes.  This is
      # useful for formats in which stylesheets are not available.
      #
      # Content will be wrapped in a tag (`div` if tableized, `pre` if
      # not) with the given `:css_class` unless `:wrap` is set to `false`.
      def initialize(opts={})
        @formatter = opts[:inline_theme] ? HTMLInline.new(opts[:inline_theme])
                   : HTML.new


        @formatter = HTMLTable.new(@formatter, opts) if opts[:line_numbers]

        if opts.fetch(:wrap, true)
          @formatter = HTMLPygments.new(@formatter, opts.fetch(:css_class, 'codehilite'))
        end
      end

      # @yield the html output.
      def stream(tokens, &b)
        @formatter.stream(tokens, &b)
      end
    end
  end
end

Version data entries

48 entries across 48 versions & 3 rubygems

Version Path
rouge-3.7.0 lib/rouge/formatters/html_legacy.rb
rouge-3.6.0 lib/rouge/formatters/html_legacy.rb
rouge-3.5.1 lib/rouge/formatters/html_legacy.rb
rouge-3.5.0 lib/rouge/formatters/html_legacy.rb
rouge-3.4.1 lib/rouge/formatters/html_legacy.rb
rouge-3.4.0 lib/rouge/formatters/html_legacy.rb
rouge-alda-3.3.0 lib/rouge/formatters/html_legacy.rb
rouge-3.3.0 lib/rouge/formatters/html_legacy.rb