class Asciidoctor::MPFA::Converter

A {Converter} implementation that generates MPFD output, and a document schema encapsulation of the document for validation

A {Converter} implementation that generates MPFD output, and a document schema encapsulation of the document for validation

Constants

XML_NAMESPACE
XML_ROOT_TAG

Public Instance Methods

bibdata_validate(doc) click to toggle source
# File lib/asciidoctor/mpfa/validate.rb, line 9
def bibdata_validate(doc)
  doctype_validate(doc)
  stage_validate(doc)
end
clause_parse(attrs, xml, node) click to toggle source
Calls superclass method
# File lib/asciidoctor/mpfa/section.rb, line 56
def clause_parse(attrs, xml, node)
  attrs[:guidance] = true if node.role == "guidance"
  attrs[:container] = true if node.role == "container"
  super
end
content_validate(doc) click to toggle source
Calls superclass method
# File lib/asciidoctor/mpfa/validate.rb, line 4
def content_validate(doc)
  super
  bibdata_validate(doc.root)
end
default_publisher() click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 22
def default_publisher
  "Mandatory Provident Fund Schemes Authority"
end
doc_converter(node) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 80
def doc_converter(node)
  IsoDoc::MPFA::WordConvert.new(doc_extract_attributes(node))
end
doctype_validate(xmldoc) click to toggle source
# File lib/asciidoctor/mpfa/validate.rb, line 14
def doctype_validate(xmldoc)
  doctype = xmldoc&.at("//bibdata/ext/doctype")&.text
  %w(policy-and-procedures best-practices supporting-document
  report legal directives proposal standard).include? doctype or
  @log.add("Document Attributes", nil, "#{doctype} is not a recognised document type")
end
html_converter(node) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 76
def html_converter(node)
  IsoDoc::MPFA::HtmlConvert.new(html_extract_attributes(node))
end
make_preface(x, s) click to toggle source
# File lib/asciidoctor/mpfa/section.rb, line 47
def make_preface(x, s)
  if x.at("//foreword | //introduction | //terms | //acknowledgements |"\
      "//abstract[not(ancestor::bibitem)] | //clause[@preface]")
    preface = s.add_previous_sibling("<preface/>").first
    move_sections_into_preface(x, preface)
    make_abstract(x, s)
  end
end
makexml(node) click to toggle source
Calls superclass method
# File lib/asciidoctor/mpfa/converter.rb, line 49
def makexml(node)
  @draft = node.attributes.has_key?("draft")
  super
end
metadata_committee(node, xml) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 26
def metadata_committee(node, xml)
  return unless node.attr("committee")
  xml.editorialgroup do |a|
    a.committee node.attr("committee"),
      **attr_code(type: node.attr("committee-type"))
    i = 2
    while node.attr("committee_#{i}") do
      a.committee node.attr("committee_#{i}"),
        **attr_code(type: node.attr("committee-type_#{i}"))
      i += 1
    end
  end
end
metadata_id(node, xml) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 40
def metadata_id(node, xml)
  xml.docidentifier { |i| i << node.attr("docnumber") }
  xml.docnumber { |i| i << node.attr("docnumber") }
end
move_sections_into_preface(x, preface) click to toggle source
# File lib/asciidoctor/mpfa/section.rb, line 35
def move_sections_into_preface(x, preface)
  foreword = x.at("//foreword")
  preface.add_child foreword.remove if foreword
  introduction = x.at("//introduction")
  preface.add_child introduction.remove if introduction
  terms = x.at("//sections/clause[descendant::terms]") || x.at("//terms")
  preface.add_child terms.remove if terms
  move_clauses_into_preface(x, preface)
  acknowledgements = x.at("//acknowledgements")
  preface.add_child acknowledgements.remove if acknowledgements
end
outputs(node, ret) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 54
def outputs(node, ret)
  File.open(@filename + ".xml", "w:UTF-8") { |f| f.write(ret) }
  presentation_xml_converter(node).convert(@filename + ".xml")
  html_converter(node).convert(@filename + ".presentation.xml", nil, false, "#{@filename}.html")
  doc_converter(node).convert(@filename + ".presentation.xml", nil, false, "#{@filename}.doc")
  pdf_converter(node)&.convert(@filename + ".presentation.xml", nil, false, "#{@filename}.pdf")
end
pdf_converter(node) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 84
def pdf_converter(node)
  return if node.attr("no-pdf")
  IsoDoc::MPFA::PdfConvert.new(doc_extract_attributes(node))
end
presentation_xml_converter(node) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 72
def presentation_xml_converter(node)
  IsoDoc::MPFA::PresentationXMLConvert.new(html_extract_attributes(node))
end
sections_cleanup(x) click to toggle source
Calls superclass method
# File lib/asciidoctor/mpfa/section.rb, line 9
def sections_cleanup(x)
  super
  x.xpath("//*[@inline-header]").each do |h|
    h.delete("inline-header")
  end
  x.xpath("//*[@guidance]").each do |h|
    #c = h.at("./preceding-sibling::clause[last()]") || next
    c = h.xpath("./preceding-sibling::clause")
    c.empty? and next
    #c.add_child h.remove
    c.last.add_child h.remove
  end
end
sectiontype_streamline(ret) click to toggle source
Calls superclass method
# File lib/asciidoctor/mpfa/section.rb, line 23
def sectiontype_streamline(ret)
  case ret
  when "glossary" then "terms and definitions"
  else
    super
  end
end
stage_validate(xmldoc) click to toggle source
# File lib/asciidoctor/mpfa/validate.rb, line 21
def stage_validate(xmldoc)
  stage = xmldoc&.at("//bibdata/status/stage")&.text
  %w(proposal working-draft committee-draft draft-standard final-draft
  published withdrawn).include? stage or
  @log.add("Document Attributes", nil, "#{stage} is not a recognised status")
end
style(n, t) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 68
def style(n, t)
  return
end
term_def_title(_toplevel, node) click to toggle source
# File lib/asciidoctor/mpfa/section.rb, line 31
def term_def_title(_toplevel, node)
  return node.title
end
title_validate(root) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 45
def title_validate(root)
  nil
end
validate(doc) click to toggle source
# File lib/asciidoctor/mpfa/converter.rb, line 62
def validate(doc)
  content_validate(doc)
  schema_validate(formattedstr_strip(doc.dup),
                  File.join(File.dirname(__FILE__), "mpfd.rng"))
end