isodoc 1.0.7 → 1.0.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +5 -5
- data/lib/isodoc/base_style/metanorma_word.scss +31 -0
- data/lib/isodoc/base_style/typography.scss +4 -0
- data/lib/isodoc/convert.rb +12 -5
- data/lib/isodoc/function/blocks.rb +8 -40
- data/lib/isodoc/function/inline.rb +18 -0
- data/lib/isodoc/function/to_word_html.rb +10 -10
- data/lib/isodoc/function/utils.rb +13 -6
- data/lib/isodoc/function/xref_anchor.rb +66 -0
- data/lib/isodoc/function/xref_gen.rb +19 -56
- data/lib/isodoc/html_function/html.rb +16 -3
- data/lib/isodoc/version.rb +1 -1
- data/lib/isodoc/word_function/body.rb +24 -12
- data/lib/isodoc/word_function/postprocess.rb +22 -12
- data/spec/assets/rice_image1 +0 -0
- data/spec/isodoc/blocks_spec.rb +7 -7
- data/spec/isodoc/footnotes_spec.rb +1 -1
- data/spec/isodoc/lists_spec.rb +1 -1
- data/spec/isodoc/postproc_spec.rb +95 -30
- data/spec/isodoc/section_spec.rb +1 -1
- data/spec/isodoc/table_spec.rb +5 -5
- data/spec/spec_helper.rb +6 -1
- metadata +5 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ef21cf58dadc44402088da8688039f145c7c772d2241207790e22721d4509acf
|
4
|
+
data.tar.gz: 5ba2928a7dd29b05b5042bec243d40ef5bc0b57c4cbbf9062469bef4f89ec6e1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4d20eccad075ca4cafff9e8b873514d7d955fe19c02f21b032a7c578b5441b414cb5d3e1f8abbe701b686b2e5ff56d1c8dc6b1fa86e6707727b2a76d05b9b513
|
7
|
+
data.tar.gz: f69deb2000b76e5e24902aad3d11179395f6930a446b5b10244510f7d1be26667164ef1acb16e1c44233d617a1368e53b2d4f15ba4640e83c82be13d66f5e4fa
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
isodoc (1.0.
|
4
|
+
isodoc (1.0.8)
|
5
5
|
asciimath
|
6
6
|
html2doc (~> 0.9.0)
|
7
7
|
htmlentities (~> 4.3.4)
|
@@ -26,7 +26,7 @@ GEM
|
|
26
26
|
docile (1.3.2)
|
27
27
|
equivalent-xml (0.6.0)
|
28
28
|
nokogiri (>= 1.4.3)
|
29
|
-
ffi (1.11.
|
29
|
+
ffi (1.11.2)
|
30
30
|
formatador (0.2.5)
|
31
31
|
guard (2.16.1)
|
32
32
|
formatador (>= 0.2.4)
|
@@ -42,7 +42,7 @@ GEM
|
|
42
42
|
guard (~> 2.1)
|
43
43
|
guard-compat (~> 1.1)
|
44
44
|
rspec (>= 2.99.0, < 4.0)
|
45
|
-
html2doc (0.9.
|
45
|
+
html2doc (0.9.2)
|
46
46
|
asciimath (~> 1.0.9)
|
47
47
|
htmlentities (~> 4.3.4)
|
48
48
|
image_size
|
@@ -58,7 +58,7 @@ GEM
|
|
58
58
|
rb-fsevent (~> 0.10, >= 0.10.3)
|
59
59
|
rb-inotify (~> 0.9, >= 0.9.10)
|
60
60
|
lumberjack (1.0.13)
|
61
|
-
metanorma (0.3.
|
61
|
+
metanorma (0.3.17)
|
62
62
|
asciidoctor
|
63
63
|
htmlentities
|
64
64
|
method_source (0.9.2)
|
@@ -72,7 +72,7 @@ GEM
|
|
72
72
|
notiffany (0.1.3)
|
73
73
|
nenv (~> 0.1)
|
74
74
|
shellany (~> 0.0)
|
75
|
-
parallel (1.
|
75
|
+
parallel (1.19.0)
|
76
76
|
parser (2.6.5.0)
|
77
77
|
ast (~> 2.4.0)
|
78
78
|
powerpack (0.1.2)
|
@@ -0,0 +1,31 @@
|
|
1
|
+
div.table_container {
|
2
|
+
margin-bottom: 14pt;
|
3
|
+
}
|
4
|
+
|
5
|
+
ol
|
6
|
+
{margin-bottom:0cm;}
|
7
|
+
ul
|
8
|
+
{margin-bottom:0cm;}
|
9
|
+
|
10
|
+
table.MsoISOTable tr
|
11
|
+
{page-break-inside:avoid;}
|
12
|
+
|
13
|
+
td { page-break-inside:avoid; }
|
14
|
+
tr { page-break-after:avoid; }
|
15
|
+
|
16
|
+
span.stem
|
17
|
+
{font-family:"Cambria Math",serif;
|
18
|
+
mso-ascii-font-family:"Cambria Math";
|
19
|
+
font-style:italic;}
|
20
|
+
|
21
|
+
dt
|
22
|
+
{page-break-inside:avoid;
|
23
|
+
page-break-after:avoid}
|
24
|
+
|
25
|
+
br.section
|
26
|
+
{page-break-before:always;
|
27
|
+
mso-break-type:section-break;}
|
28
|
+
br.pagebreak
|
29
|
+
{page-break-before:always;
|
30
|
+
mso-special-character:line-break;}
|
31
|
+
|
data/lib/isodoc/convert.rb
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
require "isodoc/common"
|
2
2
|
require "sassc"
|
3
3
|
require "fileutils"
|
4
|
+
require "tempfile"
|
4
5
|
|
5
6
|
module IsoDoc
|
6
7
|
class Convert < ::IsoDoc::Common
|
@@ -31,6 +32,7 @@ module IsoDoc
|
|
31
32
|
merge!(default_file_locations(options)) { |_, old, new| old || new }
|
32
33
|
@options = options
|
33
34
|
@files_to_delete = []
|
35
|
+
@tempfile_cache = []
|
34
36
|
@htmlstylesheet_name = options[:htmlstylesheet]
|
35
37
|
@wordstylesheet_name = options[:wordstylesheet]
|
36
38
|
@standardstylesheet_name = options[:standardstylesheet]
|
@@ -129,10 +131,15 @@ module IsoDoc
|
|
129
131
|
"lib", "isodoc")
|
130
132
|
SassC.load_paths << File.dirname(filename)
|
131
133
|
engine = SassC::Engine.new(fontheader + stylesheet, syntax: :scss)
|
132
|
-
outname = File.basename(filename, ".*") + ".css"
|
133
|
-
File.open(outname, "w:UTF-8") { |f| f.write(engine.render) }
|
134
|
-
|
135
|
-
outname
|
134
|
+
#outname = File.basename(filename, ".*") + ".css"
|
135
|
+
#File.open(outname, "w:UTF-8") { |f| f.write(engine.render) }
|
136
|
+
#@files_to_delete << outname
|
137
|
+
#outname
|
138
|
+
Tempfile.open([File.basename(filename, ".*"), "css"],
|
139
|
+
:encoding => "utf-8") do |f|
|
140
|
+
f.write(engine.render)
|
141
|
+
f
|
142
|
+
end
|
136
143
|
end
|
137
144
|
|
138
145
|
def convert1(docxml, filename, dir)
|
@@ -142,7 +149,7 @@ module IsoDoc
|
|
142
149
|
html.parent.add_namespace("epub", "http://www.idpf.org/2007/ops")
|
143
150
|
info docxml, nil
|
144
151
|
populate_css()
|
145
|
-
define_head
|
152
|
+
html.head { |head| define_head head, filename, dir }
|
146
153
|
make_body(html, docxml)
|
147
154
|
end
|
148
155
|
end.join("\n")
|
@@ -32,11 +32,8 @@ module IsoDoc::Function
|
|
32
32
|
def note_parse(node, out)
|
33
33
|
@note = true
|
34
34
|
out.div **{ id: node["id"], class: "Note" } do |div|
|
35
|
-
|
36
|
-
note_p_parse(node, div)
|
37
|
-
else
|
38
|
-
note_parse1(node, div)
|
39
|
-
end
|
35
|
+
node.first_element_child.name == "p" ?
|
36
|
+
note_p_parse(node, div) : note_parse1(node, div)
|
40
37
|
end
|
41
38
|
@note = false
|
42
39
|
end
|
@@ -75,9 +72,7 @@ module IsoDoc::Function
|
|
75
72
|
@in_figure = true
|
76
73
|
name = node.at(ns("./name"))
|
77
74
|
out.div **attr_code(id: node["id"], class: "pseudocode") do |div|
|
78
|
-
node.children.each
|
79
|
-
parse(n, div) unless n.name == "name"
|
80
|
-
end
|
75
|
+
node.children.each { |n| parse(n, div) unless n.name == "name" }
|
81
76
|
sourcecode_name_parse(node, div, name) if name
|
82
77
|
end
|
83
78
|
@in_figure = false
|
@@ -149,9 +144,7 @@ module IsoDoc::Function
|
|
149
144
|
name = node.at(ns("./name"))
|
150
145
|
out.p **attr_code(id: node["id"], class: "Sourcecode") do |div|
|
151
146
|
@sourcecode = true
|
152
|
-
node.children.each
|
153
|
-
parse(n, div) unless n.name == "name"
|
154
|
-
end
|
147
|
+
node.children.each { |n| parse(n, div) unless n.name == "name" }
|
155
148
|
@sourcecode = false
|
156
149
|
end
|
157
150
|
sourcecode_name_parse(node, out, name) if name
|
@@ -166,11 +159,8 @@ module IsoDoc::Function
|
|
166
159
|
@annotation = true
|
167
160
|
node.at("./preceding-sibling::*[local-name() = 'annotation']") or
|
168
161
|
out << "<br/>"
|
169
|
-
|
170
|
-
|
171
|
-
out << "<#{node.at(ns("//callout[@target='#{node['id']}']")).text}> "
|
172
|
-
#end
|
173
|
-
#node.children.each { |n| parse(n, out) }
|
162
|
+
callout = node.at(ns("//callout[@target='#{node['id']}']"))
|
163
|
+
out << "<br/><#{callout.text}> "
|
174
164
|
out << node&.children&.text&.strip
|
175
165
|
@annotation = false
|
176
166
|
end
|
@@ -192,9 +182,7 @@ module IsoDoc::Function
|
|
192
182
|
name = admonition_name(node, type)
|
193
183
|
out.div **{ class: admonition_class(node) } do |t|
|
194
184
|
admonition_name_parse(node, t, name) if name
|
195
|
-
node.children.each
|
196
|
-
parse(n, t) unless n.name == "name"
|
197
|
-
end
|
185
|
+
node.children.each { |n| parse(n, t) unless n.name == "name" }
|
198
186
|
end
|
199
187
|
end
|
200
188
|
|
@@ -235,10 +223,8 @@ module IsoDoc::Function
|
|
235
223
|
|
236
224
|
def para_attrs(node)
|
237
225
|
attrs = { class: para_class(node), id: node["id"] }
|
238
|
-
|
239
|
-
#attrs[:align] = node["align"] unless node["align"] == "justify"
|
226
|
+
node["align"].nil? or
|
240
227
|
attrs[:style] = "text-align:#{node['align']};"
|
241
|
-
end
|
242
228
|
attrs
|
243
229
|
end
|
244
230
|
|
@@ -272,23 +258,5 @@ module IsoDoc::Function
|
|
272
258
|
quote_attribution(node, out)
|
273
259
|
end
|
274
260
|
end
|
275
|
-
|
276
|
-
def image_title_parse(out, caption)
|
277
|
-
unless caption.nil?
|
278
|
-
out.p **{ class: "FigureTitle", style: "text-align:center;" } do |p|
|
279
|
-
p.b { |b| b << caption.to_s }
|
280
|
-
end
|
281
|
-
end
|
282
|
-
end
|
283
|
-
|
284
|
-
def image_parse(node, out, caption)
|
285
|
-
attrs = { src: node["src"],
|
286
|
-
height: node["height"] || "auto",
|
287
|
-
width: node["width"] || "auto",
|
288
|
-
title: node["title"],
|
289
|
-
alt: node["alt"] }
|
290
|
-
out.img **attr_code(attrs)
|
291
|
-
image_title_parse(out, caption)
|
292
|
-
end
|
293
261
|
end
|
294
262
|
end
|
@@ -90,6 +90,24 @@ module IsoDoc::Function
|
|
90
90
|
end
|
91
91
|
end
|
92
92
|
|
93
|
+
def image_title_parse(out, caption)
|
94
|
+
unless caption.nil?
|
95
|
+
out.p **{ class: "FigureTitle", style: "text-align:center;" } do |p|
|
96
|
+
p.b { |b| b << caption.to_s }
|
97
|
+
end
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
def image_parse(node, out, caption)
|
102
|
+
attrs = { src: node["src"],
|
103
|
+
height: node["height"] || "auto",
|
104
|
+
width: node["width"] || "auto",
|
105
|
+
title: node["title"],
|
106
|
+
alt: node["alt"] }
|
107
|
+
out.img **attr_code(attrs)
|
108
|
+
image_title_parse(out, caption)
|
109
|
+
end
|
110
|
+
|
93
111
|
def error_parse(node, out)
|
94
112
|
text = node.to_xml.gsub(/</, "<").gsub(/>/, ">")
|
95
113
|
out.para do |p|
|
@@ -40,14 +40,14 @@ module IsoDoc::Function
|
|
40
40
|
|
41
41
|
# isodoc.css overrides any CSS injected by Html2Doc, which
|
42
42
|
# is inserted before this CSS.
|
43
|
-
def define_head(
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
43
|
+
def define_head(head, filename, _dir)
|
44
|
+
if @standardstylesheet
|
45
|
+
head.style do |style|
|
46
|
+
#stylesheet = File.read(@standardstylesheet, encoding: "utf-8").
|
47
|
+
@standardstylesheet.open
|
48
|
+
stylesheet = @standardstylesheet.read.
|
49
|
+
gsub("FILENAME", File.basename(filename))
|
50
|
+
style.comment "\n#{stylesheet}\n"
|
51
51
|
end
|
52
52
|
end
|
53
53
|
end
|
@@ -149,7 +149,7 @@ module IsoDoc::Function
|
|
149
149
|
node.children.each { |n| parse(n, e) }
|
150
150
|
end
|
151
151
|
end
|
152
|
-
|
152
|
+
|
153
153
|
def strong_parse(node, out)
|
154
154
|
out.b do |e|
|
155
155
|
node.children.each { |n| parse(n, e) }
|
@@ -200,7 +200,7 @@ module IsoDoc::Function
|
|
200
200
|
when "callout" then callout_parse(node, out)
|
201
201
|
when "stem" then stem_parse(node, out)
|
202
202
|
when "clause" then clause_parse(node, out)
|
203
|
-
|
203
|
+
#when "appendix" then clause_parse(node, out)
|
204
204
|
when "xref" then xref_parse(node, out)
|
205
205
|
when "eref" then eref_parse(node, out)
|
206
206
|
when "origin" then eref_parse(node, out)
|
@@ -152,12 +152,19 @@ module IsoDoc::Function
|
|
152
152
|
|
153
153
|
def save_dataimage(uri, relative_dir = true)
|
154
154
|
%r{^data:image/(?<imgtype>[^;]+);base64,(?<imgdata>.+)$} =~ uri
|
155
|
-
uuid = UUIDTools::UUID.random_create.to_s
|
156
|
-
fname = "#{uuid}.#{imgtype}"
|
157
|
-
new_file = File.join(tmpimagedir, fname)
|
158
|
-
|
159
|
-
File.open(new_file, "wb") { |f| f.write(Base64.strict_decode64(imgdata)) }
|
160
|
-
File.join(relative_dir ? rel_tmpimagedir : tmpimagedir, fname)
|
155
|
+
#uuid = UUIDTools::UUID.random_create.to_s
|
156
|
+
#fname = "#{uuid}.#{imgtype}"
|
157
|
+
#new_file = File.join(tmpimagedir, fname)
|
158
|
+
#@files_to_delete << new_file
|
159
|
+
#File.open(new_file, "wb") { |f| f.write(Base64.strict_decode64(imgdata)) }
|
160
|
+
#File.join(relative_dir ? rel_tmpimagedir : tmpimagedir, fname)
|
161
|
+
imgtype = "png" unless /^[a-z0-9]+$/.match imgtype
|
162
|
+
Tempfile.open(["image", ".#{imgtype}"]) do |f|
|
163
|
+
f.binmode
|
164
|
+
f.write(Base64.strict_decode64(imgdata))
|
165
|
+
@tempfile_cache << f #persist to the end
|
166
|
+
f.path
|
167
|
+
end
|
161
168
|
end
|
162
169
|
end
|
163
170
|
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require "singleton"
|
2
|
+
|
3
|
+
module IsoDoc::Function
|
4
|
+
module XrefGen
|
5
|
+
class Seen_Anchor
|
6
|
+
include Singleton
|
7
|
+
|
8
|
+
def initialize
|
9
|
+
@seen = {}
|
10
|
+
end
|
11
|
+
|
12
|
+
def seen(x)
|
13
|
+
@seen.has_key?(x)
|
14
|
+
end
|
15
|
+
|
16
|
+
def add(x)
|
17
|
+
@seen[x] = true
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
@anchors = {}
|
22
|
+
|
23
|
+
def get_anchors
|
24
|
+
@anchors
|
25
|
+
end
|
26
|
+
|
27
|
+
def anchor(id, lbl, warning = true)
|
28
|
+
unless @anchors[id]
|
29
|
+
if warning
|
30
|
+
@seen ||= Seen_Anchor.instance
|
31
|
+
@seen.seen(id) or warn "No label has been processed for ID #{id}"
|
32
|
+
@seen.add(id)
|
33
|
+
return "[#{id}]"
|
34
|
+
end
|
35
|
+
end
|
36
|
+
@anchors.dig(id, lbl)
|
37
|
+
end
|
38
|
+
|
39
|
+
def anchor_struct_label(lbl, elem)
|
40
|
+
case elem
|
41
|
+
when @appendix_lbl then l10n("#{elem} #{lbl}")
|
42
|
+
else
|
43
|
+
lbl.to_s
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
def anchor_struct_xref(lbl, elem)
|
48
|
+
case elem
|
49
|
+
when @formula_lbl then l10n("#{elem} (#{lbl})")
|
50
|
+
when @inequality_lbl then l10n("#{elem} (#{lbl})")
|
51
|
+
else
|
52
|
+
l10n("#{elem} #{lbl}")
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
def anchor_struct(lbl, container, elem, type, unnumbered = false)
|
57
|
+
ret = {}
|
58
|
+
ret[:label] = unnumbered == "true" ? nil : anchor_struct_label(lbl, elem)
|
59
|
+
ret[:xref] = anchor_struct_xref(unnumbered == "true" ? "(??)" : lbl, elem)
|
60
|
+
ret[:xref].gsub!(/ $/, "")
|
61
|
+
ret[:container] = get_clause_id(container) unless container.nil?
|
62
|
+
ret[:type] = type
|
63
|
+
ret
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -1,23 +1,8 @@
|
|
1
|
-
require "roman-numerals"
|
2
1
|
require_relative "xref_counter"
|
2
|
+
require_relative "xref_anchor"
|
3
3
|
|
4
4
|
module IsoDoc::Function
|
5
5
|
module XrefGen
|
6
|
-
|
7
|
-
@anchors = {}
|
8
|
-
|
9
|
-
def get_anchors
|
10
|
-
@anchors
|
11
|
-
end
|
12
|
-
|
13
|
-
def anchor(id, lbl, warning = true)
|
14
|
-
unless @anchors[id]
|
15
|
-
warning and warn "No label has been processed for ID #{id}"
|
16
|
-
return "[#{id}]"
|
17
|
-
end
|
18
|
-
@anchors.dig(id, lbl)
|
19
|
-
end
|
20
|
-
|
21
6
|
def termnote_label(n)
|
22
7
|
@termnote_lbl.gsub(/%/, n.to_s)
|
23
8
|
end
|
@@ -29,8 +14,7 @@ module IsoDoc::Function
|
|
29
14
|
return if n["id"].nil? || n["id"].empty?
|
30
15
|
c.increment(n)
|
31
16
|
@anchors[n["id"]] =
|
32
|
-
{ label: termnote_label(c.print),
|
33
|
-
type: "termnote",
|
17
|
+
{ label: termnote_label(c.print), type: "termnote",
|
34
18
|
xref: l10n("#{anchor(t['id'], :xref)}, "\
|
35
19
|
"#{@note_xref_lbl} #{c.print}") }
|
36
20
|
end
|
@@ -46,8 +30,8 @@ module IsoDoc::Function
|
|
46
30
|
c.increment(n)
|
47
31
|
idx = examples.size == 1 ? "" : c.print
|
48
32
|
@anchors[n["id"]] = {
|
49
|
-
type: "termexample",
|
50
|
-
|
33
|
+
type: "termexample", label: idx,
|
34
|
+
xref: l10n("#{anchor(t['id'], :xref)}, "\
|
51
35
|
"#{@example_xref_lbl} #{c.print}") }
|
52
36
|
end
|
53
37
|
end
|
@@ -120,9 +104,9 @@ module IsoDoc::Function
|
|
120
104
|
label = c.increment(li).listlabel(depth)
|
121
105
|
label = "#{prev_label}.#{label}" unless prev_label.empty?
|
122
106
|
label = "#{list_anchor[:xref]} #{label}" if refer_list
|
123
|
-
li["id"] and @anchors[li["id"]] =
|
124
|
-
|
125
|
-
|
107
|
+
li["id"] and @anchors[li["id"]] =
|
108
|
+
{ xref: "#{label})", type: "listitem",
|
109
|
+
container: list_anchor[:container] }
|
126
110
|
li.xpath(ns("./ol")).each do |ol|
|
127
111
|
list_item_anchor_names(ol, list_anchor, depth + 1, label, false)
|
128
112
|
end
|
@@ -156,33 +140,6 @@ module IsoDoc::Function
|
|
156
140
|
end
|
157
141
|
end
|
158
142
|
|
159
|
-
def anchor_struct_label(lbl, elem)
|
160
|
-
case elem
|
161
|
-
when @appendix_lbl then l10n("#{elem} #{lbl}")
|
162
|
-
else
|
163
|
-
lbl.to_s
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
def anchor_struct_xref(lbl, elem)
|
168
|
-
case elem
|
169
|
-
when @formula_lbl then l10n("#{elem} (#{lbl})")
|
170
|
-
when @inequality_lbl then l10n("#{elem} (#{lbl})")
|
171
|
-
else
|
172
|
-
l10n("#{elem} #{lbl}")
|
173
|
-
end
|
174
|
-
end
|
175
|
-
|
176
|
-
def anchor_struct(lbl, container, elem, type, unnumbered = false)
|
177
|
-
ret = {}
|
178
|
-
ret[:label] = unnumbered == "true" ? nil : anchor_struct_label(lbl, elem)
|
179
|
-
ret[:xref] = anchor_struct_xref(unnumbered == "true" ? "(??)" : lbl, elem)
|
180
|
-
ret[:xref].gsub!(/ $/, "")
|
181
|
-
ret[:container] = get_clause_id(container) unless container.nil?
|
182
|
-
ret[:type] = type
|
183
|
-
ret
|
184
|
-
end
|
185
|
-
|
186
143
|
def sequential_table_names(clause)
|
187
144
|
c = Counter.new
|
188
145
|
clause.xpath(ns(".//table")).each do |t|
|
@@ -203,7 +160,8 @@ module IsoDoc::Function
|
|
203
160
|
end
|
204
161
|
end
|
205
162
|
|
206
|
-
FIRST_LVL_REQ = "[not(ancestor::permission or ancestor::requirement or
|
163
|
+
FIRST_LVL_REQ = "[not(ancestor::permission or ancestor::requirement or "\
|
164
|
+
"ancestor::recommendation)]".freeze
|
207
165
|
|
208
166
|
def sequential_permission_names(clause, klass, label)
|
209
167
|
c = Counter.new
|
@@ -213,7 +171,8 @@ module IsoDoc::Function
|
|
213
171
|
@anchors[t["id"]] = anchor_struct(id, t, label, klass, t["unnumbered"])
|
214
172
|
sequential_permission_names1(t, id, "permission", @permission_lbl)
|
215
173
|
sequential_permission_names1(t, id, "requirement", @requirement_lbl)
|
216
|
-
sequential_permission_names1(t, id, "recommendation",
|
174
|
+
sequential_permission_names1(t, id, "recommendation",
|
175
|
+
@recommendation_lbl)
|
217
176
|
end
|
218
177
|
end
|
219
178
|
|
@@ -225,7 +184,8 @@ module IsoDoc::Function
|
|
225
184
|
@anchors[t["id"]] = anchor_struct(id, t, label, klass, t["unnumbered"])
|
226
185
|
sequential_permission_names1(t, id, "permission", @permission_lbl)
|
227
186
|
sequential_permission_names1(t, id, "requirement", @requirement_lbl)
|
228
|
-
sequential_permission_names1(t, id, "recommendation",
|
187
|
+
sequential_permission_names1(t, id, "recommendation",
|
188
|
+
@recommendation_lbl)
|
229
189
|
end
|
230
190
|
end
|
231
191
|
|
@@ -278,8 +238,10 @@ module IsoDoc::Function
|
|
278
238
|
hierarchical_figure_names(clause, num)
|
279
239
|
hierarchical_formula_names(clause, num)
|
280
240
|
hierarchical_permission_names(clause, num, "permission", @permission_lbl)
|
281
|
-
hierarchical_permission_names(clause, num, "requirement",
|
282
|
-
|
241
|
+
hierarchical_permission_names(clause, num, "requirement",
|
242
|
+
@requirement_lbl)
|
243
|
+
hierarchical_permission_names(clause, num, "recommendation",
|
244
|
+
@recommendation_lbl)
|
283
245
|
end
|
284
246
|
|
285
247
|
def hierarchical_formula_names(clause, num)
|
@@ -301,7 +263,8 @@ module IsoDoc::Function
|
|
301
263
|
@anchors[t["id"]] = anchor_struct(lbl, t, label, klass, t["unnumbered"])
|
302
264
|
sequential_permission_names1(t, lbl, "permission", @permission_lbl)
|
303
265
|
sequential_permission_names1(t, lbl, "requirement", @requirement_lbl)
|
304
|
-
sequential_permission_names1(t, lbl, "recommendation",
|
266
|
+
sequential_permission_names1(t, lbl, "recommendation",
|
267
|
+
@recommendation_lbl)
|
305
268
|
end
|
306
269
|
end
|
307
270
|
end
|
@@ -183,9 +183,12 @@ module IsoDoc::HtmlFunction
|
|
183
183
|
end
|
184
184
|
|
185
185
|
def htmlstylesheet
|
186
|
-
stylesheet = File.read(@htmlstylesheet, encoding: "UTF-8")
|
186
|
+
#stylesheet = File.read(@htmlstylesheet, encoding: "UTF-8")
|
187
|
+
@htmlstylesheet.open
|
188
|
+
stylesheet = @htmlstylesheet.read
|
187
189
|
xml = Nokogiri::XML("<style/>")
|
188
190
|
xml.children.first << Nokogiri::XML::Comment.new(xml, "\n#{stylesheet}\n")
|
191
|
+
@htmlstylesheet.close!
|
189
192
|
xml.root.to_s
|
190
193
|
end
|
191
194
|
|
@@ -257,6 +260,8 @@ module IsoDoc::HtmlFunction
|
|
257
260
|
def image_localfile(i)
|
258
261
|
if /^data:image/.match i["src"]
|
259
262
|
save_dataimage(i["src"], false)
|
263
|
+
elsif %r{^([A-Z]:)?/}.match i["src"]
|
264
|
+
i["src"]
|
260
265
|
else
|
261
266
|
File.join(@localdir, i["src"])
|
262
267
|
end
|
@@ -269,10 +274,18 @@ module IsoDoc::HtmlFunction
|
|
269
274
|
i["src"] = "data:image/#{type};base64,#{data}"
|
270
275
|
end
|
271
276
|
|
272
|
-
def
|
277
|
+
def image_suffix(i)
|
278
|
+
type = i["mimetype"]&.sub(%r{^[^/*]+/}, "")
|
273
279
|
matched = /\.(?<suffix>[^. \r\n\t]+)$/.match i["src"]
|
280
|
+
type and !type.empty? and return type
|
281
|
+
!matched.nil? and matched[:suffix] and return matched[:suffix]
|
282
|
+
"png"
|
283
|
+
end
|
284
|
+
|
285
|
+
def move_image1(i)
|
286
|
+
suffix = image_suffix(i)
|
274
287
|
uuid = UUIDTools::UUID.random_create.to_s
|
275
|
-
fname = "#{uuid}.#{
|
288
|
+
fname = "#{uuid}.#{suffix}"
|
276
289
|
new_full_filename = File.join(tmpimagedir, fname)
|
277
290
|
local_filename = image_localfile(i)
|
278
291
|
FileUtils.cp local_filename, new_full_filename
|
data/lib/isodoc/version.rb
CHANGED
@@ -1,5 +1,15 @@
|
|
1
1
|
module IsoDoc::WordFunction
|
2
2
|
module Body
|
3
|
+
def define_head(head, filename, _dir)
|
4
|
+
head.style do |style|
|
5
|
+
loc = File.join(File.dirname(__FILE__), "..", "base_style",
|
6
|
+
"metanorma_word.scss")
|
7
|
+
stylesheet = File.read(loc, encoding: "utf-8")
|
8
|
+
style.comment "\n#{stylesheet}\n"
|
9
|
+
end
|
10
|
+
super
|
11
|
+
end
|
12
|
+
|
3
13
|
def anchor_names(docxml)
|
4
14
|
super
|
5
15
|
renumber_footnotes(docxml)
|
@@ -56,7 +66,7 @@ module IsoDoc::WordFunction
|
|
56
66
|
classtype = "MsoCommentText" if in_comment
|
57
67
|
classtype = "Sourcecode" if @annotation
|
58
68
|
classtype
|
59
|
-
|
69
|
+
end
|
60
70
|
|
61
71
|
def remove_bottom_border(td)
|
62
72
|
td["style"] =
|
@@ -72,7 +82,8 @@ module IsoDoc::WordFunction
|
|
72
82
|
t.at(".//tr").xpath("./td | ./th").each do |td|
|
73
83
|
cols += (td["colspan"] ? td["colspan"].to_i : 1)
|
74
84
|
end
|
75
|
-
style =
|
85
|
+
style = "border-top:0pt;mso-border-top-alt:0pt;"\
|
86
|
+
"border-bottom:#{SW1} 1.5pt;mso-border-bottom-alt:#{SW1} 1.5pt;"
|
76
87
|
tfoot.add_child("<tr><td colspan='#{cols}' style='#{style}'/></tr>")
|
77
88
|
tfoot.xpath(".//td").last
|
78
89
|
end
|
@@ -81,10 +92,10 @@ module IsoDoc::WordFunction
|
|
81
92
|
style = td.name == "th" ? "font-weight:bold;" : ""
|
82
93
|
rowmax = td["rowspan"] ? row + td["rowspan"].to_i - 1 : row
|
83
94
|
style += <<~STYLE
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
95
|
+
border-top:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
|
96
|
+
mso-border-top-alt:#{row.zero? ? "#{SW1} 1.5pt;" : 'none;'}
|
97
|
+
border-bottom:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
|
98
|
+
mso-border-bottom-alt:#{SW1} #{rowmax == totalrows ? '1.5' : '1.0'}pt;
|
88
99
|
STYLE
|
89
100
|
{ rowspan: td["rowspan"], colspan: td["colspan"],
|
90
101
|
align: td["align"], style: style.gsub(/\n/, "") }
|
@@ -99,7 +110,8 @@ module IsoDoc::WordFunction
|
|
99
110
|
def page_break(out)
|
100
111
|
out.p do |p|
|
101
112
|
p.br **{ clear: "all",
|
102
|
-
style: "mso-special-character:line-break;
|
113
|
+
style: "mso-special-character:line-break;"\
|
114
|
+
"page-break-before:always" }
|
103
115
|
end
|
104
116
|
end
|
105
117
|
|
@@ -233,8 +245,8 @@ module IsoDoc::WordFunction
|
|
233
245
|
def example_table_attr(node)
|
234
246
|
super.merge({
|
235
247
|
style: "mso-table-lspace:15.0cm;margin-left:423.0pt;"\
|
236
|
-
"mso-table-rspace:15.0cm;margin-right:423.0pt;
|
237
|
-
"mso-table-anchor-
|
248
|
+
"mso-table-rspace:15.0cm;margin-right:423.0pt;"\
|
249
|
+
"mso-table-anchor-horizontal:column;"\
|
238
250
|
"mso-table-overlap:never;border-collapse:collapse;"
|
239
251
|
})
|
240
252
|
end
|
@@ -243,8 +255,8 @@ module IsoDoc::WordFunction
|
|
243
255
|
super.merge(attr_code({
|
244
256
|
summary: node["summary"],
|
245
257
|
style: "mso-table-lspace:15.0cm;margin-left:423.0pt;"\
|
246
|
-
"mso-table-rspace:15.0cm;margin-right:423.0pt;
|
247
|
-
"mso-table-anchor-
|
258
|
+
"mso-table-rspace:15.0cm;margin-right:423.0pt;"\
|
259
|
+
"mso-table-anchor-horizontal:column;"\
|
248
260
|
"mso-table-overlap:never;border-spacing:0;border-width:1px;"
|
249
261
|
}))
|
250
262
|
end
|
@@ -252,7 +264,7 @@ module IsoDoc::WordFunction
|
|
252
264
|
def table_parse(node, out)
|
253
265
|
@in_table = true
|
254
266
|
table_title_parse(node, out)
|
255
|
-
out.div **{ align: "center" } do |div|
|
267
|
+
out.div **{ align: "center", class: "table_container" } do |div|
|
256
268
|
div.table **make_table_attr(node) do |t|
|
257
269
|
thead_parse(node, t)
|
258
270
|
tbody_parse(node, t)
|
@@ -40,10 +40,12 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
|
|
40
40
|
def toWord(result, filename, dir, header)
|
41
41
|
result = populate_template(result, :word)
|
42
42
|
result = from_xhtml(word_cleanup(to_xhtml(result)))
|
43
|
-
Html2Doc.process(result, filename: filename, stylesheet: @wordstylesheet,
|
44
|
-
header_file: header, dir: dir,
|
43
|
+
Html2Doc.process(result, filename: filename, stylesheet: @wordstylesheet&.path,
|
44
|
+
header_file: header&.path, dir: dir,
|
45
45
|
asciimathdelims: [@openmathdelim, @closemathdelim],
|
46
46
|
liststyles: { ul: @ulstyle, ol: @olstyle })
|
47
|
+
header&.unlink
|
48
|
+
@wordstylesheet&.unlink
|
47
49
|
end
|
48
50
|
|
49
51
|
def word_admonition_images(docxml)
|
@@ -90,9 +92,9 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
|
|
90
92
|
def list_add(xpath, lvl)
|
91
93
|
xpath.each do |list|
|
92
94
|
(list.xpath(".//li") - list.xpath(".//ol//li | .//ul//li")).each do |l|
|
93
|
-
l.xpath("./p | ./div
|
94
|
-
next if
|
95
|
-
p
|
95
|
+
l.xpath("./p | ./div").each_with_index do |p, i|
|
96
|
+
next if i == 0
|
97
|
+
p.wrap(%{<div class="ListContLevel#{lvl}"/>})
|
96
98
|
end
|
97
99
|
list_add(l.xpath(".//ul") - l.xpath(".//ul//ul | .//ol//ul"), lvl + 1)
|
98
100
|
list_add(l.xpath(".//ol") - l.xpath(".//ul//ol | .//ol//ol"), lvl + 1)
|
@@ -107,16 +109,20 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
|
|
107
109
|
end
|
108
110
|
end
|
109
111
|
|
112
|
+
=begin
|
110
113
|
EMPTY_PARA = "<p style='margin-top:0cm;margin-right:0cm;"\
|
111
114
|
"margin-bottom:0cm;margin-left:0.0pt;margin-bottom:.0001pt;"\
|
112
115
|
"line-height:1.0pt;mso-line-height-rule:exactly'>"\
|
113
116
|
"<span lang=EN-GB style='display:none;mso-hide:all'> </span></p>"
|
114
117
|
|
115
|
-
def
|
116
|
-
|
117
|
-
next unless t&.next_element&.name == "table"
|
118
|
+
def table_after_table(docxml)
|
119
|
+
docxml.xpath("//table[following-sibling::*[1]/self::table]").each do |t|
|
118
120
|
t.add_next_sibling(EMPTY_PARA)
|
119
121
|
end
|
122
|
+
end
|
123
|
+
=end
|
124
|
+
|
125
|
+
def word_table_separator(docxml)
|
120
126
|
docxml.xpath("//p[@class = 'TableTitle']").each do |t|
|
121
127
|
next unless t.children.empty?
|
122
128
|
t["style"] = t["style"].sub(/;?$/, ";font-size:0pt;")
|
@@ -171,10 +177,14 @@ xmlns:m="http://schemas.microsoft.com/office/2004/12/omml">
|
|
171
177
|
meta = @meta.get
|
172
178
|
meta[:filename] = filename
|
173
179
|
params = meta.map { |k, v| [k.to_s, v] }.to_h
|
174
|
-
headerfile = "header.html"
|
175
|
-
File.open(headerfile, "w:UTF-8") { |f| f.write(template.render(params)) }
|
176
|
-
|
177
|
-
headerfile
|
180
|
+
#headerfile = "header.html"
|
181
|
+
#File.open(headerfile, "w:UTF-8") { |f| f.write(template.render(params)) }
|
182
|
+
#@files_to_delete << headerfile
|
183
|
+
#headerfile
|
184
|
+
Tempfile.open(%w(header html), :encoding => "utf-8") do |f|
|
185
|
+
f.write(template.render(params))
|
186
|
+
f
|
187
|
+
end
|
178
188
|
end
|
179
189
|
|
180
190
|
def word_toc_entry(toclevel, heading)
|
Binary file
|
data/spec/isodoc/blocks_spec.rb
CHANGED
@@ -37,7 +37,7 @@ RSpec.describe IsoDoc do
|
|
37
37
|
</iso-standard>
|
38
38
|
INPUT
|
39
39
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
40
|
-
<head
|
40
|
+
<head><style/></head>
|
41
41
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
42
42
|
<div class="WordSection1">
|
43
43
|
<p> </p>
|
@@ -195,7 +195,7 @@ INPUT
|
|
195
195
|
</iso-standard>
|
196
196
|
INPUT
|
197
197
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
198
|
-
<head
|
198
|
+
<head><style/></head>
|
199
199
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
200
200
|
<div class="WordSection1">
|
201
201
|
<p> </p>
|
@@ -283,7 +283,7 @@ B</pre>
|
|
283
283
|
end
|
284
284
|
|
285
285
|
it "processes figures (Word)" do
|
286
|
-
expect(xmlpp(strip_guid(IsoDoc::WordConvert.new({}).convert("test", <<~"INPUT", true)))).to be_equivalent_to xmlpp(<<~"OUTPUT")
|
286
|
+
expect(xmlpp(strip_guid(IsoDoc::WordConvert.new({}).convert("test", <<~"INPUT", true).sub(/['"][^'".]+\.gif['"]/, "'_.gif'")))).to be_equivalent_to xmlpp(<<~"OUTPUT")
|
287
287
|
<iso-standard xmlns="http://riboseinc.com/isoxml">
|
288
288
|
<preface><foreword>
|
289
289
|
<figure id="figureA-1">
|
@@ -307,7 +307,7 @@ B</pre>
|
|
307
307
|
</iso-standard>
|
308
308
|
INPUT
|
309
309
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
310
|
-
<head
|
310
|
+
<head><style/></head>
|
311
311
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
312
312
|
<div class="WordSection1">
|
313
313
|
<p> </p>
|
@@ -321,7 +321,7 @@ B</pre>
|
|
321
321
|
|
322
322
|
<img src="rice_images/rice_image1.png" height="20" width="30" alt="alttext" title="titletext"/>
|
323
323
|
<img src="rice_images/rice_image1.png"/>
|
324
|
-
<img src="
|
324
|
+
<img src="_.gif"/>
|
325
325
|
<a href="#_" class="TableFootnoteRef">a</a><aside><div id="ftn_"><span><span id="_" class="TableFootnoteRef">a</span><span style="mso-tab-count:1">  </span></span>
|
326
326
|
<p id="_">The time <span class="stem">(#(t_90)#)</span> was estimated to be 18,2 min for this example.</p>
|
327
327
|
</div></aside>
|
@@ -449,7 +449,7 @@ B</pre>
|
|
449
449
|
</iso-standard>
|
450
450
|
INPUT
|
451
451
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
452
|
-
<head
|
452
|
+
<head><style/></head>
|
453
453
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
454
454
|
<div class="WordSection1">
|
455
455
|
<p> </p>
|
@@ -668,7 +668,7 @@ World</p>
|
|
668
668
|
</iso-standard>
|
669
669
|
INPUT
|
670
670
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
671
|
-
<head
|
671
|
+
<head><style/></head>
|
672
672
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
673
673
|
<div class="WordSection1">
|
674
674
|
<p> </p>
|
data/spec/isodoc/lists_spec.rb
CHANGED
@@ -194,7 +194,7 @@ RSpec.describe IsoDoc do
|
|
194
194
|
</iso-standard>
|
195
195
|
INPUT
|
196
196
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
197
|
-
<head
|
197
|
+
<head><style/></head>
|
198
198
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
199
199
|
<div class="WordSection1">
|
200
200
|
<p> </p>
|
@@ -60,6 +60,7 @@ RSpec.describe IsoDoc do
|
|
60
60
|
expect(File.exist?("test.doc")).to be true
|
61
61
|
word = File.read("test.doc")
|
62
62
|
expect(word).to match(/one empty stylesheet/)
|
63
|
+
expect(word).to match(/div\.table_container/)
|
63
64
|
end
|
64
65
|
|
65
66
|
it "generates HTML output docs with null configuration from file" do
|
@@ -552,6 +553,7 @@ TOCLEVEL
|
|
552
553
|
<preface><foreword>
|
553
554
|
<figure id="_">
|
554
555
|
<name>Split-it-right sample divider</name>
|
556
|
+
<image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
|
555
557
|
<image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
|
556
558
|
<image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
|
557
559
|
<image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
|
@@ -570,6 +572,7 @@ TOCLEVEL
|
|
570
572
|
<h1 class="ForewordTitle">Foreword</h1>
|
571
573
|
<div id="_" class="figure">
|
572
574
|
<img src="test_htmlimages/_.png" height="776" width="922" />
|
575
|
+
<img src="test_htmlimages/_.png" height="776" width="922" />
|
573
576
|
<img src="test_htmlimages/_.png" height="800" width="53" />
|
574
577
|
<img src="test_htmlimages/_.png" height="83" width="99" />
|
575
578
|
<img src="" height="800" width="800" />
|
@@ -581,6 +584,43 @@ TOCLEVEL
|
|
581
584
|
|
582
585
|
end
|
583
586
|
|
587
|
+
|
588
|
+
it "moves images in HTML with no file suffix" do
|
589
|
+
FileUtils.rm_f "test.html"
|
590
|
+
FileUtils.rm_rf "test_htmlimages"
|
591
|
+
IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.css"}).convert("test", <<~"INPUT", false)
|
592
|
+
<iso-standard xmlns="http://riboseinc.com/isoxml">
|
593
|
+
<preface><foreword>
|
594
|
+
<figure id="_">
|
595
|
+
<name>Split-it-right sample divider</name>
|
596
|
+
<image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
|
597
|
+
<image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
|
598
|
+
<image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
|
599
|
+
</figure>
|
600
|
+
</foreword></preface>
|
601
|
+
</iso-standard>
|
602
|
+
INPUT
|
603
|
+
html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
|
604
|
+
sub(%r{</main>.*$}m, "</main>")
|
605
|
+
expect(`ls test_htmlimages`).to match(/\.png$/)
|
606
|
+
expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
|
607
|
+
<main class='main-section'>
|
608
|
+
<button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
|
609
|
+
<br/>
|
610
|
+
<div>
|
611
|
+
<h1 class='ForewordTitle'>Foreword</h1>
|
612
|
+
<div id='_' class='figure'>
|
613
|
+
<img src='test_htmlimages/_.png' height='776' width='922'/>
|
614
|
+
<img src='test_htmlimages/_.png' height='776' width='922'/>
|
615
|
+
<img src='' height='800' width='800'/>
|
616
|
+
<p class='FigureTitle' style='text-align:center;'>Figure 1 — Split-it-right sample divider</p>
|
617
|
+
</div>
|
618
|
+
</div>
|
619
|
+
<p class='zzSTDTitle1'/>
|
620
|
+
</main>
|
621
|
+
OUTPUT
|
622
|
+
end
|
623
|
+
|
584
624
|
it "moves images in HTML, using relative file location" do
|
585
625
|
FileUtils.rm_f "spec/test.html"
|
586
626
|
FileUtils.rm_rf "spec/test_htmlimages"
|
@@ -755,7 +795,8 @@ TOCLEVEL
|
|
755
795
|
<li><p>A</p>
|
756
796
|
<p>B</p></li>
|
757
797
|
<li><ol><li><p>C</p>
|
758
|
-
<p>D</p
|
798
|
+
<p>D</p>
|
799
|
+
<sourcecode>E</sourcecode></li>
|
759
800
|
</ol></li>
|
760
801
|
</ul>
|
761
802
|
<ol>
|
@@ -773,33 +814,57 @@ TOCLEVEL
|
|
773
814
|
word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
|
774
815
|
sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
|
775
816
|
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
|
776
|
-
|
777
|
-
|
778
|
-
|
817
|
+
<div class='WordSection2' xmlns:m='m'>
|
818
|
+
<p class='MsoNormal'>
|
819
|
+
<br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
|
820
|
+
</p>
|
821
|
+
<div>
|
822
|
+
<h1 class='ForewordTitle'>Foreword</h1>
|
823
|
+
<p class='MsoListParagraphCxSpFirst'>
|
824
|
+
A
|
825
|
+
<div class='ListContLevel1'>
|
826
|
+
<p class='MsoNormal'>B</p>
|
827
|
+
</div>
|
828
|
+
</p>
|
829
|
+
<p class='MsoListParagraphCxSpLast'>
|
830
|
+
<p class='MsoListParagraphCxSpFirst'>
|
831
|
+
C
|
832
|
+
<div class='ListContLevel2'>
|
833
|
+
<p class='MsoNormal'>D</p>
|
834
|
+
</div>
|
835
|
+
<div class='ListContLevel2'>
|
836
|
+
<p class='Sourcecode'>E</p>
|
837
|
+
</div>
|
779
838
|
</p>
|
780
|
-
|
781
|
-
|
782
|
-
|
783
|
-
|
784
|
-
|
785
|
-
<p class="MsoListParagraphCxSpLast"><p class="MsoListParagraphCxSpFirst">C
|
786
|
-
<p class="ListContLevel2">D</p></p>
|
787
|
-
</p>
|
788
|
-
|
789
|
-
|
790
|
-
<p class="MsoListParagraphCxSpFirst">A1
|
791
|
-
<p class="ListContLevel1">B1</p></p>
|
792
|
-
<p class="MsoListParagraphCxSpLast">C1
|
793
|
-
<div class="formula"><a name="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62" id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62"></a><p class="ListContLevel2"><span class="stem"><m:oMath>
|
794
|
-
<m:r><m:t>D1</m:t></m:r>
|
795
|
-
|
796
|
-
</m:oMath>
|
797
|
-
</span><span style="mso-tab-count:1">  </span>(1)</p></div>
|
798
|
-
</p>
|
799
|
-
|
839
|
+
</p>
|
840
|
+
<p class='MsoListParagraphCxSpFirst'>
|
841
|
+
A1
|
842
|
+
<div class='ListContLevel1'>
|
843
|
+
<p class='MsoNormal'>B1</p>
|
800
844
|
</div>
|
801
|
-
|
802
|
-
|
845
|
+
</p>
|
846
|
+
<p class='MsoListParagraphCxSpLast'>
|
847
|
+
C1
|
848
|
+
<div class='ListContLevel2'>
|
849
|
+
<div class='formula'>
|
850
|
+
<a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
|
851
|
+
<p class='MsoNormal'>
|
852
|
+
<span class='stem'>
|
853
|
+
<m:oMath>
|
854
|
+
<m:r>
|
855
|
+
<m:t>D1</m:t>
|
856
|
+
</m:r>
|
857
|
+
</m:oMath>
|
858
|
+
</span>
|
859
|
+
<span style='mso-tab-count:1'>  </span>
|
860
|
+
(1)
|
861
|
+
</p>
|
862
|
+
</div>
|
863
|
+
</div>
|
864
|
+
</p>
|
865
|
+
</div>
|
866
|
+
<p class='MsoNormal'> </p>
|
867
|
+
</div>
|
803
868
|
OUTPUT
|
804
869
|
end
|
805
870
|
|
@@ -953,8 +1018,8 @@ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="
|
|
953
1018
|
<div>
|
954
1019
|
<h1 class="ForewordTitle">Foreword</h1>
|
955
1020
|
<p class="TableTitle" style="text-align:center;font-size:0pt;"> </p>
|
956
|
-
<div align="center">
|
957
|
-
<table class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-
|
1021
|
+
<div align="center" class="table_container">
|
1022
|
+
<table class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;"><a name="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7"></a>
|
958
1023
|
<thead>
|
959
1024
|
<tr>
|
960
1025
|
<td rowspan="2" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;">
|
@@ -1008,8 +1073,8 @@ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="
|
|
1008
1073
|
<div>
|
1009
1074
|
<h1 class='ForewordTitle'>Foreword</h1>
|
1010
1075
|
<p class='TableTitle' style='text-align:center;font-size:0pt;'> </p>
|
1011
|
-
<div align='center'>
|
1012
|
-
<table class='MsoISOTable' style='mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-
|
1076
|
+
<div align='center' class="table_container">
|
1077
|
+
<table class='MsoISOTable' style='mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
|
1013
1078
|
<a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
|
1014
1079
|
<thead>
|
1015
1080
|
<tr>
|
data/spec/isodoc/section_spec.rb
CHANGED
data/spec/isodoc/table_spec.rb
CHANGED
@@ -199,7 +199,7 @@ RSpec.describe IsoDoc do
|
|
199
199
|
</iso-standard>
|
200
200
|
INPUT
|
201
201
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
202
|
-
<head
|
202
|
+
<head><style/></head>
|
203
203
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
204
204
|
<div class="WordSection1">
|
205
205
|
<p> </p>
|
@@ -210,8 +210,8 @@ RSpec.describe IsoDoc do
|
|
210
210
|
<div>
|
211
211
|
<h1 class="ForewordTitle">Foreword</h1>
|
212
212
|
<p class="TableTitle" style="text-align:center;">Table 1</p>
|
213
|
-
<div align="center">
|
214
|
-
<table id="tableD-0" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-
|
213
|
+
<div align="center" class="table_container">
|
214
|
+
<table id="tableD-0" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;">
|
215
215
|
<tbody>
|
216
216
|
<tr>
|
217
217
|
<td style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">A</td>
|
@@ -220,8 +220,8 @@ RSpec.describe IsoDoc do
|
|
220
220
|
</table>
|
221
221
|
</div>
|
222
222
|
<p class="TableTitle" style="text-align:center;">Table 2 — Repeatability and reproducibility of husked rice yield</p>
|
223
|
-
<div align="center">
|
224
|
-
<table id="tableD-1" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-
|
223
|
+
<div align="center" class="table_container">
|
224
|
+
<table id="tableD-1" class="MsoISOTable" style="mso-table-lspace:15.0cm;margin-left:423.0pt;mso-table-rspace:15.0cm;margin-right:423.0pt;mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;" title="tool tip" summary="long desc">
|
225
225
|
<thead>
|
226
226
|
<tr>
|
227
227
|
<td rowspan="2" align="left" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">Description</td>
|
data/spec/spec_helper.rb
CHANGED
@@ -55,7 +55,12 @@ END
|
|
55
55
|
|
56
56
|
WORD_HDR = <<~END
|
57
57
|
<html xmlns:epub="http://www.idpf.org/2007/ops" lang="en">
|
58
|
-
|
58
|
+
<head>
|
59
|
+
<style>
|
60
|
+
<!--
|
61
|
+
-->
|
62
|
+
</style>
|
63
|
+
</head>
|
59
64
|
<body lang="EN-US" link="blue" vlink="#954F72">
|
60
65
|
<div class="WordSection1">
|
61
66
|
<p> </p>
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: isodoc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.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: 2019-11-
|
11
|
+
date: 2019-11-19 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: asciimath
|
@@ -326,6 +326,7 @@ files:
|
|
326
326
|
- lib/isodoc/base_style/blocks.scss
|
327
327
|
- lib/isodoc/base_style/coverpage.scss
|
328
328
|
- lib/isodoc/base_style/defaults.scss
|
329
|
+
- lib/isodoc/base_style/metanorma_word.scss
|
329
330
|
- lib/isodoc/base_style/nav.scss
|
330
331
|
- lib/isodoc/base_style/reset.scss
|
331
332
|
- lib/isodoc/base_style/typography.scss
|
@@ -345,6 +346,7 @@ files:
|
|
345
346
|
- lib/isodoc/function/terms.rb
|
346
347
|
- lib/isodoc/function/to_word_html.rb
|
347
348
|
- lib/isodoc/function/utils.rb
|
349
|
+
- lib/isodoc/function/xref_anchor.rb
|
348
350
|
- lib/isodoc/function/xref_counter.rb
|
349
351
|
- lib/isodoc/function/xref_gen.rb
|
350
352
|
- lib/isodoc/function/xref_sect_gen.rb
|
@@ -369,6 +371,7 @@ files:
|
|
369
371
|
- spec/assets/htmlintro.html
|
370
372
|
- spec/assets/i18n.yaml
|
371
373
|
- spec/assets/iso.xml
|
374
|
+
- spec/assets/rice_image1
|
372
375
|
- spec/assets/rice_image1.png
|
373
376
|
- spec/assets/scripts.html
|
374
377
|
- spec/assets/std.css
|