metanorma-standoc 1.10.4.1 → 1.10.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.adoc +19 -23
- data/lib/asciidoctor/standoc/base.rb +11 -13
- data/lib/asciidoctor/standoc/basicdoc.rng +21 -4
- data/lib/asciidoctor/standoc/blocks.rb +27 -22
- data/lib/asciidoctor/standoc/blocks_notes.rb +17 -22
- data/lib/asciidoctor/standoc/cleanup.rb +38 -71
- data/lib/asciidoctor/standoc/cleanup_block.rb +5 -70
- data/lib/asciidoctor/standoc/cleanup_image.rb +6 -7
- data/lib/asciidoctor/standoc/cleanup_inline.rb +27 -98
- data/lib/asciidoctor/standoc/cleanup_maths.rb +113 -21
- data/lib/asciidoctor/standoc/cleanup_ref.rb +5 -0
- data/lib/asciidoctor/standoc/cleanup_reqt.rb +56 -18
- data/lib/asciidoctor/standoc/cleanup_section.rb +1 -0
- data/lib/asciidoctor/standoc/cleanup_section_names.rb +31 -14
- data/lib/asciidoctor/standoc/cleanup_table.rb +68 -0
- data/lib/asciidoctor/standoc/cleanup_terms.rb +1 -1
- data/lib/asciidoctor/standoc/cleanup_text.rb +73 -0
- data/lib/asciidoctor/standoc/cleanup_xref.rb +107 -0
- data/lib/asciidoctor/standoc/converter.rb +13 -0
- data/lib/asciidoctor/standoc/isodoc.rng +241 -61
- data/lib/asciidoctor/standoc/lists.rb +15 -15
- data/lib/asciidoctor/standoc/macros.rb +14 -43
- data/lib/asciidoctor/standoc/macros_note.rb +45 -0
- data/lib/asciidoctor/standoc/macros_terms.rb +33 -15
- data/lib/asciidoctor/standoc/reqt.rb +2 -2
- data/lib/asciidoctor/standoc/reqt.rng +23 -2
- data/lib/asciidoctor/standoc/table.rb +22 -20
- data/lib/asciidoctor/standoc/terms.rb +9 -1
- data/lib/asciidoctor/standoc/validate.rb +23 -14
- data/lib/asciidoctor/standoc/validate_section.rb +5 -2
- data/lib/metanorma/standoc/version.rb +1 -1
- data/metanorma-standoc.gemspec +1 -1
- data/spec/asciidoctor/base_spec.rb +0 -33
- data/spec/asciidoctor/blank_spec.rb +37 -0
- data/spec/asciidoctor/blocks_spec.rb +151 -30
- data/spec/asciidoctor/cleanup_blocks_spec.rb +1018 -0
- data/spec/asciidoctor/cleanup_sections_spec.rb +207 -0
- data/spec/asciidoctor/cleanup_spec.rb +193 -1078
- data/spec/asciidoctor/inline_spec.rb +36 -0
- data/spec/asciidoctor/isobib_cache_spec.rb +8 -8
- data/spec/asciidoctor/lists_spec.rb +6 -6
- data/spec/asciidoctor/macros_plantuml_spec.rb +1 -1
- data/spec/asciidoctor/macros_spec.rb +41 -26
- data/spec/asciidoctor/refs_dl_spec.rb +1 -1
- data/spec/asciidoctor/refs_spec.rb +220 -444
- data/spec/asciidoctor/section_spec.rb +1 -1
- data/spec/asciidoctor/validate_spec.rb +51 -0
- data/spec/assets/xref_error.adoc +1 -0
- data/spec/fixtures/datamodel_description_sections_tree.xml +24 -24
- data/spec/spec_helper.rb +5 -7
- data/spec/vcr_cassettes/dated_iso_ref_joint_iso_iec.yml +231 -143
- data/spec/vcr_cassettes/dated_iso_ref_joint_iso_iec1.yml +152 -0
- data/spec/vcr_cassettes/isobib_get_123.yml +52 -36
- data/spec/vcr_cassettes/isobib_get_123_1.yml +103 -71
- data/spec/vcr_cassettes/isobib_get_123_1_fr.yml +112 -80
- data/spec/vcr_cassettes/isobib_get_123_2001.yml +50 -34
- data/spec/vcr_cassettes/isobib_get_124.yml +51 -35
- data/spec/vcr_cassettes/rfcbib_get_rfc8341.yml +16 -16
- data/spec/vcr_cassettes/separates_iev_citations_by_top_level_clause.yml +70 -46
- metadata +11 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2cc836755aed6cfff989fdcbc9cf8123ccfda29418247d93fdd75ba71660cee7
|
4
|
+
data.tar.gz: d1c051429283a6e4153a6a3453b839786561c0975c2acda0586cb0ca787ae26a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1e17a3351bf46679b587a82498d5f58d97e43743bd2e6906c929aa8dcbb8ca29fdd6e38acb82252375b40e5fff520f7d6a001b023c9c79681ad61fea949c0799
|
7
|
+
data.tar.gz: 01dd1e74b7990b44c526616611155067c0725b0b0bcaeebe9d728c341d26acdab64c2c5be7519b22b94fd641015aec504c333c3b3da8cf6067c19999c20ab0ff
|
data/README.adoc
CHANGED
@@ -10,26 +10,24 @@ Gem for serialising the https://github.com/metanorma/metanorma-model-standoc[Met
|
|
10
10
|
|
11
11
|
== Functionality
|
12
12
|
|
13
|
-
This gem processes Metanorma
|
14
|
-
|
15
|
-
to each standards class is refined in the gem specific to that standards class
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
*
|
22
|
-
|
23
|
-
|
13
|
+
This gem processes Metanorma AsciiDoc input into the Metanorma document model.
|
14
|
+
This gem provides underlying generic functionality; behaviour specific
|
15
|
+
to each standards class is refined in the gem specific to that standards class
|
16
|
+
(e.g. https://github.com/metanorma/metanorma-iso[Metanorma ISO]).
|
17
|
+
|
18
|
+
The following outputs are generated:
|
19
|
+
|
20
|
+
* Metanorma semantic XML
|
21
|
+
* Metanorma presentation XML
|
22
|
+
|
23
|
+
These Metanorma XML representations are processed downstream by the `isodoc` gem
|
24
|
+
to generate other end deliverables, depending on each standards class.
|
24
25
|
|
25
26
|
The following input formats are supported:
|
26
27
|
|
27
|
-
*
|
28
|
+
* Metanorma AsciiDoc
|
28
29
|
|
29
|
-
|
30
|
-
https://github.com/metanorma/metanorma-iso/blob/master/docs/guidance.adoc[Guidance for authoring].
|
31
|
-
https://github.com/metanorma/metanorma-iso/blob/master/docs/quickstart.adoc[Quickstart guide]
|
32
|
-
gives a summary overview.
|
30
|
+
See the https://www.metanorma.org[Metanorma website] for more information.
|
33
31
|
|
34
32
|
NOTE: http://asciimath.org[AsciiMathML] is used for mathematical formatting.
|
35
33
|
The gem uses the https://github.com/asciidoctor/asciimath[Ruby AsciiMath parser],
|
@@ -39,21 +37,19 @@ expressions.
|
|
39
37
|
|
40
38
|
=== Installation
|
41
39
|
|
42
|
-
|
43
|
-
|
44
|
-
|
40
|
+
See the https://www.metanorma.org[Metanorma website] for instructions.
|
41
|
+
|
42
|
+
In the terminal:
|
45
43
|
|
46
44
|
[source,console]
|
47
45
|
----
|
48
|
-
$ bash <(curl -s https://raw.githubusercontent.com/metanorma/metanorma-macos-setup/master/metanorma-setup)
|
49
46
|
$ gem install metanorma-standoc
|
50
47
|
$ gem install metanorma-cli
|
51
48
|
----
|
52
49
|
|
53
|
-
|
50
|
+
`metanorma-cli` is the command-line interface for the Metanorma suite
|
54
51
|
(incorporating the `metanorma` executable seen above).
|
55
52
|
|
56
53
|
== Documentation
|
57
54
|
|
58
|
-
See
|
59
|
-
|
55
|
+
See the https://www.metanorma.org[Metanorma website] for details.
|
@@ -23,17 +23,6 @@ module Asciidoctor
|
|
23
23
|
self.class::XML_NAMESPACE
|
24
24
|
end
|
25
25
|
|
26
|
-
def content(node)
|
27
|
-
node.content
|
28
|
-
end
|
29
|
-
|
30
|
-
def skip(node, name = nil)
|
31
|
-
name = name || node.node_name
|
32
|
-
w = "converter missing for #{name} node in Metanorma backend"
|
33
|
-
@log.add("AsciiDoc Input", node, w)
|
34
|
-
nil
|
35
|
-
end
|
36
|
-
|
37
26
|
def html_extract_attributes(node)
|
38
27
|
{
|
39
28
|
script: node.attr("script"),
|
@@ -53,8 +42,11 @@ module Asciidoctor
|
|
53
42
|
htmltoclevels: node.attr("htmltoclevels") || node.attr("toclevels"),
|
54
43
|
doctoclevels: node.attr("doctoclevels") || node.attr("toclevels"),
|
55
44
|
break_up_urls_in_tables: node.attr("break-up-urls-in-tables"),
|
45
|
+
suppressasciimathdup: node.attr("suppress-asciimath-dup"),
|
56
46
|
bare: node.attr("bare"),
|
57
47
|
sectionsplit: node.attr("sectionsplit"),
|
48
|
+
baseassetpath: node.attr("base-asset-path"),
|
49
|
+
aligncrosselements: node.attr("align-cross-elements"),
|
58
50
|
}
|
59
51
|
end
|
60
52
|
|
@@ -87,7 +79,10 @@ module Asciidoctor
|
|
87
79
|
htmltoclevels: node.attr("htmltoclevels") || node.attr("toclevels"),
|
88
80
|
doctoclevels: node.attr("doctoclevels") || node.attr("toclevels"),
|
89
81
|
break_up_urls_in_tables: node.attr("break-up-urls-in-tables"),
|
82
|
+
suppressasciimathdup: node.attr("suppress-asciimath-dup"),
|
90
83
|
bare: node.attr("bare"),
|
84
|
+
baseassetpath: node.attr("base-asset-path"),
|
85
|
+
aligncrosselements: node.attr("align-cross-elements"),
|
91
86
|
}
|
92
87
|
|
93
88
|
if font_manifest_file = node.attr("mn2pdf-font-manifest-file")
|
@@ -122,8 +117,7 @@ module Asciidoctor
|
|
122
117
|
@files_to_delete = []
|
123
118
|
@filename = if node.attr("docfile")
|
124
119
|
File.basename(node.attr("docfile"))&.gsub(/\.adoc$/, "")
|
125
|
-
else
|
126
|
-
""
|
120
|
+
else ""
|
127
121
|
end
|
128
122
|
@localdir = Metanorma::Utils::localdir(node)
|
129
123
|
@output_dir = outputdir node
|
@@ -172,6 +166,10 @@ module Asciidoctor
|
|
172
166
|
outputs(node, ret) unless node.attr("nodoc") || !node.attr("docfile")
|
173
167
|
clean_exit
|
174
168
|
ret
|
169
|
+
rescue StandardError => e
|
170
|
+
@log.add("Fatal Error", nil, e.message)
|
171
|
+
clean_exit
|
172
|
+
raise e
|
175
173
|
end
|
176
174
|
|
177
175
|
def version
|
@@ -624,6 +624,9 @@
|
|
624
624
|
<choice>
|
625
625
|
<ref name="PureTextElement"/>
|
626
626
|
<ref name="stem"/>
|
627
|
+
<ref name="eref"/>
|
628
|
+
<ref name="xref"/>
|
629
|
+
<ref name="hyperlink"/>
|
627
630
|
</choice>
|
628
631
|
</zeroOrMore>
|
629
632
|
</element>
|
@@ -634,6 +637,9 @@
|
|
634
637
|
<choice>
|
635
638
|
<ref name="PureTextElement"/>
|
636
639
|
<ref name="stem"/>
|
640
|
+
<ref name="eref"/>
|
641
|
+
<ref name="xref"/>
|
642
|
+
<ref name="hyperlink"/>
|
637
643
|
</choice>
|
638
644
|
</zeroOrMore>
|
639
645
|
</element>
|
@@ -641,7 +647,12 @@
|
|
641
647
|
<define name="tt">
|
642
648
|
<element name="tt">
|
643
649
|
<zeroOrMore>
|
644
|
-
<
|
650
|
+
<choice>
|
651
|
+
<ref name="PureTextElement"/>
|
652
|
+
<ref name="eref"/>
|
653
|
+
<ref name="xref"/>
|
654
|
+
<ref name="hyperlink"/>
|
655
|
+
</choice>
|
645
656
|
</zeroOrMore>
|
646
657
|
</element>
|
647
658
|
</define>
|
@@ -822,7 +833,9 @@
|
|
822
833
|
<attribute name="alt"/>
|
823
834
|
</optional>
|
824
835
|
<ref name="CitationType"/>
|
825
|
-
<
|
836
|
+
<oneOrMore>
|
837
|
+
<ref name="PureTextElement"/>
|
838
|
+
</oneOrMore>
|
826
839
|
</define>
|
827
840
|
<define name="hyperlink">
|
828
841
|
<element name="link">
|
@@ -835,7 +848,9 @@
|
|
835
848
|
<optional>
|
836
849
|
<attribute name="alt"/>
|
837
850
|
</optional>
|
838
|
-
<
|
851
|
+
<oneOrMore>
|
852
|
+
<ref name="PureTextElement"/>
|
853
|
+
</oneOrMore>
|
839
854
|
</element>
|
840
855
|
</define>
|
841
856
|
<define name="xref">
|
@@ -849,7 +864,9 @@
|
|
849
864
|
<optional>
|
850
865
|
<attribute name="alt"/>
|
851
866
|
</optional>
|
852
|
-
<
|
867
|
+
<oneOrMore>
|
868
|
+
<ref name="PureTextElement"/>
|
869
|
+
</oneOrMore>
|
853
870
|
</element>
|
854
871
|
</define>
|
855
872
|
<define name="fn">
|
@@ -6,14 +6,17 @@ module Asciidoctor
|
|
6
6
|
module Standoc
|
7
7
|
module Blocks
|
8
8
|
def id_attr(node = nil)
|
9
|
-
{ id: Metanorma::Utils::anchor_or_uuid(node)
|
9
|
+
{ id: Metanorma::Utils::anchor_or_uuid(node),
|
10
|
+
tag: node&.attr("tag"),
|
11
|
+
"multilingual-rendering": node&.attr("multilingual-rendering") }
|
10
12
|
end
|
11
13
|
|
12
14
|
def id_unnum_attrs(node)
|
13
|
-
attr_code(
|
14
|
-
|
15
|
-
|
16
|
-
|
15
|
+
attr_code(id_attr(node).merge(
|
16
|
+
unnumbered: node.option?("unnumbered") ? "true" : nil,
|
17
|
+
number: node.attr("number"),
|
18
|
+
subsequence: node.attr("subsequence"),
|
19
|
+
))
|
17
20
|
end
|
18
21
|
|
19
22
|
def formula_attrs(node)
|
@@ -33,6 +36,7 @@ module Asciidoctor
|
|
33
36
|
role = node.role || node.attr("style")
|
34
37
|
reqt_subpart(role) and return requirement_subpart(node)
|
35
38
|
role == "form" and return form(node)
|
39
|
+
role == "definition" and return termdefinition(node)
|
36
40
|
result = []
|
37
41
|
node.blocks.each do |b|
|
38
42
|
result << send(b.context, b)
|
@@ -42,10 +46,9 @@ module Asciidoctor
|
|
42
46
|
|
43
47
|
def form(node)
|
44
48
|
noko do |xml|
|
45
|
-
xml.form **attr_code(
|
46
|
-
|
47
|
-
|
48
|
-
) do |f|
|
49
|
+
xml.form **attr_code(id_attr(node)
|
50
|
+
.merge(class: node.attr("class"),
|
51
|
+
name: node.attr("name"), action: node.attr("action"))) do |f|
|
49
52
|
f << node.content
|
50
53
|
end
|
51
54
|
end
|
@@ -77,7 +80,7 @@ module Asciidoctor
|
|
77
80
|
|
78
81
|
def term_example(node)
|
79
82
|
noko do |xml|
|
80
|
-
xml.termexample **id_attr(node) do |ex|
|
83
|
+
xml.termexample **attr_code(id_attr(node)) do |ex|
|
81
84
|
wrap_in_para(node, ex)
|
82
85
|
end
|
83
86
|
end.join("\n")
|
@@ -92,15 +95,18 @@ module Asciidoctor
|
|
92
95
|
return pseudocode_example(node) if role == "pseudocode"
|
93
96
|
return svgmap_example(node) if role == "svgmap"
|
94
97
|
return form(node) if role == "form"
|
98
|
+
return termdefinition(node) if role == "definition"
|
95
99
|
|
100
|
+
reqt_subpart(role) and return requirement_subpart(node)
|
96
101
|
example_proper(node)
|
97
102
|
end
|
98
103
|
|
99
104
|
def svgmap_attrs(node)
|
100
|
-
attr_code(
|
101
|
-
|
102
|
-
|
103
|
-
|
105
|
+
attr_code(id_attr(node)
|
106
|
+
.merge(id: node.id,
|
107
|
+
unnumbered: node.option?("unnumbered") ? "true" : nil,
|
108
|
+
number: node.attr("number"),
|
109
|
+
subsequence: node.attr("subsequence"))
|
104
110
|
.merge(keep_attrs(node)))
|
105
111
|
end
|
106
112
|
|
@@ -159,9 +165,10 @@ module Asciidoctor
|
|
159
165
|
end
|
160
166
|
|
161
167
|
def para_attrs(node)
|
162
|
-
attr_code(keep_attrs(node)
|
168
|
+
attr_code(id_attr(node).merge(keep_attrs(node)
|
163
169
|
.merge(align: node.attr("align"),
|
164
|
-
|
170
|
+
variant_title: node.role == "variant-title" ? true : nil,
|
171
|
+
type: node.attr("type"))))
|
165
172
|
end
|
166
173
|
|
167
174
|
def paragraph(node)
|
@@ -175,9 +182,8 @@ module Asciidoctor
|
|
175
182
|
end
|
176
183
|
|
177
184
|
def quote_attrs(node)
|
178
|
-
attr_code(keep_attrs(node)
|
179
|
-
.merge(align: node.attr("align")
|
180
|
-
id: Metanorma::Utils::anchor_or_uuid(node)))
|
185
|
+
attr_code(id_attr(node).merge(keep_attrs(node))
|
186
|
+
.merge(align: node.attr("align")))
|
181
187
|
end
|
182
188
|
|
183
189
|
def quote_attribution(node, out)
|
@@ -201,12 +207,11 @@ module Asciidoctor
|
|
201
207
|
end
|
202
208
|
|
203
209
|
def listing_attrs(node)
|
204
|
-
attr_code(keep_attrs(node)
|
210
|
+
attr_code(id_attr(node).merge(keep_attrs(node)
|
205
211
|
.merge(lang: node.attr("language"),
|
206
|
-
id: Metanorma::Utils::anchor_or_uuid(node),
|
207
212
|
unnumbered: node.option?("unnumbered") ? "true" : nil,
|
208
213
|
number: node.attr("number"),
|
209
|
-
filename: node.attr("filename")))
|
214
|
+
filename: node.attr("filename"))))
|
210
215
|
end
|
211
216
|
|
212
217
|
# NOTE: html escaping is performed by Nokogiri
|
@@ -2,24 +2,21 @@ module Asciidoctor
|
|
2
2
|
module Standoc
|
3
3
|
module Blocks
|
4
4
|
def termnote_attrs(node)
|
5
|
-
attr_code(
|
6
|
-
|
5
|
+
attr_code(id_attr(node).merge(keep_attrs(node)
|
6
|
+
.merge(
|
7
7
|
unnumbered: node.attr("unnumbered"),
|
8
8
|
number: node.attr("number"),
|
9
9
|
subsequence: node.attr("subsequence"),
|
10
|
-
"keep-
|
11
|
-
|
12
|
-
"keep-separate": node.attr("keep-separate")
|
13
|
-
)
|
14
|
-
)
|
10
|
+
"keep-separate": node.attr("keep-separate"),
|
11
|
+
)))
|
15
12
|
end
|
16
13
|
|
17
14
|
def note_attrs(node)
|
18
15
|
attr_code(
|
19
16
|
termnote_attrs(node).merge(
|
20
17
|
type: node.attr("type"),
|
21
|
-
beforeclauses: node.attr("beforeclauses") == "true" ? "true" : nil
|
22
|
-
)
|
18
|
+
beforeclauses: node.attr("beforeclauses") == "true" ? "true" : nil,
|
19
|
+
),
|
23
20
|
)
|
24
21
|
end
|
25
22
|
|
@@ -27,8 +24,8 @@ module Asciidoctor
|
|
27
24
|
todo_attrs(node).merge(
|
28
25
|
attr_code(
|
29
26
|
from: node.attr("from"),
|
30
|
-
to: node.attr("to") || node.attr("from")
|
31
|
-
)
|
27
|
+
to: node.attr("to") || node.attr("from"),
|
28
|
+
),
|
32
29
|
)
|
33
30
|
end
|
34
31
|
|
@@ -45,11 +42,10 @@ module Asciidoctor
|
|
45
42
|
def todo_attrs(node)
|
46
43
|
date = node.attr("date") || Date.today.iso8601.gsub(/\+.*$/, "")
|
47
44
|
date += "T00:00:00Z" unless /T/.match? date
|
48
|
-
attr_code(
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
)
|
45
|
+
attr_code(id_attr(node)
|
46
|
+
.merge(reviewer: node.attr("reviewer") || node.attr("source") ||
|
47
|
+
"(Unknown)",
|
48
|
+
date: date))
|
53
49
|
end
|
54
50
|
|
55
51
|
def todo(node)
|
@@ -81,12 +77,11 @@ module Asciidoctor
|
|
81
77
|
a = node.attr("type") and ["danger", "safety precautions"].each do |t|
|
82
78
|
name = t if a.casecmp(t).zero?
|
83
79
|
end
|
84
|
-
attr_code(
|
85
|
-
|
86
|
-
|
87
|
-
beforeclauses: node.attr("beforeclauses") == "true" ? "true" : nil
|
88
|
-
)
|
89
|
-
)
|
80
|
+
attr_code(keep_attrs(node).merge(id_attr(node)
|
81
|
+
.merge(
|
82
|
+
type: name,
|
83
|
+
beforeclauses: node.attr("beforeclauses") == "true" ? "true" : nil,
|
84
|
+
)))
|
90
85
|
end
|
91
86
|
|
92
87
|
def admonition(node)
|
@@ -2,30 +2,25 @@ require "nokogiri"
|
|
2
2
|
require "pathname"
|
3
3
|
require "html2doc"
|
4
4
|
require_relative "./cleanup_block"
|
5
|
+
require_relative "./cleanup_table"
|
5
6
|
require_relative "./cleanup_footnotes"
|
6
7
|
require_relative "./cleanup_ref"
|
7
8
|
require_relative "./cleanup_ref_dl"
|
8
9
|
require_relative "./cleanup_boilerplate"
|
9
10
|
require_relative "./cleanup_section"
|
10
11
|
require_relative "./cleanup_terms"
|
12
|
+
require_relative "./cleanup_xref"
|
11
13
|
require_relative "./cleanup_inline"
|
12
14
|
require_relative "./cleanup_amend"
|
13
15
|
require_relative "./cleanup_maths"
|
14
16
|
require_relative "./cleanup_image"
|
15
17
|
require_relative "./cleanup_reqt"
|
18
|
+
require_relative "./cleanup_text"
|
16
19
|
require "relaton_iev"
|
17
20
|
|
18
21
|
module Asciidoctor
|
19
22
|
module Standoc
|
20
23
|
module Cleanup
|
21
|
-
def textcleanup(result)
|
22
|
-
text = result.flatten.map { |l| l.sub(/\s*$/, "") } * "\n"
|
23
|
-
!@keepasciimath and text = asciimath2mathml(text)
|
24
|
-
text = text.gsub(/\s+<fn /, "<fn ")
|
25
|
-
text.gsub(%r{<passthrough\s+formats="metanorma">([^<]*)
|
26
|
-
</passthrough>}mx) { HTMLEntities.new.decode($1) }
|
27
|
-
end
|
28
|
-
|
29
24
|
def cleanup(xmldoc)
|
30
25
|
element_name_cleanup(xmldoc)
|
31
26
|
sections_cleanup(xmldoc)
|
@@ -72,63 +67,6 @@ module Asciidoctor
|
|
72
67
|
xmldoc
|
73
68
|
end
|
74
69
|
|
75
|
-
IGNORE_DUMBQUOTES = "//pre | //pre//* | //tt | //tt//* | "\
|
76
|
-
"//sourcecode | //sourcecode//* | //bibdata//* | //stem | "\
|
77
|
-
"//stem//* | //figure[@class = 'pseudocode'] | "\
|
78
|
-
"//figure[@class = 'pseudocode']//*".freeze
|
79
|
-
|
80
|
-
def smartquotes_cleanup(xmldoc)
|
81
|
-
xmldoc.xpath("//date").each { |d| Metanorma::Utils::endash_date(d) }
|
82
|
-
if @smartquotes then smartquotes_cleanup1(xmldoc)
|
83
|
-
else dumbquote_cleanup(xmldoc)
|
84
|
-
end
|
85
|
-
end
|
86
|
-
|
87
|
-
def smartquotes_cleanup1(xmldoc)
|
88
|
-
uninterrupt_quotes_around_xml(xmldoc)
|
89
|
-
dumb2smart_quotes(xmldoc)
|
90
|
-
end
|
91
|
-
|
92
|
-
# "abc<tag/>", def => "abc",<tag/> def
|
93
|
-
def uninterrupt_quotes_around_xml(xmldoc)
|
94
|
-
xmldoc.xpath("//*[following::text()[1]"\
|
95
|
-
"[starts-with(., '\"') or starts-with(., \"'\")]]")
|
96
|
-
.each do |x|
|
97
|
-
next if !x.ancestors("pre, tt, sourcecode, stem, figure").empty?
|
98
|
-
uninterrupt_quotes_around_xml1(x)
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
|
-
def uninterrupt_quotes_around_xml1(elem)
|
103
|
-
prev = elem.at(".//preceding::text()[1]") or return
|
104
|
-
/\S$/.match?(prev.text) or return
|
105
|
-
foll = elem.at(".//following::text()[1]")
|
106
|
-
m = /^(["'][[:punct:]]*)(\s|$)/.match(HTMLEntities.new.decode(foll&.text)) or return
|
107
|
-
foll.content = foll.text.sub(/^(["'][[:punct:]]*)/, "")
|
108
|
-
prev.content = "#{prev.text}#{m[1]}"
|
109
|
-
end
|
110
|
-
|
111
|
-
def dumb2smart_quotes(xmldoc)
|
112
|
-
(xmldoc.xpath("//*[child::text()]") - xmldoc.xpath(IGNORE_DUMBQUOTES))
|
113
|
-
.each do |x|
|
114
|
-
x.children.each do |n|
|
115
|
-
next unless n.text?
|
116
|
-
|
117
|
-
/[-'"(<>]|\.\.|\dx/.match(n) or next
|
118
|
-
|
119
|
-
n.replace(Metanorma::Utils::smartformat(n.text))
|
120
|
-
end
|
121
|
-
end
|
122
|
-
end
|
123
|
-
|
124
|
-
def dumbquote_cleanup(xmldoc)
|
125
|
-
xmldoc.traverse do |n|
|
126
|
-
next unless n.text?
|
127
|
-
|
128
|
-
n.replace(n.text.gsub(/(?<=\p{Alnum})\u2019(?=\p{Alpha})/, "'")) # .
|
129
|
-
end
|
130
|
-
end
|
131
|
-
|
132
70
|
def docidentifier_cleanup(xmldoc); end
|
133
71
|
|
134
72
|
TEXT_ELEMS =
|
@@ -172,8 +110,8 @@ module Asciidoctor
|
|
172
110
|
|
173
111
|
c.xpath("./variant").each do |n|
|
174
112
|
if n.at_xpath("preceding-sibling::node()"\
|
175
|
-
|
176
|
-
|
113
|
+
"[not(self::text()[not(normalize-space())])][1]"\
|
114
|
+
"[self::variantwrap]")
|
177
115
|
n.previous_element << n
|
178
116
|
else
|
179
117
|
n.replace("<variantwrap/>").first << n
|
@@ -193,21 +131,26 @@ module Asciidoctor
|
|
193
131
|
end
|
194
132
|
|
195
133
|
def toc_cleanup(xmldoc)
|
134
|
+
toc_cleanup_para(xmldoc)
|
135
|
+
xmldoc.xpath("//toc").each { |t| toc_cleanup1(t, xmldoc) }
|
136
|
+
toc_cleanup_clause(xmldoc)
|
137
|
+
end
|
138
|
+
|
139
|
+
def toc_cleanup_para(xmldoc)
|
196
140
|
xmldoc.xpath("//p[toc]").each do |x|
|
197
141
|
x.xpath("./toc").reverse.each do |t|
|
198
142
|
x.next = t
|
199
143
|
end
|
200
144
|
x.remove if x.text.strip.empty?
|
201
145
|
end
|
202
|
-
xmldoc.xpath("//toc").each { |t| toc_cleanup1(t, xmldoc) }
|
203
146
|
end
|
204
147
|
|
205
148
|
def toc_index(toc, xmldoc)
|
206
|
-
depths =
|
207
|
-
m[x.text] = x["depth"]
|
208
|
-
end
|
149
|
+
depths = toc_index_depths(toc)
|
209
150
|
depths.keys.each_with_object([]) do |key, arr|
|
210
151
|
xmldoc.xpath(key).each do |x|
|
152
|
+
t = x.at("./following-sibling::variant-title[@type = 'toc']") and
|
153
|
+
x = t
|
211
154
|
arr << { text: x.children.to_xml, depth: depths[key].to_i,
|
212
155
|
target: x.xpath("(./ancestor-or-self::*/@id)[last()]")[0].text,
|
213
156
|
line: x.line }
|
@@ -215,6 +158,12 @@ module Asciidoctor
|
|
215
158
|
end.sort_by { |a| a[:line] }
|
216
159
|
end
|
217
160
|
|
161
|
+
def toc_index_depths(toc)
|
162
|
+
toc.xpath("./toc-xpath").each_with_object({}) do |x, m|
|
163
|
+
m[x.text] = x["depth"]
|
164
|
+
end
|
165
|
+
end
|
166
|
+
|
218
167
|
def toc_cleanup1(toc, xmldoc)
|
219
168
|
depth = 1
|
220
169
|
ret = ""
|
@@ -227,6 +176,24 @@ module Asciidoctor
|
|
227
176
|
end
|
228
177
|
toc.children = "<ul>#{ret}</ul>"
|
229
178
|
end
|
179
|
+
|
180
|
+
def toc_cleanup_clause(xmldoc)
|
181
|
+
xmldoc
|
182
|
+
.xpath("//clause[@type = 'toc'] | //annex[@type = 'toc']").each do |c|
|
183
|
+
c.xpath(".//ul[not(ancestor::ul)]").each do |ul|
|
184
|
+
toc_cleanup_clause_entry(xmldoc, ul)
|
185
|
+
ul.replace("<toc>#{ul.to_xml}</toc>")
|
186
|
+
end
|
187
|
+
end
|
188
|
+
end
|
189
|
+
|
190
|
+
def toc_cleanup_clause_entry(xmldoc, list)
|
191
|
+
list.xpath(".//xref[not(text())]").each do |x|
|
192
|
+
c1 = xmldoc.at("//*[@id = '#{x['target']}']")
|
193
|
+
t = c1.at("./variant-title[@type = 'toc']") || c1.at("./title")
|
194
|
+
x << t.dup.children
|
195
|
+
end
|
196
|
+
end
|
230
197
|
end
|
231
198
|
end
|
232
199
|
end
|
@@ -7,10 +7,9 @@ module Asciidoctor
|
|
7
7
|
def para_cleanup(xmldoc)
|
8
8
|
["//p[not(ancestor::bibdata)]", "//ol[not(ancestor::bibdata)]",
|
9
9
|
"//ul[not(ancestor::bibdata)]", "//quote[not(ancestor::bibdata)]",
|
10
|
-
"//note[not(ancestor::bibitem or
|
11
|
-
|
12
|
-
|
13
|
-
)
|
10
|
+
"//note[not(ancestor::bibitem or "\
|
11
|
+
"ancestor::table or ancestor::bibdata)]"].each do |w|
|
12
|
+
inject_id(xmldoc, w)
|
14
13
|
end
|
15
14
|
end
|
16
15
|
|
@@ -20,68 +19,6 @@ module Asciidoctor
|
|
20
19
|
end
|
21
20
|
end
|
22
21
|
|
23
|
-
def dl1_table_cleanup(xmldoc)
|
24
|
-
q = "//table/following-sibling::*[1][self::dl]"
|
25
|
-
xmldoc.xpath(q).each do |s|
|
26
|
-
s["key"] == "true" and s.previous_element << s.remove
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
# move Key dl after table footer
|
31
|
-
def dl2_table_cleanup(xmldoc)
|
32
|
-
q = "//table/following-sibling::*[1][self::p]"
|
33
|
-
xmldoc.xpath(q).each do |s|
|
34
|
-
if s.text =~ /^\s*key[^a-z]*$/i && s&.next_element&.name == "dl"
|
35
|
-
s.next_element["key"] = "true"
|
36
|
-
s.previous_element << s.next_element.remove
|
37
|
-
s.remove
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
41
|
-
|
42
|
-
def insert_thead(table)
|
43
|
-
thead = table.at("./thead")
|
44
|
-
return thead unless thead.nil?
|
45
|
-
|
46
|
-
if tname = table.at("./name")
|
47
|
-
thead = tname.add_next_sibling("<thead/>").first
|
48
|
-
return thead
|
49
|
-
end
|
50
|
-
table.children.first.add_previous_sibling("<thead/>").first
|
51
|
-
end
|
52
|
-
|
53
|
-
def header_rows_cleanup(xmldoc)
|
54
|
-
xmldoc.xpath("//table[@headerrows]").each do |s|
|
55
|
-
thead = insert_thead(s)
|
56
|
-
(thead.xpath("./tr").size...s["headerrows"].to_i).each do
|
57
|
-
row = s.at("./tbody/tr")
|
58
|
-
row.parent = thead
|
59
|
-
end
|
60
|
-
thead.xpath(".//td").each { |n| n.name = "th" }
|
61
|
-
s.delete("headerrows")
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
def table_cleanup(xmldoc)
|
66
|
-
dl1_table_cleanup(xmldoc)
|
67
|
-
dl2_table_cleanup(xmldoc)
|
68
|
-
notes_table_cleanup(xmldoc)
|
69
|
-
header_rows_cleanup(xmldoc)
|
70
|
-
end
|
71
|
-
|
72
|
-
# move notes into table
|
73
|
-
def notes_table_cleanup(xmldoc)
|
74
|
-
nomatches = false
|
75
|
-
until nomatches
|
76
|
-
q = "//table/following-sibling::*[1][self::note]"
|
77
|
-
nomatches = true
|
78
|
-
xmldoc.xpath(q).each do |n|
|
79
|
-
n.previous_element << n.remove
|
80
|
-
nomatches = false
|
81
|
-
end
|
82
|
-
end
|
83
|
-
end
|
84
|
-
|
85
22
|
# include where definition list inside stem block
|
86
23
|
def formula_cleanup(formula)
|
87
24
|
formula_cleanup_where1(formula)
|
@@ -213,18 +150,16 @@ module Asciidoctor
|
|
213
150
|
end
|
214
151
|
|
215
152
|
def sourcecode_markup(node)
|
216
|
-
acc = []
|
217
153
|
node.text.split(/(#{Regexp.escape(@sourcecode_markup_start)}|
|
218
154
|
#{Regexp.escape(@sourcecode_markup_end)})/x)
|
219
|
-
.each_slice(4).map do |a|
|
155
|
+
.each_slice(4).map.with_object([]) do |a, acc|
|
220
156
|
acc << safe_noko(a[0], node.document)
|
221
157
|
next unless a.size == 4
|
222
158
|
|
223
159
|
acc << Asciidoctor.convert(
|
224
160
|
a[2], doctype: :inline, backend: (self&.backend&.to_sym || :standoc)
|
225
161
|
)
|
226
|
-
end
|
227
|
-
acc.join
|
162
|
+
end.join
|
228
163
|
end
|
229
164
|
|
230
165
|
def form_cleanup(xmldoc)
|