Sha256: c80cdd38e98457468e0f864a0c82086840f6f907542afa98d90ad5808df0abc6

Contents?: true

Size: 1.12 KB

Versions: 4

Compression:

Stored size: 1.12 KB

Contents

# frozen_string_literal: true
module Asciidoctor
module PDF
module FormattedText
class Formatter
  if defined? ::Asciidoctor::Logging
    include ::Asciidoctor::Logging
  else
    include ::Asciidoctor::LoggingShim
  end

  FormattingSnifferPattern = /[<&]/
  WHITESPACE = " \t\n"

  def initialize options = {}
    @parser = MarkupParser.new
    @transform = Transform.new merge_adjacent_text_nodes: true, theme: options[:theme]
  end

  def format string, *args
    options = args[0] || {}
    string = string.tr_s(WHITESPACE, ' ') if options[:normalize]
    return [text: string] unless FormattingSnifferPattern.match? string
    if (parsed = @parser.parse(string))
      @transform.apply(parsed.content)
    else
      logger.error %(failed to parse formatted text: #{string})
      [text: string]
    end
  end

  # The original purpose of this method is to split paragraphs, but our formatter only works on paragraphs that have
  # been presplit. Therefore, we just need to wrap the fragments in a single-element array (representing a single
  # paragraph) and return them.
  def array_paragraphs fragments
    [fragments]
  end
end
end
end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
asciidoctor-pdf-1.5.0.beta.5 lib/asciidoctor-pdf/formatted_text/formatter.rb
asciidoctor-pdf-1.5.0.beta.4 lib/asciidoctor-pdf/formatted_text/formatter.rb
asciidoctor-pdf-1.5.0.beta.3 lib/asciidoctor-pdf/formatted_text/formatter.rb
asciidoctor-pdf-1.5.0.beta.2 lib/asciidoctor-pdf/formatted_text/formatter.rb