Sha256: 5d98b702a623c2e9ee732ff1a375f26612efdd63eeb563d68318882439f622ef

Contents?: true

Size: 1.32 KB

Versions: 4

Compression:

Stored size: 1.32 KB

Contents

require_relative "html_function/comments.rb"
require_relative "html_function/footnotes.rb"
require_relative "html_function/html.rb"
require "fileutils"

module IsoDoc
  class HeadlessHtmlConvert < ::IsoDoc::Convert

    include HtmlFunction::Comments
    include HtmlFunction::Footnotes
    include HtmlFunction::Html

    def tmpimagedir_suffix
      "_headlessimages"
    end

    def initialize(options)
      @format = :html
      super
    end

    def convert(filename, file = nil, debug = false)
      file = File.read(filename, encoding: "utf-8") if file.nil?
      @openmathdelim, @closemathdelim = extract_delims(file)
      docxml, outname_html, dir = convert_init(file, filename, debug)
      result = convert1(docxml, outname_html, dir)
      return result if debug
      postprocess(result, filename + ".tmp", dir)
      FileUtils.rm_rf dir
      strip_head(filename + ".tmp.html", outname_html + ".headless.html")
      FileUtils.rm_rf ["#{filename}.tmp.html", tmpimagedir]
    end

    def strip_head(input, output)
      file = File.read(input, encoding: "utf-8")
      doc = Nokogiri::XML(file)
      doc.xpath("//head").each { |x| x.remove }
      doc.xpath("//html").each { |x| x.name = "div" }
      body = doc.at("//body")
      body.replace(body.children)
      File.open(output, "w") { |f| f.write(doc.to_xml) }
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
isodoc-1.0.29 lib/isodoc/headlesshtml_convert.rb
isodoc-1.0.28 lib/isodoc/headlesshtml_convert.rb
isodoc-1.0.27 lib/isodoc/headlesshtml_convert.rb
isodoc-1.0.26 lib/isodoc/headlesshtml_convert.rb