Class: Asciidoctor::M3d::Converter
- Inherits:
-
ISO::Converter
- Object
- ISO::Converter
- Asciidoctor::M3d::Converter
- Defined in:
- lib/asciidoctor/m3d/converter.rb
Overview
A Converter implementation that generates M3D 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
- #inline_quoted(node) ⇒ Object
- #literal(node) ⇒ Object
- #makexml(node) ⇒ Object
- #metadata(node, xml) ⇒ Object
- #metadata_author(node, xml) ⇒ Object
- #metadata_committee(node, xml) ⇒ Object
- #metadata_copyright(node, xml) ⇒ Object
- #metadata_id(node, xml) ⇒ Object
- #metadata_publisher(node, xml) ⇒ Object
- #metadata_source(node, xml) ⇒ Object
- #metadata_status(node, xml) ⇒ Object
- #sections_cleanup(x) ⇒ Object
- #style(n, t) ⇒ Object
- #title(node, xml) ⇒ Object
- #title_validate(root) ⇒ Object
- #validate(doc) ⇒ Object
- #word_converter(node) ⇒ Object
Instance Method Details
#doctype(node) ⇒ Object
106 107 108 109 110 111 112 113 |
# File 'lib/asciidoctor/m3d/converter.rb', line 106 def doctype(node) d = node.attr("doctype") unless %w{policy best-practices supporting-document report}.include? d warn "#{d} is not a legal document type: reverting to 'report'" d = "report" end d end |
#document(node) ⇒ Object
115 116 117 118 119 120 121 122 123 124 125 126 127 128 |
# File 'lib/asciidoctor/m3d/converter.rb', line 115 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") end @files_to_delete.each { |f| system "rm #{f}" } ret end |
#html_converter(node) ⇒ Object
156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 |
# File 'lib/asciidoctor/m3d/converter.rb', line 156 def html_converter(node) IsoDoc::M3d::HtmlConvert.new( script: node.attr("script"), bodyfont: node.attr("body-font"), headerfont: node.attr("header-font"), monospacefont: node.attr("monospace-font"), titlefont: node.attr("title-font"), i18nyaml: node.attr("i18nyaml"), scope: node.attr("scope"), htmlstylesheet: node.attr("htmlstylesheet"), htmlcoverpage: node.attr("htmlcoverpage"), htmlintropage: node.attr("htmlintropage"), scripts: node.attr("scripts"), ) end |
#inline_quoted(node) ⇒ Object
191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 |
# File 'lib/asciidoctor/m3d/converter.rb', line 191 def inline_quoted(node) noko do |xml| case node.type when :emphasis then xml.em node.text when :strong then xml.strong node.text when :monospaced then xml.tt node.text when :double then xml << "\"#{node.text}\"" when :single then xml << "'#{node.text}'" when :superscript then xml.sup node.text when :subscript then xml.sub node.text when :asciimath then stem_parse(node.text, xml) else case node.role when "strike" then xml.strike node.text when "smallcap" then xml.smallcap node.text when "keyword" then xml.keyword node.text else xml << node.text end end end.join end |
#literal(node) ⇒ Object
136 137 138 139 140 141 142 143 |
# File 'lib/asciidoctor/m3d/converter.rb', line 136 def literal(node) noko do |xml| xml.figure **id_attr(node) do |f| figure_title(node, f) f.pre node.lines.join("\n") end end end |
#makexml(node) ⇒ Object
93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/asciidoctor/m3d/converter.rb', line 93 def makexml(node) result = ["<?xml version='1.0' encoding='UTF-8'?>\n<m3d-standard>"] @draft = node.attributes.has_key?("draft") result << noko { |ixml| front node, ixml } result << noko { |ixml| middle node, ixml } result << "</m3d-standard>" result = textcleanup(result.flatten * "\n") ret1 = cleanup(Nokogiri::XML(result)) validate(ret1) ret1.root.add_namespace(nil, M3D_NAMESPACE) ret1 end |
#metadata(node, xml) ⇒ Object
17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/asciidoctor/m3d/converter.rb', line 17 def (node, xml) title node, xml (node, xml) (node, xml) (node, xml) (node, xml) xml.language node.attr("language") xml.script (node.attr("script") || "Latn") (node, xml) (node, xml) (node, xml) (node, xml) end |
#metadata_author(node, xml) ⇒ Object
36 37 38 39 40 41 42 43 |
# File 'lib/asciidoctor/m3d/converter.rb', line 36 def (node, xml) xml.contributor do |c| c.role **{ type: "author" } c.organization do |a| a.name "Ribose" end end end |
#metadata_committee(node, xml) ⇒ Object
54 55 56 57 58 59 |
# File 'lib/asciidoctor/m3d/converter.rb', line 54 def (node, xml) xml.editorialgroup do |a| a.committee node.attr("technical-committee"), **attr_code(type: node.attr("technical-committee-type")) end end |
#metadata_copyright(node, xml) ⇒ Object
77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/asciidoctor/m3d/converter.rb', line 77 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 "Ribose" end end end end |
#metadata_id(node, xml) ⇒ Object
73 74 75 |
# File 'lib/asciidoctor/m3d/converter.rb', line 73 def (node, xml) xml.docidentifier { |i| i << node.attr("docnumber") } end |
#metadata_publisher(node, xml) ⇒ Object
45 46 47 48 49 50 51 52 |
# File 'lib/asciidoctor/m3d/converter.rb', line 45 def (node, xml) xml.contributor do |c| c.role **{ type: "publisher" } c.organization do |a| a.name "Ribose" end end end |
#metadata_source(node, xml) ⇒ Object
31 32 33 34 |
# File 'lib/asciidoctor/m3d/converter.rb', line 31 def (node, xml) return unless node.attr("url") xml.source node.attr("url") end |
#metadata_status(node, xml) ⇒ Object
69 70 71 |
# File 'lib/asciidoctor/m3d/converter.rb', line 69 def (node, xml) xml.status(**{ format: "plain" }) { |s| s << node.attr("status") } end |
#sections_cleanup(x) ⇒ Object
145 146 147 148 149 150 |
# File 'lib/asciidoctor/m3d/converter.rb', line 145 def sections_cleanup(x) super x.xpath("//*[@inline-header]").each do |h| h.delete("inline-header") end end |
#style(n, t) ⇒ Object
152 153 154 |
# File 'lib/asciidoctor/m3d/converter.rb', line 152 def style(n, t) return end |
#title(node, xml) ⇒ Object
61 62 63 64 65 66 67 |
# File 'lib/asciidoctor/m3d/converter.rb', line 61 def title(node, xml) ["en"].each do |lang| xml.title **{ language: lang, format: "plain" } do |t| t << asciidoc_sub(node.attr("title")) end end end |
#title_validate(root) ⇒ Object
89 90 91 |
# File 'lib/asciidoctor/m3d/converter.rb', line 89 def title_validate(root) nil end |
#validate(doc) ⇒ Object
130 131 132 133 134 |
# File 'lib/asciidoctor/m3d/converter.rb', line 130 def validate(doc) content_validate(doc) schema_validate(formattedstr_strip(doc.dup), File.join(File.dirname(__FILE__), "m3d.rng")) end |
#word_converter(node) ⇒ Object
172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 |
# File 'lib/asciidoctor/m3d/converter.rb', line 172 def word_converter(node) IsoDoc::M3d::WordConvert.new( script: node.attr("script"), bodyfont: node.attr("body-font"), headerfont: node.attr("header-font"), monospacefont: node.attr("monospace-font"), titlefont: node.attr("title-font"), i18nyaml: node.attr("i18nyaml"), scope: node.attr("scope"), wordstylesheet: node.attr("wordstylesheet"), standardstylesheet: node.attr("standardstylesheet"), header: node.attr("header"), wordcoverpage: node.attr("wordcoverpage"), wordintropage: node.attr("wordintropage"), ulstyle: node.attr("ulstyle"), olstyle: node.attr("olstyle"), ) end |