Class: Metanorma::Ribose::Converter
- Inherits:
-
Generic::Converter
- Object
- Generic::Converter
- Metanorma::Ribose::Converter
- Defined in:
- lib/metanorma/ribose/converter.rb
Overview
A Converter implementation that generates RSD output, and a document schema encapsulation of the document for validation
Constant Summary collapse
- XML_ROOT_TAG =
"rsd-standard".freeze
- XML_NAMESPACE =
"https://www.metanorma.org/ns/ribose".freeze
Instance Method Summary collapse
- #clause_parse(attrs, xml, node) ⇒ Object
- #configuration ⇒ Object
- #doc_converter(node) ⇒ Object
- #executivesummary_parse(attrs, xml, node) ⇒ Object
- #html_converter(node) ⇒ Object
- #make_preface(xml, sect) ⇒ Object
- #pdf_converter(node) ⇒ Object
- #presentation_xml_converter(node) ⇒ Object
- #sectiontype(node, level = true) ⇒ Object
Instance Method Details
#clause_parse(attrs, xml, node) ⇒ Object
40 41 42 43 44 |
# File 'lib/metanorma/ribose/converter.rb', line 40 def clause_parse(attrs, xml, node) sectiontype1(node) == "executive summary" and return executivesummary_parse(attrs, xml, node) super end |
#configuration ⇒ Object
54 55 56 |
# File 'lib/metanorma/ribose/converter.rb', line 54 def configuration Metanorma::Ribose.configuration end |
#doc_converter(node) ⇒ Object
74 75 76 |
# File 'lib/metanorma/ribose/converter.rb', line 74 def doc_converter(node) IsoDoc::Ribose::WordConvert.new(doc_extract_attributes(node)) end |
#executivesummary_parse(attrs, xml, node) ⇒ Object
46 47 48 49 50 51 52 |
# File 'lib/metanorma/ribose/converter.rb', line 46 def executivesummary_parse(attrs, xml, node) xml.executivesummary **attr_code(attrs) do |xml_section| xml_section.title { |t| t << (node.title || "Executive Summary") } content = node.content xml_section << content end end |
#html_converter(node) ⇒ Object
64 65 66 |
# File 'lib/metanorma/ribose/converter.rb', line 64 def html_converter(node) IsoDoc::Ribose::HtmlConvert.new(html_extract_attributes(node)) end |
#make_preface(xml, sect) ⇒ Object
27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'lib/metanorma/ribose/converter.rb', line 27 def make_preface(xml, sect) if xml.at("//foreword | //introduction | //acknowledgements | "\ "//clause[@preface] | //executivesummary") preface = sect.add_previous_sibling("<preface/>").first f = xml.at("//foreword") and preface.add_child f.remove f = xml.at("//executivesummary") and preface.add_child f.remove f = xml.at("//introduction") and preface.add_child f.remove move_clauses_into_preface(xml, preface) f = xml.at("//acknowledgements") and preface.add_child f.remove end make_abstract(xml, sect) end |
#pdf_converter(node) ⇒ Object
68 69 70 71 72 |
# File 'lib/metanorma/ribose/converter.rb', line 68 def pdf_converter(node) return nil if node.attr("no-pdf") IsoDoc::Ribose::PdfConvert.new(pdf_extract_attributes(node)) end |
#presentation_xml_converter(node) ⇒ Object
58 59 60 61 62 |
# File 'lib/metanorma/ribose/converter.rb', line 58 def presentation_xml_converter(node) IsoDoc::Ribose::PresentationXMLConvert .new(html_extract_attributes(node) .merge(output_formats: ::Metanorma::Ribose::Processor.new.output_formats)) end |
#sectiontype(node, level = true) ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/metanorma/ribose/converter.rb', line 15 def sectiontype(node, level = true) ret = sectiontype1(node) ret1 = sectiontype_streamline(ret) return ret1 if ret1 == "symbols and abbreviated terms" return ret1 if ret1 == "executive summary" return nil unless !level || node.level == 1 return nil if @seen_headers.include? ret @seen_headers << ret ret1 end |