Class: Asciidoctor::Sample::Converter
- Inherits:
-
Standoc::Converter
- Object
- Standoc::Converter
- Asciidoctor::Sample::Converter
- Defined in:
- lib/asciidoctor/sample/converter.rb
Overview
A Converter implementation that generates RSD output, and a document schema encapsulation of the document for validation
Instance Method Summary collapse
- #doctype(node) ⇒ Object
- #document(node) ⇒ Object
- #html_converter(node) ⇒ Object
- #makexml(node) ⇒ Object
- #metadata_author(node, xml) ⇒ Object
- #metadata_committee(node, xml) ⇒ Object
- #metadata_copyright(node, xml) ⇒ Object
- #metadata_ext(node, xml) ⇒ Object
- #metadata_id(node, xml) ⇒ Object
- #metadata_publisher(node, xml) ⇒ Object
- #metadata_security(node, xml) ⇒ Object
- #pdf_converter(node) ⇒ Object
- #sections_cleanup(x) ⇒ Object
- #style(n, t) ⇒ Object
- #title_validate(root) ⇒ Object
- #validate(doc) ⇒ Object
- #word_converter(node) ⇒ Object
Instance Method Details
#doctype(node) ⇒ Object
102 103 104 105 106 107 108 109 110 111 |
# File 'lib/asciidoctor/sample/converter.rb', line 102 def doctype(node) d = node.attr("doctype") unless %w{policy-and-procedures best-practices supporting-document report legal directives proposal standard}.include? d warn "#{d} is not a legal document type: reverting to 'standard'" d = "standard" end d end |
#document(node) ⇒ Object
113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 |
# File 'lib/asciidoctor/sample/converter.rb', line 113 def document(node) init(node) ret1 = makexml(node) ret = ret1.to_xml(indent: 2) unless node.attr("nodoc") || !node.attr("docfile") filename = node.attr("docfile").gsub(/\.adoc/, ".xml"). gsub(%r{^.*/}, "") File.open(filename, "w") { |f| f.write(ret) } html_converter(node).convert filename unless node.attr("nodoc") word_converter(node).convert filename unless node.attr("nodoc") pdf_converter(node).convert filename unless node.attr("nodoc") end @files_to_delete.each { |f| FileUtils.rm f } ret end |
#html_converter(node) ⇒ Object
146 147 148 |
# File 'lib/asciidoctor/sample/converter.rb', line 146 def html_converter(node) IsoDoc::Sample::HtmlConvert.new(html_extract_attributes(node)) end |
#makexml(node) ⇒ Object
89 90 91 92 93 94 95 96 97 98 99 100 |
# File 'lib/asciidoctor/sample/converter.rb', line 89 def makexml(node) result = ["<?xml version='1.0' encoding='UTF-8'?>\n<sample-standard>"] @draft = node.attributes.has_key?("draft") result << noko { |ixml| front node, ixml } result << noko { |ixml| middle node, ixml } result << "</sample-standard>" result = textcleanup(result) ret1 = cleanup(Nokogiri::XML(result)) validate(ret1) unless @novalid ret1.root.add_namespace(nil, EXAMPLE_NAMESPACE) ret1 end |
#metadata_author(node, xml) ⇒ Object
18 19 20 21 22 23 24 25 |
# File 'lib/asciidoctor/sample/converter.rb', line 18 def (node, xml) xml.contributor do |c| c.role **{ type: "author" } c.organization do |a| a.name "Acme" end end end |
#metadata_committee(node, xml) ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/asciidoctor/sample/converter.rb', line 36 def (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_copyright(node, xml) ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 |
# File 'lib/asciidoctor/sample/converter.rb', line 63 def (node, xml) from = node.attr("copyright-year") || Date.today.year xml.copyright do |c| c.from from c.owner do |owner| owner.organization do |o| o.name "Acme" end end end end |
#metadata_ext(node, xml) ⇒ Object
80 81 82 83 |
# File 'lib/asciidoctor/sample/converter.rb', line 80 def (node, xml) super (node, xml) end |
#metadata_id(node, xml) ⇒ Object
50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/asciidoctor/sample/converter.rb', line 50 def (node, xml) docstatus = node.attr("status") dn = node.attr("docnumber") if docstatus abbr = IsoDoc::Sample::Metadata.new("en", "Latn", {}). status_abbr(docstatus) dn = "#{dn}(#{abbr})" unless abbr.empty? end node.attr("copyright-year") and dn += ":#{node.attr("copyright-year")}" xml.docidentifier dn, **{type: "acme"} xml.docnumber { |i| i << node.attr("docnumber") } end |
#metadata_publisher(node, xml) ⇒ Object
27 28 29 30 31 32 33 34 |
# File 'lib/asciidoctor/sample/converter.rb', line 27 def (node, xml) xml.contributor do |c| c.role **{ type: "publisher" } c.organization do |a| a.name "Acme" end end end |
#metadata_security(node, xml) ⇒ Object
75 76 77 78 |
# File 'lib/asciidoctor/sample/converter.rb', line 75 def (node, xml) security = node.attr("security") || return xml.security security end |
#pdf_converter(node) ⇒ Object
154 155 156 |
# File 'lib/asciidoctor/sample/converter.rb', line 154 def pdf_converter(node) IsoDoc::Sample::PdfConvert.new(html_extract_attributes(node)) end |
#sections_cleanup(x) ⇒ Object
135 136 137 138 139 140 |
# File 'lib/asciidoctor/sample/converter.rb', line 135 def sections_cleanup(x) super x.xpath("//*[@inline-header]").each do |h| h.delete("inline-header") end end |
#style(n, t) ⇒ Object
142 143 144 |
# File 'lib/asciidoctor/sample/converter.rb', line 142 def style(n, t) return end |
#title_validate(root) ⇒ Object
85 86 87 |
# File 'lib/asciidoctor/sample/converter.rb', line 85 def title_validate(root) nil end |
#validate(doc) ⇒ Object
129 130 131 132 133 |
# File 'lib/asciidoctor/sample/converter.rb', line 129 def validate(doc) content_validate(doc) schema_validate(formattedstr_strip(doc.dup), File.join(File.dirname(__FILE__), "sample.rng")) end |
#word_converter(node) ⇒ Object
150 151 152 |
# File 'lib/asciidoctor/sample/converter.rb', line 150 def word_converter(node) IsoDoc::Sample::WordConvert.new(doc_extract_attributes(node)) end |