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