Class: Asciidoctor::Csand::Converter

Inherits:
Standoc::Converter
  • Object
show all
Defined in:
lib/asciidoctor/csand/converter.rb,
lib/asciidoctor/csand/validate.rb

Overview

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

Instance Method Summary collapse

Instance Method Details

#bibdata_validate(doc) ⇒ Object



9
10
11
# File 'lib/asciidoctor/csand/validate.rb', line 9

def bibdata_validate(doc)
  stage_validate(doc)
end

#content_validate(doc) ⇒ Object



4
5
6
7
# File 'lib/asciidoctor/csand/validate.rb', line 4

def content_validate(doc)
  super
  bibdata_validate(doc.root)
end

#doctype(node) ⇒ Object



92
93
94
95
96
97
98
99
# File 'lib/asciidoctor/csand/converter.rb', line 92

def doctype(node)
  d = node.attr("doctype")
  unless %w{guidance proposal standard report whitepaper charter policy glossary case-study}.include? d
    warn "#{d} is not a legal document type: reverting to 'standard'"
    d = "standard"
  end
  d
end

#document(node) ⇒ Object



101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'lib/asciidoctor/csand/converter.rb', line 101

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")
    pdf_converter(node).convert filename unless node.attr("nodoc")
    word_converter(node).convert filename unless node.attr("nodoc")
  end
  @files_to_delete.each { |f| FileUtils.rm f }
  ret
end

#html_converter(node) ⇒ Object



134
135
136
# File 'lib/asciidoctor/csand/converter.rb', line 134

def html_converter(node)
  IsoDoc::Csand::HtmlConvert.new(html_extract_attributes(node))
end

#makexml(node) ⇒ Object



79
80
81
82
83
84
85
86
87
88
89
90
# File 'lib/asciidoctor/csand/converter.rb', line 79

def makexml(node)
  result = ["<?xml version='1.0' encoding='UTF-8'?>\n<csand-standard>"]
  @draft = node.attributes.has_key?("draft")
  result << noko { |ixml| front node, ixml }
  result << noko { |ixml| middle node, ixml }
  result << "</csand-standard>"
  result = textcleanup(result)
  ret1 = cleanup(Nokogiri::XML(result))
  validate(ret1) unless @novalid
  ret1.root.add_namespace(nil, CSAND_NAMESPACE)
  ret1
end

#metadata_author(node, xml) ⇒ Object



18
19
20
21
22
23
24
25
# File 'lib/asciidoctor/csand/converter.rb', line 18

def (node, xml)
  xml.contributor do |c|
    c.role **{ type: "author" }
    c.organization do |a|
      a.name "Cloud Security Alliance"
    end
  end
end

#metadata_committee(node, xml) ⇒ Object



36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/asciidoctor/csand/converter.rb', line 36

def (node, xml)
  return unless node.attr("technical-committee")
  xml.editorialgroup do |a|
    a.committee node.attr("technical-committee"),
      **attr_code(type: node.attr("technical-committee-type"))
    i = 2
    while node.attr("technical-committee_#{i}") do
      a.committee node.attr("technical-committee_#{i}"),
        **attr_code(type: node.attr("technical-committee-type_#{i}"))
      i += 1
    end
  end
end


63
64
65
66
67
68
69
70
71
72
73
# File 'lib/asciidoctor/csand/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 "Cloud Security Alliance"
      end
    end
  end
end

#metadata_id(node, xml) ⇒ Object



50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/asciidoctor/csand/converter.rb', line 50

def (node, xml)
  docstatus = node.attr("status")
  dn = node.attr("docnumber")
  if docstatus
    abbr = IsoDoc::Csand::.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: "csand"}
  xml.docnumber { |i| i << node.attr("docnumber") }
end

#metadata_publisher(node, xml) ⇒ Object



27
28
29
30
31
32
33
34
# File 'lib/asciidoctor/csand/converter.rb', line 27

def (node, xml)
  xml.contributor do |c|
    c.role **{ type: "publisher" }
    c.organization do |a|
      a.name "Cloud Security Alliance"
    end
  end
end

#pdf_converter(node) ⇒ Object



137
138
139
# File 'lib/asciidoctor/csand/converter.rb', line 137

def pdf_converter(node)
  IsoDoc::Csand::PdfConvert.new(html_extract_attributes(node))
end

#sections_cleanup(x) ⇒ Object



123
124
125
126
127
128
# File 'lib/asciidoctor/csand/converter.rb', line 123

def sections_cleanup(x)
  super
  x.xpath("//*[@inline-header]").each do |h|
    h.delete("inline-header")
  end
end

#stage_validate(xmldoc) ⇒ Object



13
14
15
16
17
18
# File 'lib/asciidoctor/csand/validate.rb', line 13

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
    warn "Document Attributes: #{stage} is not a recognised status"
end

#style(n, t) ⇒ Object



130
131
132
# File 'lib/asciidoctor/csand/converter.rb', line 130

def style(n, t)
  return
end

#title_validate(root) ⇒ Object



75
76
77
# File 'lib/asciidoctor/csand/converter.rb', line 75

def title_validate(root)
  nil
end

#validate(doc) ⇒ Object



117
118
119
120
121
# File 'lib/asciidoctor/csand/converter.rb', line 117

def validate(doc)
  content_validate(doc)
  schema_validate(formattedstr_strip(doc.dup),
                  File.join(File.dirname(__FILE__), "csand.rng"))
end

#word_converter(node) ⇒ Object



140
141
142
# File 'lib/asciidoctor/csand/converter.rb', line 140

def word_converter(node)
  IsoDoc::Csand::WordConvert.new(doc_extract_attributes(node))
end