metanorma-standoc 2.9.6 → 2.9.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/isodoc/html/htmlstyle.css +4 -1
- data/lib/metanorma/standoc/basicdoc.rng +861 -481
- data/lib/metanorma/standoc/biblio-standoc.rng +100 -20
- data/lib/metanorma/standoc/biblio.rng +897 -333
- data/lib/metanorma/standoc/cleanup_bibdata.rb +2 -0
- data/lib/metanorma/standoc/cleanup_maths.rb +13 -11
- data/lib/metanorma/standoc/cleanup_text.rb +9 -2
- data/lib/metanorma/standoc/converter.rb +2 -0
- data/lib/metanorma/standoc/front.rb +6 -0
- data/lib/metanorma/standoc/init.rb +19 -6
- data/lib/metanorma/standoc/inline.rb +15 -7
- data/lib/metanorma/standoc/isodoc.rng +1031 -915
- data/lib/metanorma/standoc/macros_embed.rb +2 -2
- data/lib/metanorma/standoc/macros_inline.rb +8 -6
- data/lib/metanorma/standoc/render.rb +1 -1
- data/lib/metanorma/standoc/reqt.rng +94 -75
- data/lib/metanorma/standoc/spans_to_bibitem.rb +7 -0
- data/lib/metanorma/standoc/spans_to_bibitem_preprocessing.rb +13 -4
- data/lib/metanorma/standoc/utils.rb +12 -1
- data/lib/metanorma/standoc/version.rb +1 -1
- metadata +2 -2
@@ -66,8 +66,8 @@ module Metanorma
|
|
66
66
|
# -- but it won't: https://github.com/metanorma/metanorma-standoc/issues/802
|
67
67
|
def read_flattened_embeds(ret, doc)
|
68
68
|
reader = ::Asciidoctor::PreprocessorReader.new doc
|
69
|
-
|
70
|
-
ret.
|
69
|
+
Pathname.new doc.base_dir
|
70
|
+
ret.reverse_each do |l|
|
71
71
|
# if l[:file]
|
72
72
|
# new = Pathname.new(l[:path]).relative_path_from(b).to_s
|
73
73
|
# reader.push_include l[:lines], new, l[:path]
|
@@ -160,24 +160,26 @@ module Metanorma
|
|
160
160
|
str.sub(/^(["'])(.+)\1$/, "\\2")
|
161
161
|
end
|
162
162
|
|
163
|
-
def format(attrs)
|
163
|
+
def format(attrs, number)
|
164
164
|
# a="," => "a=,"
|
165
|
-
quoted_csv_split(attrs || "", ",").map do |x|
|
166
|
-
m = /^(.+?)=(.+)?$/.match(x) or next
|
165
|
+
out = quoted_csv_split(attrs || "", ",").map do |x|
|
166
|
+
m = /^(.+?)=(.+)?$/.match(HTMLEntities.new.decode(x)) or next
|
167
167
|
"#{m[1]}='#{m[2]}'"
|
168
|
-
end
|
168
|
+
end
|
169
|
+
/^\+/.match?(number.strip) and out << "number_sign='plus'"
|
170
|
+
out.join(",")
|
169
171
|
end
|
170
172
|
|
171
173
|
def number(text)
|
172
174
|
n = BigDecimal(text)
|
173
175
|
trailing_zeroes = 0
|
174
176
|
m = /\.[1-9]*(0+)/.match(text) and trailing_zeroes += m[1].size
|
175
|
-
n.to_s("E").sub("e", "0" * trailing_zeroes + "e")
|
177
|
+
n.to_s("E").sub("e", "0" * trailing_zeroes + "e") # rubocop:disable Style/StringConcatenation
|
176
178
|
end
|
177
179
|
|
178
180
|
def process(parent, target, attrs)
|
179
181
|
out = Asciidoctor::Inline.new(parent, :quoted, attrs["text"]).convert
|
180
|
-
fmt = format(out)
|
182
|
+
fmt = format(out, target)
|
181
183
|
fmt.empty? and fmt = "default"
|
182
184
|
fmt = %( number-format="#{fmt}")
|
183
185
|
<<~OUTPUT
|
@@ -93,7 +93,7 @@ module Metanorma
|
|
93
93
|
pdf-allow-print pdf-allow-print-hq
|
94
94
|
pdf-allow-access-content pdf-encrypt-metadata fonts
|
95
95
|
font-license-agreement).each_with_object({}) do |x, m|
|
96
|
-
m[x.
|
96
|
+
m[x.delete("-").to_i] = node.attr(x)
|
97
97
|
end
|
98
98
|
|
99
99
|
pdf_options.merge(fonts_manifest_option(node) || {})
|
@@ -1,20 +1,27 @@
|
|
1
1
|
<?xml version="1.0" encoding="UTF-8"?>
|
2
|
-
<grammar xmlns="http://relaxng.org/ns/structure/1.0" datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes">
|
2
|
+
<grammar xmlns:a="http://relaxng.org/ns/compatibility/annotations/1.0" xmlns="http://relaxng.org/ns/structure/1.0" datatypeLibrary="http://www.w3.org/2001/XMLSchema-datatypes">
|
3
3
|
<!--
|
4
4
|
Presupposes isodoc.rnc, is included in it
|
5
5
|
include "isodoc.rnc" { }
|
6
|
+
|
7
|
+
This is the Metanorma default provisions model; it is overridden by other provisions models,
|
8
|
+
such as Modspec
|
6
9
|
-->
|
7
10
|
<define name="requirement">
|
11
|
+
<a:documentation>Specification of an attribute of a subject that is required.
|
12
|
+
NOTE: A requirement can contain other requirements</a:documentation>
|
8
13
|
<element name="requirement">
|
9
14
|
<ref name="RequirementType"/>
|
10
15
|
</element>
|
11
16
|
</define>
|
12
17
|
<define name="recommendation">
|
18
|
+
<a:documentation>Specification of an attribute of a subject that is recommended</a:documentation>
|
13
19
|
<element name="recommendation">
|
14
20
|
<ref name="RequirementType"/>
|
15
21
|
</element>
|
16
22
|
</define>
|
17
23
|
<define name="permission">
|
24
|
+
<a:documentation>Specification of an attribute of a subject that is permitted</a:documentation>
|
18
25
|
<element name="permission">
|
19
26
|
<ref name="RequirementType"/>
|
20
27
|
</element>
|
@@ -22,83 +29,101 @@
|
|
22
29
|
<define name="RequirementType">
|
23
30
|
<optional>
|
24
31
|
<attribute name="obligation">
|
25
|
-
<
|
26
|
-
|
27
|
-
|
28
|
-
<optional>
|
29
|
-
<attribute name="unnumbered">
|
30
|
-
<data type="boolean"/>
|
31
|
-
</attribute>
|
32
|
-
</optional>
|
33
|
-
<optional>
|
34
|
-
<attribute name="number"/>
|
35
|
-
</optional>
|
36
|
-
<optional>
|
37
|
-
<attribute name="subsequence"/>
|
38
|
-
</optional>
|
39
|
-
<optional>
|
40
|
-
<attribute name="keep-with-next">
|
41
|
-
<data type="boolean"/>
|
42
|
-
</attribute>
|
43
|
-
</optional>
|
44
|
-
<optional>
|
45
|
-
<attribute name="keep-lines-together">
|
46
|
-
<data type="boolean"/>
|
32
|
+
<a:documentation>An attribute that may be used to override the obligation represented in
|
33
|
+
the tag name of the top level containers</a:documentation>
|
34
|
+
<ref name="ReqtObligationType"/>
|
47
35
|
</attribute>
|
48
36
|
</optional>
|
49
37
|
<attribute name="id">
|
50
38
|
<data type="ID"/>
|
51
39
|
</attribute>
|
40
|
+
<ref name="NumberingAttributes"/>
|
41
|
+
<ref name="BlockAttributes"/>
|
52
42
|
<optional>
|
53
|
-
<attribute name="filename"
|
54
|
-
|
55
|
-
|
56
|
-
<attribute name="model"/>
|
57
|
-
</optional>
|
58
|
-
<optional>
|
59
|
-
<attribute name="type"/>
|
43
|
+
<attribute name="filename">
|
44
|
+
<a:documentation>File name of the requirement model when exported</a:documentation>
|
45
|
+
</attribute>
|
60
46
|
</optional>
|
61
47
|
<optional>
|
62
|
-
<attribute name="
|
48
|
+
<attribute name="model">
|
49
|
+
<a:documentation>Model of requirements realised by this requirement, e.g. "ogc" for Modspec</a:documentation>
|
50
|
+
</attribute>
|
63
51
|
</optional>
|
64
52
|
<optional>
|
65
|
-
<attribute name="
|
66
|
-
<
|
53
|
+
<attribute name="type">
|
54
|
+
<a:documentation>Type of requirement; does not override labelling, unlike `class`</a:documentation>
|
67
55
|
</attribute>
|
68
56
|
</optional>
|
69
57
|
<optional>
|
70
|
-
<attribute name="class"
|
58
|
+
<attribute name="class">
|
59
|
+
<a:documentation>Class of provision, used to sequence and label that class separately.
|
60
|
+
By default, provisions are sequenced and labelled as requirements, recommendations, or
|
61
|
+
permissions, by obligation; the class overrides that</a:documentation>
|
62
|
+
</attribute>
|
71
63
|
</optional>
|
72
64
|
<optional>
|
73
|
-
<ref name="reqtitle"
|
65
|
+
<ref name="reqtitle">
|
66
|
+
<a:documentation>Human-readable title of the requirement</a:documentation>
|
67
|
+
</ref>
|
74
68
|
</optional>
|
75
69
|
<optional>
|
76
|
-
<ref name="
|
70
|
+
<ref name="reqtlabel">
|
71
|
+
<a:documentation>Formal identifier with which the requirement is referenced</a:documentation>
|
72
|
+
</ref>
|
77
73
|
</optional>
|
78
74
|
<zeroOrMore>
|
79
|
-
<ref name="subject"
|
75
|
+
<ref name="subject">
|
76
|
+
<a:documentation>The party subject to the obligation stated in the requirement</a:documentation>
|
77
|
+
</ref>
|
80
78
|
</zeroOrMore>
|
81
79
|
<zeroOrMore>
|
82
|
-
<ref name="reqinherit"
|
80
|
+
<ref name="reqinherit">
|
81
|
+
<a:documentation>Reference to the identifier of another requirement, of which this requirement
|
82
|
+
is a subclass, and from which it inherits attributes</a:documentation>
|
83
|
+
</ref>
|
83
84
|
</zeroOrMore>
|
84
85
|
<zeroOrMore>
|
85
|
-
<ref name="classification"
|
86
|
+
<ref name="classification">
|
87
|
+
<a:documentation>Key/Value pairs of metadata used to describe the requirement.
|
88
|
+
A key can be associated with multiple values</a:documentation>
|
89
|
+
</ref>
|
86
90
|
</zeroOrMore>
|
87
91
|
<zeroOrMore>
|
88
92
|
<choice>
|
89
|
-
<ref name="measurementtarget"
|
90
|
-
|
91
|
-
|
92
|
-
<ref name="
|
93
|
-
|
94
|
-
|
93
|
+
<ref name="measurementtarget">
|
94
|
+
<a:documentation>Quantitative statement of metrics that the requirement realises</a:documentation>
|
95
|
+
</ref>
|
96
|
+
<ref name="specification">
|
97
|
+
<a:documentation>Formal specification of the requirement. Expected to be machine-readable</a:documentation>
|
98
|
+
</ref>
|
99
|
+
<ref name="verification">
|
100
|
+
<a:documentation>Processes or code used to verify that the requirement is being complied
|
101
|
+
with. Can be a test (including test code), or a compliance statement</a:documentation>
|
102
|
+
</ref>
|
103
|
+
<ref name="import">
|
104
|
+
<a:documentation>A reference to source code or a statement of prerequisites which is defined elsewhere</a:documentation>
|
105
|
+
</ref>
|
106
|
+
<ref name="description">
|
107
|
+
<a:documentation>Descriptive statement of the content of the requirement. Is expected to
|
108
|
+
be human-readable, and to contain formatting markup following Metanorma
|
109
|
+
conventions. Is expected to be discursive, and be resumed after
|
110
|
+
interruption by other sub-containers</a:documentation>
|
111
|
+
</ref>
|
112
|
+
<ref name="component">
|
113
|
+
<a:documentation>Provisions nested within this provision, which cannot be referenced autonomously and have
|
114
|
+
subclasses specific to the parent provision. Not expressed with provision metadata</a:documentation>
|
115
|
+
</ref>
|
95
116
|
</choice>
|
96
117
|
</zeroOrMore>
|
97
118
|
<optional>
|
98
|
-
<ref name="reqt_references"
|
119
|
+
<ref name="reqt_references">
|
120
|
+
<a:documentation>A list of references for the requirement, following the Relaton model</a:documentation>
|
121
|
+
</ref>
|
99
122
|
</optional>
|
100
123
|
<zeroOrMore>
|
101
124
|
<choice>
|
125
|
+
<a:documentation>Provisions nested within this provision, which are self-standing and do not have
|
126
|
+
subclasses specific to the parent provision</a:documentation>
|
102
127
|
<ref name="requirement"/>
|
103
128
|
<ref name="recommendation"/>
|
104
129
|
<ref name="permission"/>
|
@@ -107,10 +132,10 @@
|
|
107
132
|
</define>
|
108
133
|
<define name="reqtitle">
|
109
134
|
<element name="title">
|
110
|
-
<ref name="
|
135
|
+
<ref name="LocalizedMarkedUpString"/>
|
111
136
|
</element>
|
112
137
|
</define>
|
113
|
-
<define name="
|
138
|
+
<define name="reqtlabel">
|
114
139
|
<element name="identifier">
|
115
140
|
<oneOrMore>
|
116
141
|
<ref name="TextElement"/>
|
@@ -158,7 +183,9 @@
|
|
158
183
|
</define>
|
159
184
|
<define name="component">
|
160
185
|
<element name="component">
|
161
|
-
<attribute name="class"
|
186
|
+
<attribute name="class">
|
187
|
+
<a:documentation>Class of component</a:documentation>
|
188
|
+
</attribute>
|
162
189
|
<ref name="RequirementSubpart"/>
|
163
190
|
</element>
|
164
191
|
</define>
|
@@ -170,44 +197,36 @@
|
|
170
197
|
</element>
|
171
198
|
</define>
|
172
199
|
<define name="RequirementSubpart">
|
173
|
-
<
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
200
|
+
<a:documentation>A subcontainer can be either machine-readable or human-readable, or a
|
201
|
+
mixture of the two.
|
202
|
+
A machine-readable component can be included as source code with
|
203
|
+
nomination of the language</a:documentation>
|
204
|
+
<optional>
|
205
|
+
<attribute name="type">
|
206
|
+
<a:documentation>Type of sub-container.
|
207
|
+
For example a `verification[@type = "unit-test"]` contains a unit test of a single
|
208
|
+
feature, and is to be treated differently from
|
209
|
+
`verification[@type = "comprehensive"]`, which represents a comprehensive test suite</a:documentation>
|
179
210
|
</attribute>
|
180
211
|
</optional>
|
181
212
|
<optional>
|
182
|
-
<attribute name="
|
183
|
-
<
|
184
|
-
|
185
|
-
</optional>
|
186
|
-
<optional>
|
187
|
-
<attribute name="keep-lines-together">
|
213
|
+
<attribute name="exclude">
|
214
|
+
<a:documentation>Indicates that the current sub-container is only intended to be
|
215
|
+
machine-readable, and is not to be rendered as document output</a:documentation>
|
188
216
|
<data type="boolean"/>
|
189
217
|
</attribute>
|
190
218
|
</optional>
|
191
|
-
<
|
192
|
-
<attribute name="tag"/>
|
193
|
-
</optional>
|
194
|
-
<optional>
|
195
|
-
<attribute name="multilingual-rendering">
|
196
|
-
<ref name="MultilingualRenderingType"/>
|
197
|
-
</attribute>
|
198
|
-
</optional>
|
219
|
+
<ref name="BlockAttributes"/>
|
199
220
|
<oneOrMore>
|
200
221
|
<choice>
|
222
|
+
<a:documentation>Content of subpart: blocks, rather than provisions</a:documentation>
|
201
223
|
<ref name="BasicBlock"/>
|
202
224
|
<ref name="component"/>
|
203
225
|
</choice>
|
204
226
|
</oneOrMore>
|
205
227
|
</define>
|
206
|
-
<define name="
|
207
|
-
<
|
208
|
-
|
209
|
-
<value>recommendation</value>
|
210
|
-
<value>permission</value>
|
211
|
-
</choice>
|
228
|
+
<define name="ReqtObligationType">
|
229
|
+
<a:documentation>Values are "requirement", "recommendation", "permission"; multiple values can be comma-delimited</a:documentation>
|
230
|
+
<text/>
|
212
231
|
</define>
|
213
232
|
</grammar>
|
@@ -38,10 +38,17 @@ module Metanorma
|
|
38
38
|
ret += spans_to_bibitem_docid(spans)
|
39
39
|
ret += spans_to_contribs(spans)
|
40
40
|
ret += spans_to_bibitem_edn(spans)
|
41
|
+
spans[:abstract] and ret += "<abstract>#{spans[:abstract]}</abstract>"
|
41
42
|
ret += spans_to_series(spans)
|
42
43
|
spans[:pubplace] and ret += "<place>#{spans[:pubplace]}</place>"
|
43
44
|
ret += spans_to_bibitem_host(spans)
|
44
45
|
ret += spans_to_bibitem_extent(spans[:extent])
|
46
|
+
spans[:classification]&.each do |s|
|
47
|
+
ret += span_to_docid(s, "classification")
|
48
|
+
end
|
49
|
+
spans[:image]&.each do |s|
|
50
|
+
ret += "<depiction>#{s[:val]}</depiction>"
|
51
|
+
end
|
45
52
|
ret
|
46
53
|
end
|
47
54
|
|
@@ -3,10 +3,15 @@ module Metanorma
|
|
3
3
|
module Cleanup
|
4
4
|
class SpansToBibitem
|
5
5
|
def extract_spans(bib)
|
6
|
-
bib.xpath("./formattedref//span").each_with_object([]) do |s, m|
|
6
|
+
ret = bib.xpath("./formattedref//span").each_with_object([]) do |s, m|
|
7
7
|
s.at("./ancestor::span") and next
|
8
8
|
extract_spans1(s, m)
|
9
9
|
end
|
10
|
+
bib.xpath("./formattedref//image").each do |i|
|
11
|
+
i.delete("id")
|
12
|
+
ret << { key: "image", type: nil, val: i.remove.to_xml }
|
13
|
+
end
|
14
|
+
ret
|
10
15
|
end
|
11
16
|
|
12
17
|
def extract_spans1(span, acc)
|
@@ -25,7 +30,8 @@ module Metanorma
|
|
25
30
|
end
|
26
31
|
|
27
32
|
def empty_span_hash
|
28
|
-
{ contrib: [], docid: [], uri: [], date: [],
|
33
|
+
{ contrib: [], docid: [], uri: [], date: [], classification: [],
|
34
|
+
image: [], extent: {}, in: {} }
|
29
35
|
end
|
30
36
|
|
31
37
|
def spans_preprocess(spans)
|
@@ -36,7 +42,7 @@ module Metanorma
|
|
36
42
|
|
37
43
|
def span_preprocess1(span, ret)
|
38
44
|
case span[:key]
|
39
|
-
when "uri", "docid"
|
45
|
+
when "uri", "docid", "classification"
|
40
46
|
val = link_unwrap(Nokogiri::XML.fragment(span[:val])).to_xml
|
41
47
|
ret[span[:key].to_sym] << { type: span[:type], val: }
|
42
48
|
when "date"
|
@@ -45,8 +51,11 @@ module Metanorma
|
|
45
51
|
when "pages", "volume", "issue"
|
46
52
|
ret[:extent][span[:key].to_sym] ||= []
|
47
53
|
ret[:extent][span[:key].to_sym] << span[:val]
|
48
|
-
when "pubplace", "title", "type", "series", "edition", "version"
|
54
|
+
when "pubplace", "title", "type", "series", "edition", "version",
|
55
|
+
"abstract"
|
49
56
|
ret[span[:key].to_sym] = span[:val]
|
57
|
+
when "image"
|
58
|
+
ret[span[:key].to_sym] << { type: span[:type], val: span[:val] }
|
50
59
|
when "note"
|
51
60
|
ret[span[:key].to_sym] = { type: span[:type], val: span[:val] }
|
52
61
|
when "in_title"
|
@@ -13,6 +13,16 @@ module Metanorma
|
|
13
13
|
opts.empty? ? (send transform, node) : (send transform, node, opts)
|
14
14
|
end
|
15
15
|
|
16
|
+
def processor
|
17
|
+
parent_type = self.class.name.split("::")[0...-1]
|
18
|
+
parent_type << "Processor"
|
19
|
+
begin
|
20
|
+
Object.const_get(parent_type.join("::"))
|
21
|
+
rescue NameError
|
22
|
+
nil
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
16
26
|
def document_ns_attributes(_doc)
|
17
27
|
nil
|
18
28
|
end
|
@@ -37,7 +47,8 @@ module Metanorma
|
|
37
47
|
%("\\1#{eql}\\3"))
|
38
48
|
Metanorma::Utils::csv_split(text, delim)
|
39
49
|
.map do |x|
|
40
|
-
c.encode(x.sub(/^(["'])(.+)\1$/, "\\2"),
|
50
|
+
c.encode(x.sub(/^(["'])(.+)\1$/, "\\2"),
|
51
|
+
:basic, :hexadecimal)
|
41
52
|
end
|
42
53
|
end
|
43
54
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: metanorma-standoc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.9.
|
4
|
+
version: 2.9.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ribose Inc.
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-10-14 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: addressable
|