isodoc 1.1.4 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. checksums.yaml +4 -4
  2. data/lib/isodoc-yaml/i18n-en.yaml +4 -1
  3. data/lib/isodoc-yaml/i18n-fr.yaml +4 -1
  4. data/lib/isodoc-yaml/i18n-zh-Hans.yaml +4 -1
  5. data/lib/isodoc.rb +1 -0
  6. data/lib/isodoc/common.rb +0 -2
  7. data/lib/isodoc/convert.rb +33 -27
  8. data/lib/isodoc/function/blocks.rb +10 -22
  9. data/lib/isodoc/function/blocks_example_note.rb +14 -15
  10. data/lib/isodoc/function/cleanup.rb +5 -4
  11. data/lib/isodoc/function/inline.rb +6 -76
  12. data/lib/isodoc/function/references.rb +10 -9
  13. data/lib/isodoc/function/reqt.rb +12 -11
  14. data/lib/isodoc/function/section.rb +39 -54
  15. data/lib/isodoc/function/table.rb +1 -6
  16. data/lib/isodoc/function/terms.rb +13 -6
  17. data/lib/isodoc/function/to_word_html.rb +1 -0
  18. data/lib/isodoc/function/utils.rb +4 -3
  19. data/lib/isodoc/html_function/html.rb +0 -1
  20. data/lib/isodoc/{function/i18n.rb → i18n.rb} +37 -36
  21. data/lib/isodoc/metadata.rb +4 -3
  22. data/lib/isodoc/metadata_date.rb +1 -1
  23. data/lib/isodoc/presentation_function/block.rb +138 -0
  24. data/lib/isodoc/presentation_function/inline.rb +131 -0
  25. data/lib/isodoc/presentation_function/section.rb +46 -0
  26. data/lib/isodoc/presentation_xml_convert.rb +38 -5
  27. data/lib/isodoc/version.rb +1 -1
  28. data/lib/isodoc/word_function/body.rb +12 -8
  29. data/lib/isodoc/word_function/inline.rb +3 -1
  30. data/lib/isodoc/xref.rb +5 -3
  31. data/lib/isodoc/xref/xref_sect_gen.rb +3 -3
  32. data/spec/assets/i18n.yaml +12 -1
  33. data/spec/isodoc/blocks_spec.rb +1101 -147
  34. data/spec/isodoc/cleanup_spec.rb +2 -2
  35. data/spec/isodoc/footnotes_spec.rb +2 -2
  36. data/spec/isodoc/i18n_spec.rb +679 -110
  37. data/spec/isodoc/inline_spec.rb +323 -142
  38. data/spec/isodoc/lists_spec.rb +2 -2
  39. data/spec/isodoc/postproc_spec.rb +1311 -1333
  40. data/spec/isodoc/ref_spec.rb +181 -3
  41. data/spec/isodoc/section_spec.rb +508 -680
  42. data/spec/isodoc/table_spec.rb +155 -4
  43. data/spec/isodoc/terms_spec.rb +111 -79
  44. data/spec/isodoc/xref_spec.rb +1569 -1186
  45. metadata +6 -3
@@ -261,7 +261,7 @@ RSpec.describe IsoDoc do
261
261
  </dd>
262
262
  </dl>
263
263
  <div class="Note">
264
- <p><span class="note_label">NOTE</span>&#160; This is a note</p>
264
+ <p>&#160; This is a note</p>
265
265
  </div>
266
266
  </div>
267
267
  <p class="zzSTDTitle1"/>
@@ -324,7 +324,7 @@ RSpec.describe IsoDoc do
324
324
  <tr>
325
325
  <td colspan="2">
326
326
  <div class="Note">
327
- <p class="Note"><span class="note_label">NOTE</span><span style="mso-tab-count:1">&#160; </span>This is a note</p>
327
+ <p class="Note"><span class="note_label"/><span style="mso-tab-count:1">&#160; </span>This is a note</p>
328
328
  </div>
329
329
  </td>
330
330
  </tr>
@@ -1,124 +1,124 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spec_helper'
4
- require 'fileutils'
3
+ require "spec_helper"
4
+ require "fileutils"
5
5
 
6
6
  RSpec.describe IsoDoc do
7
- it 'generates file based on string input' do
8
- FileUtils.rm_f 'test.doc'
9
- FileUtils.rm_f 'test.html'
10
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').convert('test', <<~"INPUT", false)
11
- <iso-standard xmlns="http://riboseinc.com/isoxml">
12
- <bibdata>
13
- <title language="en">test</title>
14
- </bibdata>
15
- <preface><foreword>
16
- <note>
17
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
18
- </note>
19
- </foreword></preface>
20
- </iso-standard>
7
+ it "generates file based on string input" do
8
+ FileUtils.rm_f "test.doc"
9
+ FileUtils.rm_f "test.html"
10
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).convert("test", <<~"INPUT", false)
11
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
12
+ <bibdata>
13
+ <title language="en">test</title>
14
+ </bibdata>
15
+ <preface><foreword>
16
+ <note>
17
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
18
+ </note>
19
+ </foreword></preface>
20
+ </iso-standard>
21
21
  INPUT
22
- expect(File.exist?('test.html')).to be true
23
- html = File.read('test.html')
22
+ expect(File.exist?("test.html")).to be true
23
+ html = File.read("test.html")
24
24
  expect(html).to match(%r{<title>test</title>})
25
25
  expect(html).to match(/another empty stylesheet/)
26
26
  expect(html).to match(%r{cdnjs\.cloudflare\.com/ajax/libs/mathjax/})
27
27
  expect(html).to match(/delimiters: \[\['\(#\(', '\)#\)'\]\]/)
28
28
  end
29
29
 
30
- it 'ignores Liquid markup in the document body' do
31
- FileUtils.rm_f 'test.doc'
32
- FileUtils.rm_f 'test.html'
33
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
34
- <iso-standard xmlns="http://riboseinc.com/isoxml">
35
- <bibdata>
36
- <title language="en">test</title>
37
- </bibdata>
38
- <preface><foreword>
39
- <note>
40
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
41
- </note>
42
- </foreword></preface>
43
- </iso-standard>
30
+ it "ignores Liquid markup in the document body" do
31
+ FileUtils.rm_f "test.doc"
32
+ FileUtils.rm_f "test.html"
33
+ IsoDoc::HtmlConvert.new(wordstylesheet: "spec/assets/word.css").convert("test", <<~"INPUT", false)
34
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
35
+ <bibdata>
36
+ <title language="en">test</title>
37
+ </bibdata>
38
+ <preface><foreword>
39
+ <note>
40
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
41
+ </note>
42
+ </foreword></preface>
43
+ </iso-standard>
44
44
  INPUT
45
- expect(File.exist?('test.html')).to be true
46
- html = File.read('test.html')
45
+ expect(File.exist?("test.html")).to be true
46
+ html = File.read("test.html")
47
47
  end
48
48
 
49
- it 'ignores Liquid markup in the document body (Word)' do
50
- FileUtils.rm_f 'test.doc'
51
- FileUtils.rm_f 'test.html'
52
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
53
- <iso-standard xmlns="http://riboseinc.com/isoxml">
54
- <bibdata>
55
- <title language="en">test</title>
56
- </bibdata>
57
- <preface><foreword>
58
- <note>
59
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
60
- </note>
61
- </foreword></preface>
62
- </iso-standard>
49
+ it "ignores Liquid markup in the document body (Word)" do
50
+ FileUtils.rm_f "test.doc"
51
+ FileUtils.rm_f "test.html"
52
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css"}).convert("test", <<~"INPUT", false)
53
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
54
+ <bibdata>
55
+ <title language="en">test</title>
56
+ </bibdata>
57
+ <preface><foreword>
58
+ <note>
59
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
60
+ </note>
61
+ </foreword></preface>
62
+ </iso-standard>
63
63
  INPUT
64
- expect(File.exist?('test.doc')).to be true
65
- html = File.read('test.doc')
64
+ expect(File.exist?("test.doc")).to be true
65
+ html = File.read("test.doc")
66
66
  end
67
67
 
68
- it 'generates HTML output docs with null configuration' do
69
- FileUtils.rm_f 'test.doc'
70
- FileUtils.rm_f 'test.html'
71
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
72
- <iso-standard xmlns="http://riboseinc.com/isoxml">
73
- <preface><foreword>
74
- <note>
75
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
76
- </note>
77
- </foreword></preface>
78
- </iso-standard>
68
+ it "generates HTML output docs with null configuration" do
69
+ FileUtils.rm_f "test.doc"
70
+ FileUtils.rm_f "test.html"
71
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css"}).convert("test", <<~"INPUT", false)
72
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
73
+ <preface><foreword>
74
+ <note>
75
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
76
+ </note>
77
+ </foreword></preface>
78
+ </iso-standard>
79
79
  INPUT
80
- expect(File.exist?('test.html')).to be true
81
- html = File.read('test.html')
80
+ expect(File.exist?("test.html")).to be true
81
+ html = File.read("test.html")
82
82
  expect(html).not_to match(%r{<title>test</title>})
83
83
  expect(html).not_to match(/another empty stylesheet/)
84
84
  expect(html).to match(%r{cdnjs\.cloudflare\.com/ajax/libs/mathjax/})
85
85
  expect(html).to match(/delimiters: \[\['\(#\(', '\)#\)'\]\]/)
86
86
  end
87
87
 
88
- it 'generates Word output docs with null configuration' do
89
- FileUtils.rm_f 'test.doc'
90
- FileUtils.rm_f 'test.html'
91
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
92
- <iso-standard xmlns="http://riboseinc.com/isoxml">
93
- <preface><foreword>
94
- <note>
95
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
96
- </note>
97
- </foreword></preface>
98
- </iso-standard>
88
+ it "generates Word output docs with null configuration" do
89
+ FileUtils.rm_f "test.doc"
90
+ FileUtils.rm_f "test.html"
91
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
92
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
93
+ <preface><foreword>
94
+ <note>
95
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
96
+ </note>
97
+ </foreword></preface>
98
+ </iso-standard>
99
99
  INPUT
100
- expect(File.exist?('test.doc')).to be true
101
- word = File.read('test.doc')
100
+ expect(File.exist?("test.doc")).to be true
101
+ word = File.read("test.doc")
102
102
  expect(word).to match(/one empty stylesheet/)
103
103
  expect(word).to match(/div\.table_container/)
104
104
  end
105
105
 
106
- it 'generates HTML output docs with null configuration from file' do
107
- FileUtils.rm_f 'spec/assets/iso.doc'
108
- FileUtils.rm_f 'spec/assets/iso.html'
109
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
110
- expect(File.exist?('spec/assets/iso.html')).to be true
111
- html = File.read('spec/assets/iso.html')
106
+ it "generates HTML output docs with null configuration from file" do
107
+ FileUtils.rm_f "spec/assets/iso.doc"
108
+ FileUtils.rm_f "spec/assets/iso.html"
109
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
110
+ expect(File.exist?("spec/assets/iso.html")).to be true
111
+ html = File.read("spec/assets/iso.html")
112
112
  expect(html).to match(/another empty stylesheet/)
113
113
  expect(html).to match(%r{https://use.fontawesome.com})
114
114
  expect(html).to match(%r{libs/jquery})
115
115
  end
116
116
 
117
- it 'generates Headless HTML output docs with null configuration from file' do
118
- FileUtils.rm_f 'spec/assets/iso.html'
119
- IsoDoc::HeadlessHtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
120
- expect(File.exist?('spec/assets/iso.headless.html')).to be true
121
- html = File.read('spec/assets/iso.headless.html')
117
+ it "generates Headless HTML output docs with null configuration from file" do
118
+ FileUtils.rm_f "spec/assets/iso.html"
119
+ IsoDoc::HeadlessHtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
120
+ expect(File.exist?("spec/assets/iso.headless.html")).to be true
121
+ html = File.read("spec/assets/iso.headless.html")
122
122
  expect(html).not_to match(/another empty stylesheet/)
123
123
  expect(html).not_to match(%r{https://use.fontawesome.com})
124
124
  expect(html).not_to match(%r{libs/jquery})
@@ -128,1431 +128,1409 @@ INPUT
128
128
  expect(html).to match(%r{<div})
129
129
  end
130
130
 
131
- it 'generates Word output docs with null configuration from file' do
132
- FileUtils.rm_f 'spec/assets/iso.doc'
133
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
134
- expect(File.exist?('spec/assets/iso.doc')).to be true
135
- word = File.read('spec/assets/iso.doc')
131
+ it "generates Word output docs with null configuration from file" do
132
+ FileUtils.rm_f "spec/assets/iso.doc"
133
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
134
+ expect(File.exist?("spec/assets/iso.doc")).to be true
135
+ word = File.read("spec/assets/iso.doc")
136
136
  expect(word).to match(/one empty stylesheet/)
137
137
  end
138
138
 
139
- it 'generates HTML output docs with complete configuration' do
140
- FileUtils.rm_f 'test.doc'
141
- FileUtils.rm_f 'test.html'
142
- IsoDoc::HtmlConvert.new(bodyfont: 'Zapf', htmlstylesheet: 'spec/assets/html.scss', htmlcoverpage: 'spec/assets/htmlcover.html', htmlintropage: 'spec/assets/htmlintro.html', scripts: 'spec/assets/scripts.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
143
- <iso-standard xmlns="http://riboseinc.com/isoxml">
144
- <preface><foreword>
145
- <note>
146
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
147
- </note>
148
- </foreword></preface>
149
- </iso-standard>
139
+ it "generates HTML output docs with complete configuration" do
140
+ FileUtils.rm_f "test.doc"
141
+ FileUtils.rm_f "test.html"
142
+ IsoDoc::HtmlConvert.new({bodyfont: "Zapf", htmlstylesheet: "spec/assets/html.scss", htmlcoverpage: "spec/assets/htmlcover.html", htmlintropage: "spec/assets/htmlintro.html", scripts: "spec/assets/scripts.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
143
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
144
+ <preface><foreword>
145
+ <note>
146
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
147
+ </note>
148
+ </foreword></preface>
149
+ </iso-standard>
150
150
  INPUT
151
- html = File.read('test.html')
151
+ html = File.read("test.html")
152
152
  expect(html).to match(/another empty stylesheet/)
153
153
  expect(html).to match(/font-family: Zapf/)
154
154
  expect(html).to match(/an empty html cover page/)
155
155
  expect(html).to match(/an empty html intro page/)
156
156
  expect(html).to match(/This is > a script/)
157
157
  expect(html).not_to match(/CDATA/)
158
- expect(html).to match(%r{Enkonduko</h1>})
158
+ expect(html).to match(%r{Anta&#x16D;parolo</h1>})
159
159
  end
160
160
 
161
- it 'generates HTML output docs with default fonts' do
162
- FileUtils.rm_f 'test.doc'
163
- FileUtils.rm_f 'test.html'
164
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', htmlcoverpage: 'spec/assets/htmlcover.html', htmlintropage: 'spec/assets/htmlintro.html', scripts: 'spec/assets/scripts.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
165
- <iso-standard xmlns="http://riboseinc.com/isoxml">
166
- <preface><foreword>
167
- <note>
168
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
169
- </note>
170
- </foreword></preface>
171
- </iso-standard>
161
+ it "generates HTML output docs with default fonts" do
162
+ FileUtils.rm_f "test.doc"
163
+ FileUtils.rm_f "test.html"
164
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", htmlcoverpage: "spec/assets/htmlcover.html", htmlintropage: "spec/assets/htmlintro.html", scripts: "spec/assets/scripts.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
165
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
166
+ <preface><foreword>
167
+ <note>
168
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
169
+ </note>
170
+ </foreword></preface>
171
+ </iso-standard>
172
172
  INPUT
173
- html = File.read('test.html')
173
+ html = File.read("test.html")
174
174
  expect(html).to match(/another empty stylesheet/)
175
175
  expect(html).to match(/font-family: Arial/)
176
176
  expect(html).to match(/an empty html cover page/)
177
177
  expect(html).to match(/an empty html intro page/)
178
178
  expect(html).to match(/This is > a script/)
179
179
  expect(html).not_to match(/CDATA/)
180
- expect(html).to match(%r{Enkonduko</h1>})
180
+ expect(html).to match(%r{Anta&#x16D;parolo</h1>})
181
181
  end
182
182
 
183
- it 'generates Word output docs with complete configuration' do
184
- FileUtils.rm_f 'test.doc'
185
- FileUtils.rm_f 'test.html'
186
- IsoDoc::WordConvert.new(bodyfont: 'Zapf', wordstylesheet: 'spec/assets/html.scss', standardstylesheet: 'spec/assets/std.css', header: 'spec/assets/header.html', wordcoverpage: 'spec/assets/wordcover.html', wordintropage: 'spec/assets/wordintro.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
187
- <iso-standard xmlns="http://riboseinc.com/isoxml">
188
- <preface><foreword>
189
- <note>
190
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
191
- </note>
192
- </foreword></preface>
193
- </iso-standard>
183
+ it "generates Word output docs with complete configuration" do
184
+ FileUtils.rm_f "test.doc"
185
+ FileUtils.rm_f "test.html"
186
+ IsoDoc::WordConvert.new({bodyfont: "Zapf", wordstylesheet: "spec/assets/html.scss", standardstylesheet: "spec/assets/std.css", header: "spec/assets/header.html", wordcoverpage: "spec/assets/wordcover.html", wordintropage: "spec/assets/wordintro.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
187
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
188
+ <preface><foreword>
189
+ <note>
190
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
191
+ </note>
192
+ </foreword></preface>
193
+ </iso-standard>
194
194
  INPUT
195
- word = File.read('test.doc')
195
+ word = File.read("test.doc")
196
196
  expect(word).to match(/another empty stylesheet/)
197
197
  expect(word).to match(/font-family: Zapf/)
198
198
  expect(word).to match(/a third empty stylesheet/)
199
- # expect(word).to match(/<title>test<\/title>/)
199
+ #expect(word).to match(/<title>test<\/title>/)
200
200
  expect(word).to match(/test_files\/header.html/)
201
201
  expect(word).to match(/an empty word cover page/)
202
202
  expect(word).to match(/an empty word intro page/)
203
- expect(word).to match(%r{Enkonduko</h1>})
203
+ expect(word).to match(%r{Anta&#x16D;parolo</h1>})
204
204
  end
205
205
 
206
- it 'generates Word output docs with default fonts' do
207
- FileUtils.rm_f 'test.doc'
208
- FileUtils.rm_f 'test.html'
209
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/html.scss', standardstylesheet: 'spec/assets/std.css', header: 'spec/assets/header.html', wordcoverpage: 'spec/assets/wordcover.html', wordintropage: 'spec/assets/wordintro.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
210
- <iso-standard xmlns="http://riboseinc.com/isoxml">
211
- <preface><foreword>
212
- <note>
213
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
214
- </note>
215
- </foreword></preface>
216
- </iso-standard>
206
+ it "generates Word output docs with default fonts" do
207
+ FileUtils.rm_f "test.doc"
208
+ FileUtils.rm_f "test.html"
209
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/html.scss", standardstylesheet: "spec/assets/std.css", header: "spec/assets/header.html", wordcoverpage: "spec/assets/wordcover.html", wordintropage: "spec/assets/wordintro.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
210
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
211
+ <preface><foreword>
212
+ <note>
213
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
214
+ </note>
215
+ </foreword></preface>
216
+ </iso-standard>
217
217
  INPUT
218
- word = File.read('test.doc')
218
+ word = File.read("test.doc")
219
219
  expect(word).to match(/another empty stylesheet/)
220
220
  expect(word).to match(/font-family: Arial/)
221
221
  expect(word).to match(/a third empty stylesheet/)
222
- # expect(word).to match(/<title>test<\/title>/)
222
+ #expect(word).to match(/<title>test<\/title>/)
223
223
  expect(word).to match(/test_files\/header.html/)
224
224
  expect(word).to match(/an empty word cover page/)
225
225
  expect(word).to match(/an empty word intro page/)
226
- expect(word).to match(%r{Enkonduko</h1>})
226
+ expect(word).to match(%r{Anta&#x16D;parolo</h1>})
227
227
  end
228
228
 
229
- it 'converts definition lists to tables for Word' do
230
- FileUtils.rm_f 'test.doc'
231
- FileUtils.rm_f 'test.html'
232
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
233
- <iso-standard xmlns="http://riboseinc.com/isoxml">
234
- <preface><foreword>
235
- <dl>
236
- <dt>Term</dt>
237
- <dd>Definition</dd>
238
- <dt>Term 2</dt>
239
- <dd>Definition 2</dd>
240
- </dl>
241
- </foreword></preface>
242
- </iso-standard>
229
+ it "converts definition lists to tables for Word" do
230
+ FileUtils.rm_f "test.doc"
231
+ FileUtils.rm_f "test.html"
232
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
233
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
234
+ <preface><foreword>
235
+ <dl>
236
+ <dt>Term</dt>
237
+ <dd>Definition</dd>
238
+ <dt>Term 2</dt>
239
+ <dd>Definition 2</dd>
240
+ </dl>
241
+ </foreword></preface>
242
+ </iso-standard>
243
243
  INPUT
244
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
245
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
244
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
245
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
246
246
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
247
- <div class="WordSection2">
248
- <p class="MsoNormal"><br clear="all" style="mso-special-character:line-break;page-break-before:always"/></p>
249
- <div>
250
- <h1 class="ForewordTitle">Foreword</h1>
251
- <table class="dl">
252
- <tr>
253
- <td valign="top" align="left">
254
- <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term</p>
255
- </td>
256
- <td valign="top">Definition</td>
257
- </tr>
258
- <tr>
259
- <td valign="top" align="left">
260
- <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term 2</p>
261
- </td>
262
- <td valign="top">Definition 2</td>
263
- </tr>
264
- </table>
247
+ <div class="WordSection2">
248
+ <p class="MsoNormal"><br clear="all" style="mso-special-character:line-break;page-break-before:always"/></p>
249
+ <div>
250
+ <h1 class="ForewordTitle">Foreword</h1>
251
+ <table class="dl">
252
+ <tr>
253
+ <td valign="top" align="left">
254
+ <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term</p>
255
+ </td>
256
+ <td valign="top">Definition</td>
257
+ </tr>
258
+ <tr>
259
+ <td valign="top" align="left">
260
+ <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term 2</p>
261
+ </td>
262
+ <td valign="top">Definition 2</td>
263
+ </tr>
264
+ </table>
265
+ </div>
266
+ <p class="MsoNormal">&#xA0;</p>
265
267
  </div>
266
- <p class="MsoNormal">&#xA0;</p>
267
- </div>
268
268
  OUTPUT
269
269
  end
270
270
 
271
- it 'populates Word template with terms reference labels' do
272
- FileUtils.rm_f 'test.doc'
273
- FileUtils.rm_f 'test.html'
274
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
275
- <iso-standard xmlns="http://riboseinc.com/isoxml">
276
- <sections>
277
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
278
-
279
- <term id="paddy1"><preferred>paddy</preferred>
280
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
281
- <termsource status="modified">
282
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
283
- <modification>
284
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
285
- </modification>
286
- </termsource></term>
287
-
288
- </terms>
289
- </sections>
290
- </iso-standard>
291
-
271
+ it "populates Word template with terms reference labels" do
272
+ FileUtils.rm_f "test.doc"
273
+ FileUtils.rm_f "test.html"
274
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
275
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
276
+ <sections>
277
+ <terms id="_terms_and_definitions" obligation="normative"><title>1.<tab/>Terms and Definitions</title>
278
+ <term id="paddy1"><name>1.1.</name><preferred>paddy</preferred>
279
+ <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
280
+ <termsource status="modified">
281
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011">ISO 7301:2011, Clause 3.1</origin>
282
+ <modification>
283
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
284
+ </modification>
285
+ </termsource></term>
286
+ </terms>
287
+ </sections>
288
+ </iso-standard>
292
289
  INPUT
293
- word = File.read('test.doc').sub(/^.*<div class="WordSection3">/m, '<div class="WordSection3">')
294
- .sub(%r{<div style="mso-element:footnote-list"/>.*$}m, '')
290
+ word = File.read("test.doc").sub(/^.*<div class="WordSection3">/m, '<div class="WordSection3">').
291
+ sub(%r{<div style="mso-element:footnote-list"/>.*$}m, "")
295
292
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
296
- <div class="WordSection3">
297
- <p class="zzSTDTitle1"></p>
298
- <div><a name="_terms_and_definitions" id="_terms_and_definitions"></a><h1>1.<span style="mso-tab-count:1">&#xA0; </span>Terms and Definitions</h1>
299
- <p class="TermNum"><a name="paddy1" id="paddy1"></a>1.1.</p><p class="Terms" style="text-align:left;">paddy</p>
300
- <p class="MsoNormal"><a name="_eb29b35e-123e-4d1c-b50b-2714d41e747f" id="_eb29b35e-123e-4d1c-b50b-2714d41e747f"></a>rice retaining its husk after threshing</p>
301
- <p class="MsoNormal">[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified &#x2014; The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here]</p></div>
302
- </div>
293
+ <div class="WordSection3">
294
+ <p class="zzSTDTitle1"></p>
295
+ <div><a name="_terms_and_definitions" id="_terms_and_definitions"></a><h1>1.<span style="mso-tab-count:1">&#xA0; </span>Terms and Definitions</h1>
296
+ <p class="TermNum"><a name="paddy1" id="paddy1"></a>1.1.</p><p class="Terms" style="text-align:left;">paddy</p>
297
+ <p class="MsoNormal"><a name="_eb29b35e-123e-4d1c-b50b-2714d41e747f" id="_eb29b35e-123e-4d1c-b50b-2714d41e747f"></a>rice retaining its husk after threshing</p>
298
+ <p class="MsoNormal">[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified &#x2014; The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here]</p></div>
299
+ </div>
303
300
  OUTPUT
304
301
  end
305
302
 
306
- it 'populates Word header' do
307
- FileUtils.rm_f 'test.doc'
308
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', header: 'spec/assets/header.html').convert('test', <<~"INPUT", false)
309
- <iso-standard xmlns="http://riboseinc.com/isoxml">
310
- <bibdata type="article">
311
- <docidentifier>
312
- <project-number part="1">1000</project-number>
313
- </docidentifier>
314
- </bibdata>
315
- </iso-standard>
316
-
303
+ it "populates Word header" do
304
+ FileUtils.rm_f "test.doc"
305
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", header: "spec/assets/header.html"}).convert("test", <<~"INPUT", false)
306
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
307
+ <bibdata type="article">
308
+ <docidentifier>
309
+ <project-number part="1">1000</project-number>
310
+ </docidentifier>
311
+ </bibdata>
312
+ </iso-standard>
317
313
  INPUT
318
- word = File.read('test.doc').sub(%r{^.*Content-Location: file:///C:/Doc/test_files/header.html}m, 'Content-Location: file:///C:/Doc/test_files/header.html')
319
- .sub(/------=_NextPart.*$/m, '')
314
+ word = File.read("test.doc").sub(%r{^.*Content-Location: file:///C:/Doc/test_files/header.html}m, "Content-Location: file:///C:/Doc/test_files/header.html").
315
+ sub(/------=_NextPart.*$/m, "")
320
316
  expect(word).to be_equivalent_to <<~"OUTPUT"
321
-
322
- Content-Location: file:///C:/Doc/test_files/header.html
323
- Content-Transfer-Encoding: base64
324
- Content-Type: text/html charset="utf-8"
325
-
326
- Ci8qIGFuIGVtcHR5IGhlYWRlciAqLwoKU1RBUlQgRE9DIElEOiAKICAgICAgICAgICAxMDAwCiAg
327
- ICAgICAgIDogRU5EIERPQyBJRAoKRklMRU5BTUU6IHRlc3QKCg==
328
-
317
+ Content-Location: file:///C:/Doc/test_files/header.html
318
+ Content-Transfer-Encoding: base64
319
+ Content-Type: text/html charset="utf-8"
320
+ Ci8qIGFuIGVtcHR5IGhlYWRlciAqLwoKU1RBUlQgRE9DIElEOiAKICAgICAgICAgICAxMDAwCiAg
321
+ ICAgICAgIDogRU5EIERPQyBJRAoKRklMRU5BTUU6IHRlc3QKCg==
329
322
  OUTPUT
330
323
  end
331
324
 
332
- it 'populates Word ToC' do
333
- FileUtils.rm_f 'test.doc'
334
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html').convert('test', <<~"INPUT", false)
335
- <iso-standard xmlns="http://riboseinc.com/isoxml">
336
- <sections>
337
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
338
-
339
- <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
340
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
341
- </fn></title>
342
- </clause>
343
- <clause id="O" inline-header="false" obligation="normative">
344
- <title>Clause 4.2</title>
345
- <p>A<fn reference="1">
346
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
347
- </fn></p>
348
- <clause id="P" inline-header="false" obligation="normative">
349
- <title>Clause 4.2.1</title>
350
- </clause>
351
- </clause></clause>
352
- </sections>
353
- </iso-standard>
354
-
325
+ it "populates Word ToC" do
326
+ FileUtils.rm_f "test.doc"
327
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html"}).convert("test", <<~"INPUT", false)
328
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
329
+ <sections>
330
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
331
+ <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
332
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
333
+ </fn></title>
334
+ </clause>
335
+ <clause id="O" inline-header="false" obligation="normative">
336
+ <title>Clause 4.2</title>
337
+ <p>A<fn reference="1">
338
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
339
+ </fn></p>
340
+ <clause id="P" inline-header="false" obligation="normative">
341
+ <title>Clause 4.2.1</title>
342
+ </clause>
343
+ </clause></clause>
344
+ </sections>
345
+ </iso-standard>
355
346
  INPUT
356
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
357
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
358
- expect(xmlpp(word.gsub(/_Toc\d\d+/, '_Toc'))).to be_equivalent_to xmlpp(<<~'OUTPUT')
359
- <div class="WordSection2">
360
- /* an empty word intro page */
347
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
348
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
349
+ expect(xmlpp(word.gsub(/_Toc\d\d+/, "_Toc"))).to be_equivalent_to xmlpp(<<~'OUTPUT')
350
+ <div class="WordSection2">
351
+ /* an empty word intro page */
352
+
361
353
  <p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes">&#xA0;</span>TOC
362
- \o "1-2" \h \z \u <span style="mso-element:field-separator"></span></span>
363
- <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
364
- <a href="#_Toc">1. Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
365
- <span style="mso-tab-count:1 dotted">. </span>
366
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
367
- <span style="mso-element:field-begin"></span></span>
368
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
369
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
370
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
354
+ \o "1-2" \h \z \u <span style="mso-element:field-separator"></span></span>
355
+ <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
356
+ <a href="#_Toc">Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
357
+ <span style="mso-tab-count:1 dotted">. </span>
358
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
359
+ <span style="mso-element:field-begin"></span></span>
360
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
361
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
362
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
371
363
  <p class="MsoToc2">
372
- <span class="MsoHyperlink">
373
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
374
- <a href="#_Toc">1.1. Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
375
- <span style="mso-tab-count:1 dotted">. </span>
376
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
377
- <span style="mso-element:field-begin"></span></span>
378
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
379
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
380
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
381
- </span>
382
- </p>
364
+ <span class="MsoHyperlink">
365
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
366
+ <a href="#_Toc">Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
367
+ <span style="mso-tab-count:1 dotted">. </span>
368
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
369
+ <span style="mso-element:field-begin"></span></span>
370
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
371
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
372
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
373
+ </span>
374
+ </p>
383
375
  <p class="MsoToc2">
384
- <span class="MsoHyperlink">
385
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
386
- <a href="#_Toc">1.2. Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
387
- <span style="mso-tab-count:1 dotted">. </span>
388
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
389
- <span style="mso-element:field-begin"></span></span>
390
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
391
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
392
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
393
- </span>
394
- </p>
376
+ <span class="MsoHyperlink">
377
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
378
+ <a href="#_Toc">Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
379
+ <span style="mso-tab-count:1 dotted">. </span>
380
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
381
+ <span style="mso-element:field-begin"></span></span>
382
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
383
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
384
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
385
+ </span>
386
+ </p>
395
387
  <p class="MsoToc1">
396
- <span lang="EN-GB" xml:lang="EN-GB">
397
- <span style="mso-element:field-end"></span>
398
- </span>
399
- <span lang="EN-GB" xml:lang="EN-GB">
400
- <p class="MsoNormal">&#xA0;</p>
401
- </span>
402
- </p>
403
- <p class="MsoNormal">&#xA0;</p>
404
- </div>
388
+ <span lang="EN-GB" xml:lang="EN-GB">
389
+ <span style="mso-element:field-end"></span>
390
+ </span>
391
+ <span lang="EN-GB" xml:lang="EN-GB">
392
+ <p class="MsoNormal">&#xA0;</p>
393
+ </span>
394
+ </p>
395
+ <p class="MsoNormal">&#xA0;</p>
396
+ </div>
405
397
  OUTPUT
406
398
  end
407
399
 
408
- it 'populates Word ToC with custom levels' do
409
- FileUtils.rm_f 'test.doc'
410
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html', doctoclevels: 3).convert('test', <<~"INPUT", false)
411
- <iso-standard xmlns="http://riboseinc.com/isoxml">
412
- <sections>
413
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
414
-
415
- <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
416
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
417
- </fn></title>
418
- </clause>
419
- <clause id="O" inline-header="false" obligation="normative">
420
- <title>Clause 4.2</title>
421
- <p>A<fn reference="1">
422
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
423
- </fn></p>
424
- <clause id="P" inline-header="false" obligation="normative">
425
- <title>Clause 4.2.1</title>
426
- </clause>
427
- </clause></clause>
428
- </sections>
429
- </iso-standard>
430
-
400
+ it "populates Word ToC with custom levels" do
401
+ FileUtils.rm_f "test.doc"
402
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html", doctoclevels: 3}).convert("test", <<~"INPUT", false)
403
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
404
+ <sections>
405
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
406
+ <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
407
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
408
+ </fn></title>
409
+ </clause>
410
+ <clause id="O" inline-header="false" obligation="normative">
411
+ <title>Clause 4.2</title>
412
+ <p>A<fn reference="1">
413
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
414
+ </fn></p>
415
+ <clause id="P" inline-header="false" obligation="normative">
416
+ <title>Clause 4.2.1</title>
417
+ </clause>
418
+ </clause></clause>
419
+ </sections>
420
+ </iso-standard>
431
421
  INPUT
432
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
433
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
434
- expect(xmlpp(word.gsub(/_Toc\d\d+/, '_Toc'))).to be_equivalent_to xmlpp(<<~'OUTPUT')
435
- <div class="WordSection2">
436
- /* an empty word intro page */
437
-
438
- <p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes">&#xA0;</span>TOC
439
- \o "1-3" \h \z \u <span style="mso-element:field-separator"></span></span>
440
- <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
441
- <a href="#_Toc">1. Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
442
- <span style="mso-tab-count:1 dotted">. </span>
443
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
444
- <span style="mso-element:field-begin"></span></span>
445
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
446
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
447
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
448
-
449
- <p class="MsoToc2">
450
- <span class="MsoHyperlink">
451
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
452
- <a href="#_Toc">1.1. Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
453
- <span style="mso-tab-count:1 dotted">. </span>
454
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
455
- <span style="mso-element:field-begin"></span></span>
456
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
457
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
458
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
459
- </span>
460
- </p>
422
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
423
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
424
+ expect(xmlpp(word.gsub(/_Toc\d\d+/, "_Toc"))).to be_equivalent_to xmlpp(<<~'OUTPUT')
425
+ <div class="WordSection2">
426
+ /* an empty word intro page */
461
427
 
462
- <p class="MsoToc2">
463
- <span class="MsoHyperlink">
464
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
465
- <a href="#_Toc">1.2. Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
466
- <span style="mso-tab-count:1 dotted">. </span>
467
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
468
- <span style="mso-element:field-begin"></span></span>
469
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
470
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
471
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
472
- </span>
473
- </p>
474
-
475
- <p class="MsoToc3">
476
- <span class="MsoHyperlink">
477
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
478
- <a href="#_Toc">1.2.1. Clause 4.2.1<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
479
- <span style="mso-tab-count:1 dotted">. </span>
480
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
481
- <span style="mso-element:field-begin"></span></span>
482
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
483
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
484
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
485
- </span>
486
- </p>
487
-
488
- <p class="MsoToc1">
489
- <span lang="EN-GB" xml:lang="EN-GB">
490
- <span style="mso-element:field-end"></span>
491
- </span>
492
- <span lang="EN-GB" xml:lang="EN-GB">
493
- <p class="MsoNormal">&#xA0;</p>
494
- </span>
495
- </p>
496
-
497
-
498
- <p class="MsoNormal">&#xA0;</p>
499
- </div>
428
+ <p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes">&#xA0;</span>TOC
429
+ \o "1-3" \h \z \u <span style="mso-element:field-separator"></span></span>
430
+ <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
431
+ <a href="#_Toc">Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
432
+ <span style="mso-tab-count:1 dotted">. </span>
433
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
434
+ <span style="mso-element:field-begin"></span></span>
435
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
436
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
437
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
438
+ <p class="MsoToc2">
439
+ <span class="MsoHyperlink">
440
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
441
+ <a href="#_Toc">Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
442
+ <span style="mso-tab-count:1 dotted">. </span>
443
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
444
+ <span style="mso-element:field-begin"></span></span>
445
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
446
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
447
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
448
+ </span>
449
+ </p>
450
+ <p class="MsoToc2">
451
+ <span class="MsoHyperlink">
452
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
453
+ <a href="#_Toc">Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
454
+ <span style="mso-tab-count:1 dotted">. </span>
455
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
456
+ <span style="mso-element:field-begin"></span></span>
457
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
458
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
459
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
460
+ </span>
461
+ </p>
462
+ <p class="MsoToc3">
463
+ <span class="MsoHyperlink">
464
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
465
+ <a href="#_Toc">Clause 4.2.1<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
466
+ <span style="mso-tab-count:1 dotted">. </span>
467
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
468
+ <span style="mso-element:field-begin"></span></span>
469
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
470
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
471
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
472
+ </span>
473
+ </p>
474
+ <p class="MsoToc1">
475
+ <span lang="EN-GB" xml:lang="EN-GB">
476
+ <span style="mso-element:field-end"></span>
477
+ </span>
478
+ <span lang="EN-GB" xml:lang="EN-GB">
479
+ <p class="MsoNormal">&#xA0;</p>
480
+ </span>
481
+ </p>
482
+ <p class="MsoNormal">&#xA0;</p>
483
+ </div>
500
484
  OUTPUT
501
- end
502
-
503
- it 'generates HTML output with custom ToC levels function' do
504
- FileUtils.rm_f 'test.doc'
505
- FileUtils.rm_f 'test.html'
506
- IsoDoc::HtmlConvert.new(htmltoclevels: 3).convert('test', <<~"INPUT", false)
507
- <iso-standard xmlns="http://riboseinc.com/isoxml">
508
- <preface><foreword>
509
- <note>
510
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
511
- </note>
512
- </foreword></preface>
513
- </iso-standard>
485
+ end
486
+
487
+ it "generates HTML output with custom ToC levels function" do
488
+ FileUtils.rm_f "test.doc"
489
+ FileUtils.rm_f "test.html"
490
+ IsoDoc::HtmlConvert.new({htmltoclevels: 3}).convert("test", <<~"INPUT", false)
491
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
492
+ <preface><foreword>
493
+ <note>
494
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
495
+ </note>
496
+ </foreword></preface>
497
+ </iso-standard>
514
498
  INPUT
515
- html = File.read('test.html')
499
+ html = File.read("test.html")
516
500
  toclevel = <<~"TOCLEVEL"
517
- function toclevel() { return "h1:not(:empty):not(.TermNum):not(.noTOC),h2:not(:empty):not(.TermNum):not(.noTOC),h3:not(:empty):not(.TermNum):not(.noTOC)";}
501
+ function toclevel() { return "h1:not(:empty):not(.TermNum):not(.noTOC),h2:not(:empty):not(.TermNum):not(.noTOC),h3:not(:empty):not(.TermNum):not(.noTOC)";}
518
502
  TOCLEVEL
519
503
  expect(html).to include toclevel
520
504
  end
521
505
 
522
- it 'reorders footnote numbers in HTML' do
523
- FileUtils.rm_f 'test.html'
524
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html').convert('test', <<~"INPUT", false)
525
- <iso-standard xmlns="http://riboseinc.com/isoxml">
526
- <sections>
527
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><fn reference="3">
528
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">This is a footnote.</p>
529
- </fn><clause id="N" inline-header="false" obligation="normative">
530
-
531
- <title>Introduction to this<fn reference="2">
532
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
533
- </fn></title>
534
- </clause>
535
- <clause id="O" inline-header="false" obligation="normative">
536
- <title>Clause 4.2</title>
537
- <p>A<fn reference="1">
538
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
539
- </fn></p>
540
- </clause></clause>
541
- </sections>
542
- </iso-standard>
506
+ it "reorders footnote numbers in HTML" do
507
+ FileUtils.rm_f "test.html"
508
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html"}).convert("test", <<~"INPUT", false)
509
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
510
+ <sections>
511
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><fn reference="3">
512
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">This is a footnote.</p>
513
+ </fn><clause id="N" inline-header="false" obligation="normative">
514
+ <title>Introduction to this<fn reference="2">
515
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
516
+ </fn></title>
517
+ </clause>
518
+ <clause id="O" inline-header="false" obligation="normative">
519
+ <title>Clause 4.2</title>
520
+ <p>A<fn reference="1">
521
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
522
+ </fn></p>
523
+ </clause></clause>
524
+ </sections>
525
+ </iso-standard>
543
526
  INPUT
544
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main xmlns:epub="epub" class="main-section">')
545
- .sub(%r{</main>.*$}m, '</main>')
527
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main xmlns:epub="epub" class="main-section">').
528
+ sub(%r{</main>.*$}m, "</main>")
546
529
  expect(xmlpp(html)).to be_equivalent_to xmlpp(<<~"OUTPUT")
547
- <main xmlns:epub="epub" class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
548
- <p class="zzSTDTitle1"></p>
549
- <div id="A">
550
- <h1>1.&#xA0; Clause 4</h1>
551
- <a class='FootnoteRef' href='#fn:3' id='fnref:1'>
552
- <sup>1</sup>
553
- </a>
554
- <div id="N">
555
- <h2>1.1.&#160; Introduction to this<a class='FootnoteRef' href='#fn:2' id='fnref:2'><sup>2</sup></a></h2>
556
- </div>
557
- <div id="O">
558
- <h2>1.2.&#160; Clause 4.2</h2>
559
- <p>A<a class='FootnoteRef' href='#fn:2'><sup>2</sup></a></p>
530
+ <main xmlns:epub="epub" class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
531
+ <p class="zzSTDTitle1"></p>
532
+ <div id="A">
533
+ <h1>Clause 4</h1>
534
+ <a class='FootnoteRef' href='#fn:3' id='fnref:1'>
535
+ <sup>1</sup>
536
+ </a>
537
+ <div id="N">
538
+ <h2>Introduction to this<a class='FootnoteRef' href='#fn:2' id='fnref:2'><sup>2</sup></a></h2>
539
+ </div>
540
+ <div id="O">
541
+ <h2>Clause 4.2</h2>
542
+ <p>A<a class='FootnoteRef' href='#fn:2'><sup>2</sup></a></p>
543
+ </div>
560
544
  </div>
561
- </div>
562
- <aside id="fn:3" class="footnote">
563
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:3'>
564
- <sup>1</sup>
565
- </a>This is a footnote.</p>
566
- <a href="#fnref:1">&#x21A9;</a></aside>
567
- <aside id="fn:2" class="footnote">
568
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:2'><sup>2</sup></a>Formerly denoted as 15 % (m/m).</p>
569
- <a href="#fnref:2">&#x21A9;</a></aside>
545
+ <aside id="fn:3" class="footnote">
546
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:3'>
547
+ <sup>1</sup>
548
+ </a>This is a footnote.</p>
549
+ <a href="#fnref:1">&#x21A9;</a></aside>
550
+ <aside id="fn:2" class="footnote">
551
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:2'><sup>2</sup></a>Formerly denoted as 15 % (m/m).</p>
552
+ <a href="#fnref:2">&#x21A9;</a></aside>
570
553
  </main>
571
554
  OUTPUT
572
555
  end
573
556
 
574
- it 'moves images in HTML' do
575
- FileUtils.rm_f 'test.html'
576
- FileUtils.rm_rf 'test_htmlimages'
577
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
578
- <iso-standard xmlns="http://riboseinc.com/isoxml">
579
- <preface><foreword>
580
- <figure id="_">
581
- <name>Split-it-right sample divider</name>
582
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
583
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
584
- <image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
585
- <image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
586
- <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
587
- </figure>
588
- </foreword></preface>
589
- </iso-standard>
557
+ it "moves images in HTML" do
558
+ FileUtils.rm_f "test.html"
559
+ FileUtils.rm_rf "test_htmlimages"
560
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
561
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
562
+ <preface><foreword>
563
+ <figure id="_">
564
+ <name>Split-it-right sample divider</name>
565
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
566
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
567
+ <image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
568
+ <image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
569
+ <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
570
+ </figure>
571
+ </foreword></preface>
572
+ </iso-standard>
590
573
  INPUT
591
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
592
- .sub(%r{</main>.*$}m, '</main>')
574
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
575
+ sub(%r{</main>.*$}m, "</main>")
593
576
  expect(`ls test_htmlimages`).to match(/\.png$/)
594
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
595
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
596
- <br />
597
- <div>
598
- <h1 class="ForewordTitle">Foreword</h1>
599
- <div id="_" class="figure">
600
- <img src="test_htmlimages/_.png" height="776" width="922" />
601
- <img src="test_htmlimages/_.png" height="776" width="922" />
602
- <img src="test_htmlimages/_.png" height="800" width="53" />
603
- <img src="test_htmlimages/_.png" height="83" width="99" />
604
- <img src="" height="800" width="800" />
605
- <p class="FigureTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; Split-it-right sample divider</p></div>
606
- </div>
607
- <p class="zzSTDTitle1"></p>
608
- </main>
577
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
578
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
579
+ <br />
580
+ <div>
581
+ <h1 class="ForewordTitle">Foreword</h1>
582
+ <div id="_" class="figure">
583
+ <img src="test_htmlimages/_.png" height="776" width="922" />
584
+ <img src="test_htmlimages/_.png" height="776" width="922" />
585
+ <img src="test_htmlimages/_.png" height="800" width="53" />
586
+ <img src="test_htmlimages/_.png" height="83" width="99" />
587
+ <img src="" height="800" width="800" />
588
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
589
+ </div>
590
+ <p class="zzSTDTitle1"></p>
591
+ </main>
609
592
  OUTPUT
593
+
610
594
  end
611
595
 
612
- it 'moves images in HTML with no file suffix' do
613
- FileUtils.rm_f 'test.html'
614
- FileUtils.rm_rf 'test_htmlimages'
615
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
616
- <iso-standard xmlns="http://riboseinc.com/isoxml">
617
- <preface><foreword>
618
- <figure id="_">
619
- <name>Split-it-right sample divider</name>
620
- <image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
621
- <image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
622
- <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
623
- </figure>
624
- </foreword></preface>
625
- </iso-standard>
596
+
597
+ it "moves images in HTML with no file suffix" do
598
+ FileUtils.rm_f "test.html"
599
+ FileUtils.rm_rf "test_htmlimages"
600
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
601
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
602
+ <preface><foreword>
603
+ <figure id="_">
604
+ <name>Split-it-right sample divider</name>
605
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
606
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
607
+ <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
608
+ </figure>
609
+ </foreword></preface>
610
+ </iso-standard>
626
611
  INPUT
627
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
628
- .sub(%r{</main>.*$}m, '</main>')
612
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
613
+ sub(%r{</main>.*$}m, "</main>")
629
614
  expect(`ls test_htmlimages`).to match(/\.png$/)
630
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
631
- <main class='main-section'>
632
- <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
633
- <br/>
634
- <div>
635
- <h1 class='ForewordTitle'>Foreword</h1>
636
- <div id='_' class='figure'>
637
- <img src='test_htmlimages/_.png' height='776' width='922'/>
638
- <img src='test_htmlimages/_.png' height='776' width='922'/>
639
- <img src='' height='800' width='800'/>
640
- <p class='FigureTitle' style='text-align:center;'>Figure 1&#xA0;&#x2014; Split-it-right sample divider</p>
641
- </div>
615
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
616
+ <main class='main-section'>
617
+ <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
618
+ <br/>
619
+ <div>
620
+ <h1 class='ForewordTitle'>Foreword</h1>
621
+ <div id='_' class='figure'>
622
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
623
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
624
+ <img src='' height='800' width='800'/>
625
+ <p class='FigureTitle' style='text-align:center;'>Split-it-right sample divider</p>
642
626
  </div>
643
- <p class='zzSTDTitle1'/>
644
- </main>
627
+ </div>
628
+ <p class='zzSTDTitle1'/>
629
+ </main>
645
630
  OUTPUT
646
631
  end
647
632
 
648
- it 'moves images in HTML, using relative file location' do
649
- FileUtils.rm_f 'spec/test.html'
650
- FileUtils.rm_rf 'spec/test_htmlimages'
651
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/test', <<~"INPUT", false)
652
- <iso-standard xmlns="http://riboseinc.com/isoxml">
653
- <preface><foreword>
654
- <figure id="_">
655
- <name>Split-it-right sample divider</name>
656
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
657
- <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
658
- <image src="assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
659
- <image src="assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
660
- </figure>
661
- </foreword></preface>
662
- </iso-standard>
633
+ it "moves images in HTML, using relative file location" do
634
+ FileUtils.rm_f "spec/test.html"
635
+ FileUtils.rm_rf "spec/test_htmlimages"
636
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/test", <<~"INPUT", false)
637
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
638
+ <preface><foreword>
639
+ <figure id="_">
640
+ <name>Split-it-right sample divider</name>
641
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
642
+ <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
643
+ <image src="assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
644
+ <image src="assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
645
+ </figure>
646
+ </foreword></preface>
647
+ </iso-standard>
663
648
  INPUT
664
- html = File.read('spec/test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
665
- .sub(%r{</main>.*$}m, '</main>')
649
+ html = File.read("spec/test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
650
+ sub(%r{</main>.*$}m, "</main>")
666
651
  expect(`ls test_htmlimages`).to match(/\.png$/)
667
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
668
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
669
- <br />
670
- <div>
671
- <h1 class="ForewordTitle">Foreword</h1>
672
- <div id="_" class="figure">
673
- <img src="test_htmlimages/_.png" height="776" width="922" />
674
- <img src="test_htmlimages/_.png" height="776" width="922" />
675
- <img src="test_htmlimages/_.png" height="800" width="53" />
676
- <img src="test_htmlimages/_.png" height="83" width="99" />
677
- <p class="FigureTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; Split-it-right sample divider</p></div>
678
- </div>
679
- <p class="zzSTDTitle1"></p>
680
- </main>
652
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
653
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
654
+ <br />
655
+ <div>
656
+ <h1 class="ForewordTitle">Foreword</h1>
657
+ <div id="_" class="figure">
658
+ <img src="test_htmlimages/_.png" height="776" width="922" />
659
+ <img src="test_htmlimages/_.png" height="776" width="922" />
660
+ <img src="test_htmlimages/_.png" height="800" width="53" />
661
+ <img src="test_htmlimages/_.png" height="83" width="99" />
662
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
663
+ </div>
664
+ <p class="zzSTDTitle1"></p>
665
+ </main>
681
666
  OUTPUT
682
667
  end
683
668
 
684
- it 'encodes images in HTML as data URIs' do
685
- FileUtils.rm_f 'test.html'
686
- FileUtils.rm_rf 'test_htmlimages'
687
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', datauriimage: true).convert('test', <<~"INPUT", false)
688
- <iso-standard xmlns="http://riboseinc.com/isoxml">
689
- <preface><foreword>
690
- <figure id="_">
691
- <name>Split-it-right sample divider</name>
692
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
693
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
694
- </figure>
695
- </foreword></preface>
696
- </iso-standard>
669
+
670
+ it "encodes images in HTML as data URIs" do
671
+ FileUtils.rm_f "test.html"
672
+ FileUtils.rm_rf "test_htmlimages"
673
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", datauriimage: true}).convert("test", <<~"INPUT", false)
674
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
675
+ <preface><foreword>
676
+ <figure id="_">
677
+ <name>Split-it-right sample divider</name>
678
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
679
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
680
+ </figure>
681
+ </foreword></preface>
682
+ </iso-standard>
697
683
  INPUT
698
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
699
- .sub(%r{</main>.*$}m, '</main>')
684
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
685
+ sub(%r{</main>.*$}m, "</main>")
700
686
  expect(xmlpp(html.gsub(%r{src="data:image/png;base64,[^"]+"}, %{src="data:image/png;base64,_"}))).to be_equivalent_to xmlpp(<<~"OUTPUT")
701
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
702
- <br />
703
- <div>
704
- <h1 class="ForewordTitle">Foreword</h1>
705
- <div id="_" class="figure">
706
- <img src="data:image/png;base64,_" height="776" width="922" />
707
- <img src="data:image/png;base64,_" height="776" width="922" />
708
- <p class="FigureTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; Split-it-right sample divider</p></div>
709
- </div>
710
- <p class="zzSTDTitle1"></p>
711
- </main>
687
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
688
+ <br />
689
+ <div>
690
+ <h1 class="ForewordTitle">Foreword</h1>
691
+ <div id="_" class="figure">
692
+ <img src="data:image/png;base64,_" height="776" width="922" />
693
+ <img src="data:image/png;base64,_" height="776" width="922" />
694
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
695
+ </div>
696
+ <p class="zzSTDTitle1"></p>
697
+ </main>
712
698
  OUTPUT
699
+
713
700
  end
714
701
 
715
- it 'encodes images in HTML as data URIs, using relative file location' do
716
- FileUtils.rm_f 'spec/test.html'
717
- FileUtils.rm_rf 'spec/test_htmlimages'
718
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', datauriimage: true).convert('spec/test', <<~"INPUT", false)
719
- <iso-standard xmlns="http://riboseinc.com/isoxml">
720
- <preface><foreword>
721
- <figure id="_">
722
- <name>Split-it-right sample divider</name>
723
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
724
- <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
725
- </figure>
726
- </foreword></preface>
727
- </iso-standard>
702
+ it "encodes images in HTML as data URIs, using relative file location" do
703
+ FileUtils.rm_f "spec/test.html"
704
+ FileUtils.rm_rf "spec/test_htmlimages"
705
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", datauriimage: true}).convert("spec/test", <<~"INPUT", false)
706
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
707
+ <preface><foreword>
708
+ <figure id="_">
709
+ <name>Split-it-right sample divider</name>
710
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
711
+ <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
712
+ </figure>
713
+ </foreword></preface>
714
+ </iso-standard>
728
715
  INPUT
729
- html = File.read('spec/test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
730
- .sub(%r{</main>.*$}m, '</main>')
716
+ html = File.read("spec/test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
717
+ sub(%r{</main>.*$}m, "</main>")
731
718
  expect(xmlpp(html.gsub(%r{src="data:image/png;base64,[^"]+"}, %{src="data:image/png;base64,_"}))).to be_equivalent_to xmlpp(<<~"OUTPUT")
732
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
733
- <br />
734
- <div>
735
- <h1 class="ForewordTitle">Foreword</h1>
736
- <div id="_" class="figure">
737
- <img src="data:image/png;base64,_" height="776" width="922" />
738
- <img src="data:image/png;base64,_" height="776" width="922" />
739
- <p class="FigureTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; Split-it-right sample divider</p></div>
740
- </div>
741
- <p class="zzSTDTitle1"></p>
742
- </main>
719
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
720
+ <br />
721
+ <div>
722
+ <h1 class="ForewordTitle">Foreword</h1>
723
+ <div id="_" class="figure">
724
+ <img src="data:image/png;base64,_" height="776" width="922" />
725
+ <img src="data:image/png;base64,_" height="776" width="922" />
726
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
727
+ </div>
728
+ <p class="zzSTDTitle1"></p>
729
+ </main>
743
730
  OUTPUT
744
- end
745
-
746
- it 'processes IsoXML terms for HTML' do
747
- FileUtils.rm_f 'test.html'
748
- FileUtils.rm_f 'test.doc'
749
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
750
- <iso-standard xmlns="http://riboseinc.com/isoxml">
751
- <sections>
752
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
753
731
 
754
- <term id="paddy1"><preferred>paddy</preferred>
755
- <domain>rice</domain>
756
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
757
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
758
- <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
759
- <ul>
760
- <li>A</li>
761
- </ul>
762
- </termexample>
763
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
764
- <ul>
765
- <li>A</li>
766
- </ul>
767
- </termexample>
732
+ end
768
733
 
769
- <termsource status="modified">
770
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
771
- <modification>
772
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
773
- </modification>
774
- </termsource></term>
775
734
 
776
- <term id="paddy"><preferred>paddy</preferred><admitted>paddy rice</admitted>
777
- <admitted>rough rice</admitted>
778
- <deprecates>cargo rice</deprecates>
779
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
780
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f893">
781
- <ul>
782
- <li>A</li>
783
- </ul>
784
- </termexample>
785
- <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74e">
786
- <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
787
- </termnote>
788
- <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74f">
789
- <ul><li>A</li></ul>
790
- <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
791
- </termnote>
792
- <termsource status="identical">
793
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
794
- </termsource></term>
795
- </terms>
796
- </sections>
797
- </iso-standard>
735
+ it "processes IsoXML terms for HTML" do
736
+ FileUtils.rm_f "test.html"
737
+ FileUtils.rm_f "test.doc"
738
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
739
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
740
+ <sections>
741
+ <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
742
+ <term id="paddy1"><name>1.1.</name><preferred>paddy</preferred>
743
+ <domain>rice</domain>
744
+ <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
745
+ <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
746
+ <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
747
+ <ul>
748
+ <li>A</li>
749
+ </ul>
750
+ </termexample>
751
+ <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
752
+ <ul>
753
+ <li>A</li>
754
+ </ul>
755
+ </termexample>
756
+ <termsource status="modified">
757
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
758
+ <modification>
759
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
760
+ </modification>
761
+ </termsource></term>
762
+ <term id="paddy"><name>1.2.</name><preferred>paddy</preferred><admitted>paddy rice</admitted>
763
+ <admitted>rough rice</admitted>
764
+ <deprecates>cargo rice</deprecates>
765
+ <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
766
+ <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f893">
767
+ <ul>
768
+ <li>A</li>
769
+ </ul>
770
+ </termexample>
771
+ <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74e">
772
+ <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
773
+ </termnote>
774
+ <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74f">
775
+ <ul><li>A</li></ul>
776
+ <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
777
+ </termnote>
778
+ <termsource status="identical">
779
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
780
+ </termsource></term>
781
+ </terms>
782
+ </sections>
783
+ </iso-standard>
798
784
  INPUT
799
- expect(File.exist?('test.html')).to be true
800
- html = File.read('test.html')
785
+ expect(File.exist?("test.html")).to be true
786
+ html = File.read("test.html")
801
787
  expect(html).to match(%r{<h2 class="TermNum" id="paddy1">1\.1\.</h2>})
802
788
  expect(html).to match(%r{<h2 class="TermNum" id="paddy">1\.2\.</h2>})
803
789
  end
804
790
 
805
- it 'processes empty term modifications' do
806
- FileUtils.rm_f 'test.html'
807
- FileUtils.rm_f 'test.doc'
808
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
809
- <iso-standard xmlns="http://riboseinc.com/isoxml">
810
- <sections>
811
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
812
- <term id="paddy1"><preferred>paddy</preferred>
813
- <domain>rice</domain>
814
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
815
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
816
- <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
817
- <ul>
818
- <li>A</li>
819
- </ul>
820
- </termexample>
821
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
822
- <ul>
823
- <li>A</li>
824
- </ul>
825
- </termexample>
826
- <termsource status="modified">
827
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
828
- <modification>
829
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489"/>
830
- </modification>
831
- </termsource></term>
832
- </terms>
833
- </sections>
834
- </iso-standard>
791
+ it "processes empty term modifications" do
792
+ FileUtils.rm_f "test.html"
793
+ FileUtils.rm_f "test.doc"
794
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
795
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
796
+ <sections>
797
+ <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
798
+ <term id="paddy1"><preferred>paddy</preferred>
799
+ <domain>rice</domain>
800
+ <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
801
+ <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
802
+ <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
803
+ <ul>
804
+ <li>A</li>
805
+ </ul>
806
+ </termexample>
807
+ <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
808
+ <ul>
809
+ <li>A</li>
810
+ </ul>
811
+ </termexample>
812
+ <termsource status="modified">
813
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011">ISO 7301:2011, Clause 3.1</origin>
814
+ <modification>
815
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489"/>
816
+ </modification>
817
+ </termsource></term>
818
+ </terms>
819
+ </sections>
820
+ </iso-standard>
835
821
  INPUT
836
- expect(File.exist?('test.html')).to be true
837
- html = File.read('test.html')
822
+ expect(File.exist?("test.html")).to be true
823
+ html = File.read("test.html")
838
824
  expect(html).to include '[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified]'
839
825
  end
840
826
 
841
- it 'creates continuation styles for multiparagraph list items in Word' do
842
- FileUtils.rm_f 'test.doc'
843
- FileUtils.rm_f 'test.html'
844
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
845
- <iso-standard xmlns="http://riboseinc.com/isoxml">
846
- <preface><foreword>
847
- <ul>
848
- <li><p>A</p>
849
- <p>B</p></li>
850
- <li><ol><li><p>C</p>
851
- <p>D</p>
852
- <sourcecode>E</sourcecode></li>
853
- </ol></li>
854
- </ul>
855
- <ol>
856
- <li><p>A1</p>
857
- <p>B1</p></li>
858
- <li><ul><li><p>C1</p>
859
- <formula id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62">
860
- <stem type="AsciiMath">D1</stem>
861
- </formula>
862
- </ul></li>
863
- </ol>
864
- </foreword></preface>
865
- </iso-standard>
827
+
828
+ it "creates continuation styles for multiparagraph list items in Word" do
829
+ FileUtils.rm_f "test.doc"
830
+ FileUtils.rm_f "test.html"
831
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
832
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
833
+ <preface><foreword>
834
+ <ul>
835
+ <li><p>A</p>
836
+ <p>B</p></li>
837
+ <li><ol><li><p>C</p>
838
+ <p>D</p>
839
+ <sourcecode>E</sourcecode></li>
840
+ </ol></li>
841
+ </ul>
842
+ <ol>
843
+ <li><p>A1</p>
844
+ <p>B1</p></li>
845
+ <li><ul><li><p>C1</p>
846
+ <formula id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62">
847
+ <stem type="AsciiMath">D1</stem>
848
+ </formula>
849
+ </ul></li>
850
+ </ol>
851
+ </foreword></preface>
852
+ </iso-standard>
866
853
  INPUT
867
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
868
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
854
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
855
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
869
856
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
870
- <div class='WordSection2' xmlns:m='m'>
871
- <p class='MsoNormal'>
872
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
857
+ <div class='WordSection2' xmlns:m='m'>
858
+ <p class='MsoNormal'>
859
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
860
+ </p>
861
+ <div>
862
+ <h1 class='ForewordTitle'>Foreword</h1>
863
+ <p class='MsoListParagraphCxSpFirst'>
864
+ A
865
+ <div class='ListContLevel1'>
866
+ <p class='MsoNormal'>B</p>
867
+ </div>
873
868
  </p>
874
- <div>
875
- <h1 class='ForewordTitle'>Foreword</h1>
869
+ <p class='MsoListParagraphCxSpLast'>
876
870
  <p class='MsoListParagraphCxSpFirst'>
877
- A
878
- <div class='ListContLevel1'>
879
- <p class='MsoNormal'>B</p>
871
+ C
872
+ <div class='ListContLevel2'>
873
+ <p class='MsoNormal'>D</p>
880
874
  </div>
881
- </p>
882
- <p class='MsoListParagraphCxSpLast'>
883
- <p class='MsoListParagraphCxSpFirst'>
884
- C
885
- <div class='ListContLevel2'>
886
- <p class='MsoNormal'>D</p>
887
- </div>
888
- <div class='ListContLevel2'>
889
- <p class='Sourcecode'>E</p>
890
- </div>
891
- </p>
892
- </p>
893
- <p class='MsoListParagraphCxSpFirst'>
894
- A1
895
- <div class='ListContLevel1'>
896
- <p class='MsoNormal'>B1</p>
875
+ <div class='ListContLevel2'>
876
+ <p class='Sourcecode'>E</p>
897
877
  </div>
898
878
  </p>
899
- <p class='MsoListParagraphCxSpLast'>
900
- C1
901
- <div class='ListContLevel2'>
902
- <div>
903
- <a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
904
- <div class='formula'>
905
- <p class='MsoNormal'>
906
- <span class='stem'>
907
- <m:oMath>
908
- <m:r>
909
- <m:t>D1</m:t>
910
- </m:r>
911
- </m:oMath>
912
- </span>
913
- <span style='mso-tab-count:1'>&#xA0; </span>
914
- (1)
915
- </p>
916
- </div>
879
+ </p>
880
+ <p class='MsoListParagraphCxSpFirst'>
881
+ A1
882
+ <div class='ListContLevel1'>
883
+ <p class='MsoNormal'>B1</p>
884
+ </div>
885
+ </p>
886
+ <p class='MsoListParagraphCxSpLast'>
887
+ C1
888
+ <div class='ListContLevel2'>
889
+ <div>
890
+ <a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
891
+ <div class='formula'>
892
+ <p class='MsoNormal'>
893
+ <span class='stem'>
894
+ <m:oMath>
895
+ <m:r>
896
+ <m:t>D1</m:t>
897
+ </m:r>
898
+ </m:oMath>
899
+ </span>
900
+ </p>
917
901
  </div>
918
902
  </div>
919
- </p>
920
- </div>
921
- <p class='MsoNormal'>&#xA0;</p>
903
+ </div>
904
+ </p>
922
905
  </div>
906
+ <p class='MsoNormal'>&#xA0;</p>
907
+ </div>
923
908
  OUTPUT
924
909
  end
925
910
 
926
- it 'does not lose HTML escapes in postprocessing' do
927
- FileUtils.rm_f 'test.doc'
928
- FileUtils.rm_f 'test.html'
929
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
930
- <iso-standard xmlns="http://riboseinc.com/isoxml">
931
- <preface><foreword>
932
- <sourcecode id="samplecode">
933
- <name>XML code</name>
934
- &lt;xml&gt; &amp;
935
- </sourcecode>
936
- </foreword></preface>
937
- </iso-standard>
911
+ it "does not lose HTML escapes in postprocessing" do
912
+ FileUtils.rm_f "test.doc"
913
+ FileUtils.rm_f "test.html"
914
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
915
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
916
+ <preface><foreword>
917
+ <sourcecode id="samplecode">
918
+ <name>XML code</name>
919
+ &lt;xml&gt; &amp;
920
+ </sourcecode>
921
+ </foreword></preface>
922
+ </iso-standard>
938
923
  INPUT
939
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
940
- .sub(%r{</main>.*$}m, '</main>')
924
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
925
+ sub(%r{</main>.*$}m, "</main>")
941
926
  expect(xmlpp(html)).to be_equivalent_to xmlpp(<<~"OUTPUT")
942
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
943
- <br />
944
- <div>
945
- <h1 class="ForewordTitle">Foreword</h1>
946
- <pre id="samplecode" class="prettyprint "><br />&#xA0;&#xA0;&#xA0; <br />&#xA0; &lt;xml&gt; &amp;<br />
947
- </pre>
948
- <p class="SourceTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; XML code</p>
949
- </div>
950
- <p class="zzSTDTitle1"></p>
951
- </main>
927
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
928
+ <br />
929
+ <div>
930
+ <h1 class="ForewordTitle">Foreword</h1>
931
+ <pre id="samplecode" class="prettyprint "><br />&#xA0;&#xA0;&#xA0; <br />&#xA0; &lt;xml&gt; &amp;<br />
932
+ </pre>
933
+ <p class="SourceTitle" style="text-align:center;">XML code</p>
934
+ </div>
935
+ <p class="zzSTDTitle1"></p>
936
+ </main>
952
937
  OUTPUT
953
938
  end
954
939
 
955
- it 'does not lose HTML escapes in postprocessing (Word)' do
956
- FileUtils.rm_f 'test.doc'
957
- FileUtils.rm_f 'test.html'
958
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
959
- <iso-standard xmlns="http://riboseinc.com/isoxml">
960
- <preface><foreword>
961
- <sourcecode id="samplecode">
962
- <name>XML code</name>
963
- &lt;xml&gt; &amp;
964
- </sourcecode>
965
- </foreword></preface>
966
- </iso-standard>
940
+
941
+ it "does not lose HTML escapes in postprocessing (Word)" do
942
+ FileUtils.rm_f "test.doc"
943
+ FileUtils.rm_f "test.html"
944
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
945
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
946
+ <preface><foreword>
947
+ <sourcecode id="samplecode">
948
+ <name>XML code</name>
949
+ &lt;xml&gt; &amp;
950
+ </sourcecode>
951
+ </foreword></preface>
952
+ </iso-standard>
967
953
  INPUT
968
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
969
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
954
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
955
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
970
956
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
971
- <div class="WordSection2">
972
- <p class="MsoNormal">
973
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
974
- </p>
975
- <div>
976
- <h1 class="ForewordTitle">Foreword</h1>
977
- <p class="Sourcecode" style="page-break-after:avoid;"><a name="samplecode" id="samplecode"></a><br/>&#xA0;&#xA0;&#xA0; <br/>&#xA0; &lt;xml&gt; &amp;<br/></p><p class="SourceTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; XML code</p>
978
- </div>
979
- <p class="MsoNormal">&#xA0;</p>
957
+ <div class="WordSection2">
958
+ <p class="MsoNormal">
959
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
960
+ </p>
961
+ <div>
962
+ <h1 class="ForewordTitle">Foreword</h1>
963
+ <p class="Sourcecode" style="page-break-after:avoid;"><a name="samplecode" id="samplecode"></a><br/>&#xA0;&#xA0;&#xA0; <br/>&#xA0; &lt;xml&gt; &amp;<br/></p><p class="SourceTitle" style="text-align:center;">XML code</p>
980
964
  </div>
981
-
965
+ <p class="MsoNormal">&#xA0;</p>
966
+ </div>
982
967
  OUTPUT
983
968
  end
984
969
 
985
- it 'propagates example style to paragraphs in postprocessing (Word)' do
986
- FileUtils.rm_f 'test.doc'
987
- FileUtils.rm_f 'test.html'
988
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
989
- <iso-standard xmlns="http://riboseinc.com/isoxml">
990
- <preface><foreword>
991
- <example id="samplecode">
992
- <p>ABC</p>
993
- </example>
994
- </foreword></preface>
995
- </iso-standard>
970
+ it "propagates example style to paragraphs in postprocessing (Word)" do
971
+ FileUtils.rm_f "test.doc"
972
+ FileUtils.rm_f "test.html"
973
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
974
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
975
+ <preface><foreword>
976
+ <example id="samplecode">
977
+ <p>ABC</p>
978
+ </example>
979
+ </foreword></preface>
980
+ </iso-standard>
996
981
  INPUT
997
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
998
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
982
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
983
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
999
984
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
1000
- <div class="WordSection2">
1001
- <p class="MsoNormal">
1002
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
1003
- </p>
1004
- <div>
1005
- <h1 class="ForewordTitle">Foreword</h1>
1006
- <div class="example"><a name="samplecode" id="samplecode"></a><p class="example-title">EXAMPLE</p>
1007
- <p class="example">ABC</p>
985
+ <div class="WordSection2">
986
+ <p class="MsoNormal">
987
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
988
+ </p>
989
+ <div>
990
+ <h1 class="ForewordTitle">Foreword</h1>
991
+ <div class="example"><a name="samplecode" id="samplecode"></a>
992
+ <p class="example">ABC</p>
993
+ </div>
1008
994
  </div>
1009
- </div>
1010
- <p class="MsoNormal">&#xA0;</p>
1011
- </div>
995
+ <p class="MsoNormal">&#xA0;</p>
996
+ </div>
1012
997
  OUTPUT
1013
998
  end
1014
999
 
1015
- it 'deals with image captions (Word)' do
1016
- FileUtils.rm_f 'test.doc'
1017
- FileUtils.rm_f 'test.html'
1018
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
1019
- <iso-standard xmlns="http://riboseinc.com/isoxml">
1020
- <preface><foreword>
1021
- <figure id="fig1">
1022
- <name>Typical arrangement of the far-field scan set-up</name>
1023
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
1024
- </figure>
1025
- </foreword></preface>
1026
- </iso-standard>
1000
+ it "deals with image captions (Word)" do
1001
+ FileUtils.rm_f "test.doc"
1002
+ FileUtils.rm_f "test.html"
1003
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
1004
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
1005
+ <preface><foreword>
1006
+ <figure id="fig1">
1007
+ <name>Typical arrangement of the far-field scan set-up</name>
1008
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
1009
+ </figure>
1010
+ </foreword></preface>
1011
+ </iso-standard>
1027
1012
  INPUT
1028
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
1029
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
1030
- .sub(/src="[^"]+"/, 'src="_"')
1013
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
1014
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
1015
+ sub(/src="[^"]+"/, 'src="_"')
1031
1016
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
1032
- <div class="WordSection2">
1033
- <p class="MsoNormal">
1034
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
1035
- </p>
1036
- <div>
1037
- <h1 class="ForewordTitle">Foreword</h1>
1038
- <div class="figure"><a name="fig1" id="fig1"></a>
1039
- <p style="page-break-after:avoid;" class="figure"><img src="_" width="400" height="337"/></p>
1040
- <p class="FigureTitle" style="text-align:center;">Figure 1&#xA0;&#x2014; Typical arrangement of the far-field scan set-up</p></div>
1041
- </div>
1042
- <p class="MsoNormal">&#xA0;</p>
1017
+ <div class="WordSection2">
1018
+ <p class="MsoNormal">
1019
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
1020
+ </p>
1021
+ <div>
1022
+ <h1 class="ForewordTitle">Foreword</h1>
1023
+ <div class="figure"><a name="fig1" id="fig1"></a>
1024
+ <p style="page-break-after:avoid;" class="figure"><img src="_" width="400" height="337"/></p>
1025
+ <p class="FigureTitle" style="text-align:center;">Typical arrangement of the far-field scan set-up</p></div>
1043
1026
  </div>
1027
+ <p class="MsoNormal">&#xA0;</p>
1028
+ </div>
1044
1029
  OUTPUT
1030
+
1045
1031
  end
1046
1032
 
1047
- it 'deals with empty table titles (Word)' do
1048
- FileUtils.rm_f 'test.doc'
1049
- FileUtils.rm_f 'test.html'
1050
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
1051
- <iso-standard xmlns="http://riboseinc.com/isoxml">
1052
- <preface><foreword>
1053
- <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
1054
- <td rowspan="2">
1055
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength <stem type="MathML"><math xmlns="http://www.w3.org/1998/Math/MathML"><mrow><mo>(</mo><mi>μ</mi><mi>m</mi><mo>)</mo></mrow></math></stem></p>
1056
- </td>
1057
- <th colspan="3" align="left">Predictive wavelengths</th>
1058
- </tr>
1059
- </thead>
1060
- </table>
1061
- </preface>
1062
- </iso-standard>
1033
+ it "deals with empty table titles (Word)" do
1034
+ FileUtils.rm_f "test.doc"
1035
+ FileUtils.rm_f "test.html"
1036
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
1037
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
1038
+ <preface><foreword>
1039
+ <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
1040
+ <td rowspan="2">
1041
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength <stem type="MathML"><math xmlns="http://www.w3.org/1998/Math/MathML"><mrow><mo>(</mo><mi>μ</mi><mi>m</mi><mo>)</mo></mrow></math></stem></p>
1042
+ </td>
1043
+ <th colspan="3" align="left">Predictive wavelengths</th>
1044
+ </tr>
1045
+ </thead>
1046
+ </table>
1047
+ </preface>
1048
+ </iso-standard>
1063
1049
  INPUT
1064
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
1065
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
1066
- .sub(/src="[^"]+"/, 'src="_"')
1050
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
1051
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
1052
+ sub(/src="[^"]+"/, 'src="_"')
1067
1053
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
1068
- <div class="WordSection2" xmlns:m="m">
1069
- <p class="MsoNormal">
1070
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
1071
- </p>
1072
- <div>
1073
- <h1 class="ForewordTitle">Foreword</h1>
1074
- <div align="center" class="table_container">
1075
- <table class="MsoISOTable" style="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>
1076
- <thead>
1077
- <tr>
1078
- <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;">
1079
- <p class="MsoNormal"><a name="_c47d9b39-adb2-431d-9320-78cb148fdb56" id="_c47d9b39-adb2-431d-9320-78cb148fdb56"></a>Output wavelength <span class="stem"><m:oMath>
1080
- <m:r><m:t>(&#x3BC;m)</m:t></m:r>
1081
- </m:oMath>
1082
- </span></p>
1083
- </td>
1084
- <th colspan="3" align="left" style="font-weight:bold;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;">Predictive wavelengths</th>
1085
- </tr>
1086
- </thead>
1087
- </table>
1088
- </div>
1089
- </div>
1090
- <p class="MsoNormal">&#xA0;</p>
1091
- </div>
1054
+ <div class="WordSection2" xmlns:m="m">
1055
+ <p class="MsoNormal">
1056
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
1057
+ </p>
1058
+ <div>
1059
+ <h1 class="ForewordTitle">Foreword</h1>
1060
+ <div align="center" class="table_container">
1061
+ <table class="MsoISOTable" style="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>
1062
+ <thead>
1063
+ <tr>
1064
+ <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;">
1065
+ <p class="MsoNormal"><a name="_c47d9b39-adb2-431d-9320-78cb148fdb56" id="_c47d9b39-adb2-431d-9320-78cb148fdb56"></a>Output wavelength <span class="stem"><m:oMath>
1066
+ <m:r><m:t>(&#x3BC;m)</m:t></m:r>
1067
+ </m:oMath>
1068
+ </span></p>
1069
+ </td>
1070
+ <th colspan="3" align="left" style="font-weight:bold;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;">Predictive wavelengths</th>
1071
+ </tr>
1072
+ </thead>
1073
+ </table>
1074
+ </div>
1075
+ </div>
1076
+ <p class="MsoNormal">&#xA0;</p>
1077
+ </div>
1092
1078
  OUTPUT
1093
1079
  end
1094
1080
 
1095
- it 'propagates alignment of table cells (Word)' do
1096
- FileUtils.rm_f 'test.doc'
1097
- FileUtils.rm_f 'test.html'
1098
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
1099
- <iso-standard xmlns="http://riboseinc.com/isoxml">
1100
- <preface><foreword>
1101
- <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
1102
- <td rowspan="2" align="left">
1103
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength</p>
1104
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb57">Output wavelength</p>
1105
- </td>
1106
- <th colspan="3" align="right"><p id="_c47d9b39-adb2-431d-9320-78cb148fdb58">Predictive wavelengths</p></th>
1107
- </tr>
1108
- </thead>
1109
- </table>
1110
- </preface>
1111
- </iso-standard>
1081
+ it "propagates alignment of table cells (Word)" do
1082
+ FileUtils.rm_f "test.doc"
1083
+ FileUtils.rm_f "test.html"
1084
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
1085
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
1086
+ <preface><foreword>
1087
+ <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
1088
+ <td rowspan="2" align="left">
1089
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength</p>
1090
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb57">Output wavelength</p>
1091
+ </td>
1092
+ <th colspan="3" align="right"><p id="_c47d9b39-adb2-431d-9320-78cb148fdb58">Predictive wavelengths</p></th>
1093
+ </tr>
1094
+ </thead>
1095
+ </table>
1096
+ </preface>
1097
+ </iso-standard>
1112
1098
  INPUT
1113
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
1114
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
1115
- .sub(/src="[^"]+"/, 'src="_"')
1099
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
1100
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
1101
+ sub(/src="[^"]+"/, 'src="_"')
1116
1102
  expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
1117
- <div class='WordSection2' xmlns:m='m'>
1118
- <p class='MsoNormal'>
1119
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
1120
- </p>
1121
- <div>
1122
- <h1 class='ForewordTitle'>Foreword</h1>
1123
- <div align='center' class="table_container">
1124
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1125
- <a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
1126
- <thead>
1127
- <tr>
1128
- <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.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;'>
1129
- <p style='text-align: left' class='MsoNormal'>
1130
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb56' id='_c47d9b39-adb2-431d-9320-78cb148fdb56'/>
1131
- Output wavelength
1132
- </p>
1133
- <p style='text-align: left' class='MsoNormal'>
1134
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb57' id='_c47d9b39-adb2-431d-9320-78cb148fdb57'/>
1135
- Output wavelength
1136
- </p>
1137
- </td>
1138
- <th colspan='3' align='right' style='font-weight:bold;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;'>
1139
- <p style='text-align: right' class='MsoNormal'>
1140
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb58' id='_c47d9b39-adb2-431d-9320-78cb148fdb58'/>
1141
- Predictive wavelengths
1142
- </p>
1143
- </th>
1144
- </tr>
1145
- </thead>
1146
- </table>
1147
- </div>
1103
+ <div class='WordSection2' xmlns:m='m'>
1104
+ <p class='MsoNormal'>
1105
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
1106
+ </p>
1107
+ <div>
1108
+ <h1 class='ForewordTitle'>Foreword</h1>
1109
+ <div align='center' class="table_container">
1110
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1111
+ <a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
1112
+ <thead>
1113
+ <tr>
1114
+ <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.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;'>
1115
+ <p style='text-align: left' class='MsoNormal'>
1116
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb56' id='_c47d9b39-adb2-431d-9320-78cb148fdb56'/>
1117
+ Output wavelength
1118
+ </p>
1119
+ <p style='text-align: left' class='MsoNormal'>
1120
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb57' id='_c47d9b39-adb2-431d-9320-78cb148fdb57'/>
1121
+ Output wavelength
1122
+ </p>
1123
+ </td>
1124
+ <th colspan='3' align='right' style='font-weight:bold;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;'>
1125
+ <p style='text-align: right' class='MsoNormal'>
1126
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb58' id='_c47d9b39-adb2-431d-9320-78cb148fdb58'/>
1127
+ Predictive wavelengths
1128
+ </p>
1129
+ </th>
1130
+ </tr>
1131
+ </thead>
1132
+ </table>
1148
1133
  </div>
1149
- <p class='MsoNormal'>&#xA0;</p>
1150
1134
  </div>
1135
+ <p class='MsoNormal'>&#xA0;</p>
1136
+ </div>
1151
1137
  OUTPUT
1152
- end
1153
-
1154
- it 'cleans up boilerplate' do
1155
- expect(xmlpp(IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').html_preface(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
1156
- <html>
1157
- <head/>
1158
- <body>
1159
- <div class="main-section">
1160
- <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
1161
- <div id="boilerplate-license"> <h1>License</h1> </div>
1162
- <div id="boilerplate-legal"> <h1>Legal</h1> </div>
1163
- <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
1138
+ end
1139
+
1140
+ it "cleans up boilerplate" do
1141
+ expect(xmlpp(IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).html_preface(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
1142
+ <html>
1143
+ <head/>
1144
+ <body>
1145
+ <div class="main-section">
1146
+ <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
1147
+ <div id="boilerplate-license"> <h1>License</h1> </div>
1148
+ <div id="boilerplate-legal"> <h1>Legal</h1> </div>
1149
+ <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
1150
+ <hr/>
1151
+ <div id="boilerplate-feedback-destination"/>
1152
+ <div id="boilerplate-legal-destination"/>
1153
+ <div id="boilerplate-license-destination"/>
1154
+ <div id="boilerplate-copyright-destination"/>
1155
+ </div>
1156
+ </body>
1157
+ </html>
1158
+ INPUT
1159
+ <main class='main-section'>
1160
+ <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
1164
1161
  <hr/>
1165
- <div id="boilerplate-feedback-destination"/>
1166
- <div id="boilerplate-legal-destination"/>
1167
- <div id="boilerplate-license-destination"/>
1168
- <div id="boilerplate-copyright-destination"/>
1162
+ <div id='boilerplate-feedback'>
1163
+ <h1 class='IntroTitle'>Feedback</h1>
1169
1164
  </div>
1170
- </body>
1171
- </html>
1172
- INPUT
1173
- <main class='main-section'>
1174
- <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
1175
- <hr/>
1176
- <div id='boilerplate-feedback'>
1177
- <h1 class='IntroTitle'>Feedback</h1>
1178
- </div>
1179
- <div id='boilerplate-legal'>
1180
- <h1 class='IntroTitle'>Legal</h1>
1181
- </div>
1182
- <div id='boilerplate-license'>
1183
- <h1 class='IntroTitle'>License</h1>
1184
- </div>
1185
- <div id='boilerplate-copyright'>
1186
- <h1 class='IntroTitle'>Copyright</h1>
1187
- </div>
1188
- </main>
1165
+ <div id='boilerplate-legal'>
1166
+ <h1 class='IntroTitle'>Legal</h1>
1167
+ </div>
1168
+ <div id='boilerplate-license'>
1169
+ <h1 class='IntroTitle'>License</h1>
1170
+ </div>
1171
+ <div id='boilerplate-copyright'>
1172
+ <h1 class='IntroTitle'>Copyright</h1>
1173
+ </div>
1174
+ </main>
1189
1175
  OUTPUT
1190
1176
  end
1191
1177
 
1192
- it 'cleans up boilerplate (Word)' do
1193
- expect(xmlpp(IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
1194
- <html>
1195
- <head/>
1196
- <body>
1197
- <div class="main-section">
1198
- <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
1199
- <div id="boilerplate-license"> <h1>License</h1> </div>
1200
- <div id="boilerplate-legal"> <h1>Legal</h1> </div>
1201
- <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
1178
+ it "cleans up boilerplate (Word)" do
1179
+ expect(xmlpp(IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
1180
+ <html>
1181
+ <head/>
1182
+ <body>
1183
+ <div class="main-section">
1184
+ <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
1185
+ <div id="boilerplate-license"> <h1>License</h1> </div>
1186
+ <div id="boilerplate-legal"> <h1>Legal</h1> </div>
1187
+ <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
1188
+ <hr/>
1189
+ <div id="boilerplate-feedback-destination"/>
1190
+ <div id="boilerplate-legal-destination"/>
1191
+ <div id="boilerplate-license-destination"/>
1192
+ <div id="boilerplate-copyright-destination"/>
1193
+ </div>
1194
+ </body>
1195
+ </html>
1196
+ INPUT
1197
+ <html>
1198
+ <head/>
1199
+ <body>
1200
+ <div class='main-section'>
1202
1201
  <hr/>
1203
- <div id="boilerplate-feedback-destination"/>
1204
- <div id="boilerplate-legal-destination"/>
1205
- <div id="boilerplate-license-destination"/>
1206
- <div id="boilerplate-copyright-destination"/>
1202
+ <div id='boilerplate-feedback'>
1203
+ <p class='TitlePageSubhead'>Feedback</p>
1207
1204
  </div>
1208
- </body>
1209
- </html>
1210
- INPUT
1211
- <html>
1212
- <head/>
1213
- <body>
1214
- <div class='main-section'>
1215
- <hr/>
1216
- <div id='boilerplate-feedback'>
1217
- <p class='TitlePageSubhead'>Feedback</p>
1218
- </div>
1219
- <div id='boilerplate-legal'>
1220
- <p class='TitlePageSubhead'>Legal</p>
1221
- </div>
1222
- <div id='boilerplate-license'>
1223
- <p class='TitlePageSubhead'>License</p>
1224
- </div>
1225
- <div id='boilerplate-copyright'>
1226
- <p class='TitlePageSubhead'>Copyright</p>
1227
- </div>
1228
- </div>
1229
- </body>
1230
- </html>
1205
+ <div id='boilerplate-legal'>
1206
+ <p class='TitlePageSubhead'>Legal</p>
1207
+ </div>
1208
+ <div id='boilerplate-license'>
1209
+ <p class='TitlePageSubhead'>License</p>
1210
+ </div>
1211
+ <div id='boilerplate-copyright'>
1212
+ <p class='TitlePageSubhead'>Copyright</p>
1213
+ </div>
1214
+ </div>
1215
+ </body>
1216
+ </html>
1231
1217
  OUTPUT
1232
1218
  end
1233
1219
 
1234
- it 'deals with landscape and portrait pagebreaks (Word)' do
1235
- FileUtils.rm_f 'test.doc'
1236
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').convert('test', <<~"INPUT", false)
1237
- <standard-document xmlns="http://riboseinc.com/isoxml">
1238
- <bibdata type="standard">
1239
- <title language="en" format="text/plain">Document title</title>
1240
- <version>
1241
- <draft>1.2</draft>
1242
- </version>
1243
- <language>en</language>
1244
- <script>Latn</script>
1245
- <status><stage>published</stage></status>
1246
- <ext>
1247
- <doctype>article</doctype>
1248
- </ext>
1249
- </bibdata>
1250
- <preface>
1251
- <introduction><title>Preface 1</title>
1252
- <p align="center">This is a <pagebreak orientation="landscape"/> paragraph</p>
1253
- <table>
1254
- <tbody>
1255
- <tr><td>A</td><td>B</td></tr>
1256
- </tbody>
1257
- </table>
1258
- <clause><title>Preface 1.1</title>
1259
- <p>On my side</p>
1260
- <pagebreak orientation="portrait"/>
1261
- <p>Upright again</p>
1262
- </clause>
1263
- <clause><title>Preface 1.3</title>
1264
- <p>And still upright</p>
1265
- </clause>
1266
- </introduction>
1267
- </preface>
1268
- <sections><clause><title>Foreword</title>
1269
- <note>
1270
- <p id="_">For further information on the Foreword, see <strong>ISO/IEC Directives, Part 2, 2016, Clause 12.</strong></p>
1271
- <pagebreak orientation="landscape"/>
1272
- <table id="_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249">
1273
- <thead>
1274
- <tr>
1275
- <th align="left">A</th>
1276
- <th align="left">B</th>
1277
- </tr>
1278
- </thead>
1279
- <tbody>
1280
- <tr>
1281
- <td align="left">C</td>
1282
- <td align="left">D</td>
1283
- </tr>
1284
- </tbody>
1285
- <note id="_8fff1596-290e-4314-b03c-7a8aab97eebe">
1286
- <p id="_32c22439-387a-48cf-a006-5ab3b934ba73">B</p>
1287
- </note></table>
1288
- <pagebreak orientation="portrait"/>
1289
- <p>And up</p>
1290
- </note>
1291
- <pagebreak orientation="portrait"/>
1292
- </clause></sections>
1293
- <annex id="_level_1" inline-header="false" obligation="normative">
1294
- <title>Annex 1</title>
1295
- </annex>
1296
- </standard-document>
1220
+ it "deals with landscape and portrait pagebreaks (Word)" do
1221
+ FileUtils.rm_f "test.doc"
1222
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).convert("test", <<~"INPUT", false)
1223
+ <standard-document xmlns="http://riboseinc.com/isoxml">
1224
+ <bibdata type="standard">
1225
+ <title language="en" format="text/plain">Document title</title>
1226
+ <version>
1227
+ <draft>1.2</draft>
1228
+ </version>
1229
+ <language>en</language>
1230
+ <script>Latn</script>
1231
+ <status><stage>published</stage></status>
1232
+ <ext>
1233
+ <doctype>article</doctype>
1234
+ </ext>
1235
+ </bibdata>
1236
+ <preface>
1237
+ <introduction><title>Preface 1</title>
1238
+ <p align="center">This is a <pagebreak orientation="landscape"/> paragraph</p>
1239
+ <table>
1240
+ <tbody>
1241
+ <tr><td>A</td><td>B</td></tr>
1242
+ </tbody>
1243
+ </table>
1244
+ <clause><title>Preface 1.1</title>
1245
+ <p>On my side</p>
1246
+ <pagebreak orientation="portrait"/>
1247
+ <p>Upright again</p>
1248
+ </clause>
1249
+ <clause><title>Preface 1.3</title>
1250
+ <p>And still upright</p>
1251
+ </clause>
1252
+ </introduction>
1253
+ </preface>
1254
+ <sections><clause><title>Foreword</title>
1255
+ <note>
1256
+ <p id="_">For further information on the Foreword, see <strong>ISO/IEC Directives, Part 2, 2016, Clause 12.</strong></p>
1257
+ <pagebreak orientation="landscape"/>
1258
+ <table id="_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249">
1259
+ <thead>
1260
+ <tr>
1261
+ <th align="left">A</th>
1262
+ <th align="left">B</th>
1263
+ </tr>
1264
+ </thead>
1265
+ <tbody>
1266
+ <tr>
1267
+ <td align="left">C</td>
1268
+ <td align="left">D</td>
1269
+ </tr>
1270
+ </tbody>
1271
+ <note id="_8fff1596-290e-4314-b03c-7a8aab97eebe">
1272
+ <p id="_32c22439-387a-48cf-a006-5ab3b934ba73">B</p>
1273
+ </note></table>
1274
+ <pagebreak orientation="portrait"/>
1275
+ <p>And up</p>
1276
+ </note>
1277
+ <pagebreak orientation="portrait"/>
1278
+ </clause></sections>
1279
+ <annex id="_level_1" inline-header="false" obligation="normative">
1280
+ <title>Annex 1</title>
1281
+ </annex>
1282
+ </standard-document>
1297
1283
  INPUT
1298
- expect(File.exist?('test.doc')).to be true
1299
- html = File.read('test.doc', encoding: 'UTF-8')
1300
- expect(html).to include 'div.WordSection2_0 {page:WordSection2P;}'
1301
- expect(html).to include 'div.WordSection2_1 {page:WordSection2L;}'
1302
- expect(html).to include 'div.WordSection3_0 {page:WordSection3P;}'
1303
- expect(html).to include 'div.WordSection3_1 {page:WordSection3P;}'
1304
- expect(html).to include 'div.WordSection3_2 {page:WordSection3L;}'
1305
-
1306
- expect(xmlpp(html.sub(/^.*<body /m, '<body ').sub(%r{</body>.*$}m, '</body>'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
1307
- <body lang='EN-US' xml:lang='EN-US' link='blue' vlink='#954F72'>
1308
- <div class='WordSection1'>
1309
- <p class='MsoNormal'>&#xA0;</p>
1310
- </div>
1311
- <p class='MsoNormal'>
1312
- <br clear='all' class='section'/>
1313
- </p>
1314
- <div class='WordSection2'>
1315
- <p class='MsoNormal'>
1316
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
1317
- </p>
1318
- <div class='Section3' id=''>
1319
- <h1 class='IntroTitle'>Introduction</h1>
1320
- <p align='center' style='text-align:center;' class='MsoNormal'>
1321
- This is a
1322
- <p class='MsoNormal'>
1323
- <br clear='all' class='section'/>
1324
- </p>
1325
- paragraph
1326
- </p>
1327
- </div>
1328
- </div>
1329
- <div class='WordSection2_1'>
1330
- <div align='center' class='table_container'>
1331
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1332
- <tbody>
1333
- <tr>
1334
- <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>
1335
- <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;'>B</td>
1336
- </tr>
1337
- </tbody>
1338
- </table>
1339
- </div>
1340
- <div>
1341
- <h1>Preface 1.1</h1>
1342
- <p class='MsoNormal'>On my side</p>
1343
- <p class='MsoNormal'>
1344
- <br clear='all' class='section'/>
1345
- </p>
1346
- </div>
1347
- </div>
1348
- <div class='WordSection2_0'>
1349
- <p class='MsoNormal'>Upright again</p>
1350
- <div>
1351
- <h1>Preface 1.3</h1>
1352
- <p class='MsoNormal'>And still upright</p>
1353
- </div>
1354
- <p class='MsoNormal'>&#xA0;</p>
1355
- </div>
1284
+ expect(File.exist?("test.doc")).to be true
1285
+ html = File.read("test.doc", encoding: "UTF-8")
1286
+ expect(html).to include "div.WordSection2_0 {page:WordSection2P;}"
1287
+ expect(html).to include "div.WordSection2_1 {page:WordSection2L;}"
1288
+ expect(html).to include "div.WordSection3_0 {page:WordSection3P;}"
1289
+ expect(html).to include "div.WordSection3_1 {page:WordSection3P;}"
1290
+ expect(html).to include "div.WordSection3_2 {page:WordSection3L;}"
1291
+
1292
+
1293
+ expect(xmlpp(html.sub(/^.*<body /m, "<body ").sub(%r{</body>.*$}m, "</body>"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
1294
+ <body lang='EN-US' xml:lang='EN-US' link='blue' vlink='#954F72'>
1295
+ <div class='WordSection1'>
1296
+ <p class='MsoNormal'>&#xA0;</p>
1297
+ </div>
1298
+ <p class='MsoNormal'>
1299
+ <br clear='all' class='section'/>
1300
+ </p>
1301
+ <div class='WordSection2'>
1302
+ <p class='MsoNormal'>
1303
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
1304
+ </p>
1305
+ <div class='Section3' id=''>
1306
+ <h1 class='IntroTitle'>Preface 1</h1>
1307
+ <p align='center' style='text-align:center;' class='MsoNormal'>
1308
+ This is a
1356
1309
  <p class='MsoNormal'>
1357
1310
  <br clear='all' class='section'/>
1358
1311
  </p>
1359
- <div class='WordSection3'>
1360
- <p class='zzSTDTitle1'>Document title</p>
1361
- <div>
1362
- <h1>Foreword</h1>
1363
- <div class='Note'>
1364
- <p class='Note'>
1365
- <span class='note_label'>NOTE 1</span>
1366
- <span style='mso-tab-count:1'>&#xA0; </span>
1367
- For further information on the Foreword, see
1368
- <b>ISO/IEC Directives, Part 2, 2016, Clause 12.</b>
1369
- </p>
1370
- <p class='Note'>
1371
- <br clear='all' class='section'/>
1372
- </p>
1373
- </div>
1374
- </div>
1375
- </div>
1376
- <div class='WordSection3_2'>
1377
- <p class='TableTitle' style='text-align:center;'>Table 1</p>
1378
- <div align='center' class='table_container'>
1379
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1380
- <a name='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249' id='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249'/>
1381
- <thead>
1382
- <tr>
1383
- <th align='left' style='font-weight:bold;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</th>
1384
- <th align='left' style='font-weight:bold;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;'>B</th>
1385
- </tr>
1386
- </thead>
1387
- <tbody>
1388
- <tr>
1389
- <td 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;'>C</td>
1390
- <td 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;'>D</td>
1391
- </tr>
1392
- </tbody>
1393
- <tfoot>
1394
- <tr>
1395
- <td colspan='2' style='border-top:0pt;mso-border-top-alt:0pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
1396
- <div class='Note'>
1397
- <a name='_8fff1596-290e-4314-b03c-7a8aab97eebe' id='_8fff1596-290e-4314-b03c-7a8aab97eebe'/>
1398
- <p class='Note'>
1399
- <span class='note_label'>NOTE</span>
1400
- <span style='mso-tab-count:1'>&#xA0; </span>
1401
- B
1402
- </p>
1403
- </div>
1404
- </td>
1405
- </tr>
1406
- </tfoot>
1407
- </table>
1408
- </div>
1409
- <p class='Note'>
1410
- <br clear='all' class='section'/>
1411
- </p>
1412
- </div>
1413
- <div class='WordSection3_1'>
1414
- <p class='Note'>And up</p>
1415
- <p class='MsoNormal'>
1312
+ paragraph
1313
+ </p>
1314
+ </div>
1315
+ </div>
1316
+ <div class='WordSection2_1'>
1317
+ <div align='center' class='table_container'>
1318
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1319
+ <tbody>
1320
+ <tr>
1321
+ <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>
1322
+ <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;'>B</td>
1323
+ </tr>
1324
+ </tbody>
1325
+ </table>
1326
+ </div>
1327
+ <div>
1328
+ <h2>Preface 1.1</h2>
1329
+ <p class='MsoNormal'>On my side</p>
1330
+ <p class='MsoNormal'>
1331
+ <br clear='all' class='section'/>
1332
+ </p>
1333
+ </div>
1334
+ </div>
1335
+ <div class='WordSection2_0'>
1336
+ <p class='MsoNormal'>Upright again</p>
1337
+ <div>
1338
+ <h2>Preface 1.3</h2>
1339
+ <p class='MsoNormal'>And still upright</p>
1340
+ </div>
1341
+ <p class='MsoNormal'>&#xA0;</p>
1342
+ </div>
1343
+ <p class='MsoNormal'>
1416
1344
  <br clear='all' class='section'/>
1417
1345
  </p>
1418
- </div>
1419
- <div class='WordSection3_0'>
1420
- <div class='Section3'>
1421
- <a name='_level_1' id='_level_1'/>
1422
- <h1 class='Annex'>
1423
- <b>Annex A</b>
1424
- <br/>
1425
- (normative)
1426
- <br/>
1427
- <br/>
1428
- <b>Annex 1</b>
1429
- </h1>
1346
+ <div class='WordSection3'>
1347
+ <p class='zzSTDTitle1'>Document title</p>
1348
+ <div>
1349
+ <h1>Foreword</h1>
1350
+ <div class='Note'>
1351
+ <p class='Note'>
1352
+ <span class='note_label'/>
1353
+ <span style='mso-tab-count:1'>&#xA0; </span>
1354
+ For further information on the Foreword, see
1355
+ <b>ISO/IEC Directives, Part 2, 2016, Clause 12.</b>
1356
+ </p>
1357
+ <p class='Note'>
1358
+ <br clear='all' class='section'/>
1359
+ </p>
1360
+ </div>
1361
+ </div>
1430
1362
  </div>
1431
- </div>
1432
- <div style='mso-element:footnote-list'/>
1433
- </body>
1363
+ <div class='WordSection3_2'>
1364
+ <div align='center' class='table_container'>
1365
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
1366
+ <a name='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249' id='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249'/>
1367
+ <thead>
1368
+ <tr>
1369
+ <th align='left' style='font-weight:bold;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</th>
1370
+ <th align='left' style='font-weight:bold;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;'>B</th>
1371
+ </tr>
1372
+ </thead>
1373
+ <tbody>
1374
+ <tr>
1375
+ <td 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;'>C</td>
1376
+ <td 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;'>D</td>
1377
+ </tr>
1378
+ </tbody>
1379
+ <tfoot>
1380
+ <tr>
1381
+ <td colspan='2' style='border-top:0pt;mso-border-top-alt:0pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
1382
+ <div class='Note'>
1383
+ <a name='_8fff1596-290e-4314-b03c-7a8aab97eebe' id='_8fff1596-290e-4314-b03c-7a8aab97eebe'/>
1384
+ <p class='Note'>
1385
+ <span class='note_label'/>
1386
+ <span style='mso-tab-count:1'>&#xA0; </span>
1387
+ B
1388
+ </p>
1389
+ </div>
1390
+ </td>
1391
+ </tr>
1392
+ </tfoot>
1393
+ </table>
1394
+ </div>
1395
+ <p class='Note'>
1396
+ <br clear='all' class='section'/>
1397
+ </p>
1398
+ </div>
1399
+ <div class='WordSection3_1'>
1400
+ <p class='Note'>And up</p>
1401
+ <p class='MsoNormal'>
1402
+ <br clear='all' class='section'/>
1403
+ </p>
1404
+ </div>
1405
+ <div class='WordSection3_0'>
1406
+ <div class='Section3'>
1407
+ <a name='_level_1' id='_level_1'/>
1408
+ <h1 class='Annex'>Annex 1</h1>
1409
+ </div>
1410
+ </div>
1411
+ <div style='mso-element:footnote-list'/>
1412
+ </body>
1434
1413
  OUTPUT
1435
- end
1436
-
1437
- it 'expands out nested tables in Word' do
1438
- expect(xmlpp(IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
1439
- <html>
1440
- <head/>
1441
- <body>
1442
- <div class="main-section">
1443
- <table id="_7830dff8-419e-4b9e-85cf-a063689f44ca" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr>
1444
-
1445
- <table id="_a0f8c202-fd34-460c-bd5e-b2f4cc29210d" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
1446
- <p id="_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7">Description text</p>
1447
- </td></tr></tbody></table>
1448
- </tbody></table>
1449
- </div>
1450
- <div id="_second_sample"><h2>1.2.<span style="mso-tab-count:1">&#xA0; </span>Second sample</h2>
1451
-
1452
- <table id="_9846c486-14e5-4b1c-bb2f-55cc254dd309" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr><table id="_62de974c-7128-44d6-ba86-99f818f1d467" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
1453
- <p id="_30b90b08-bd71-4497-bbcc-8c61fbb9f772">Description text</p>
1454
- </td></tr></tbody></table>
1455
- <table id="_fede5681-71f6-47bb-bc65-7bd0b11acd01" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2">
1456
- <p id="_8daa3d74-90fd-4a57-9169-de457a68cfda">Description text</p>
1457
- </td></tr></tbody></table></tbody></table>
1458
- </div>
1459
- </body>
1460
- </html>
1414
+ end
1415
+
1416
+ it "expands out nested tables in Word" do
1417
+ expect(xmlpp(IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
1418
+ <html>
1419
+ <head/>
1420
+ <body>
1421
+ <div class="main-section">
1422
+ <table id="_7830dff8-419e-4b9e-85cf-a063689f44ca" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr>
1423
+ <table id="_a0f8c202-fd34-460c-bd5e-b2f4cc29210d" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
1424
+ <p id="_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7">Description text</p>
1425
+ </td></tr></tbody></table>
1426
+ </tbody></table>
1427
+ </div>
1428
+ <div id="_second_sample"><h2>1.2.<span style="mso-tab-count:1">&#xA0; </span>Second sample</h2>
1429
+ <table id="_9846c486-14e5-4b1c-bb2f-55cc254dd309" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr><table id="_62de974c-7128-44d6-ba86-99f818f1d467" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
1430
+ <p id="_30b90b08-bd71-4497-bbcc-8c61fbb9f772">Description text</p>
1431
+ </td></tr></tbody></table>
1432
+ <table id="_fede5681-71f6-47bb-bc65-7bd0b11acd01" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2">
1433
+ <p id="_8daa3d74-90fd-4a57-9169-de457a68cfda">Description text</p>
1434
+ </td></tr></tbody></table></tbody></table>
1435
+ </div>
1436
+ </body>
1437
+ </html>
1461
1438
  INPUT
1462
- <html>
1463
- <head/>
1464
- <body>
1465
- <div class='main-section'>
1466
- <table id='_7830dff8-419e-4b9e-85cf-a063689f44ca' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1467
- <thead>
1468
- <tr style='background:#A5A5A5;'>
1469
- <th style='vertical-align:top;' class='recommend' colspan='2'>
1470
- <p class='RecommendationTitle'>Requirement 1:</p>
1471
- </th>
1472
- </tr>
1473
- </thead>
1474
- <tbody>
1475
- <tr>
1476
- <td style='vertical-align:top;' class='recommend' colspan='2'>
1477
- <p>requirement label</p>
1478
- </td>
1479
- </tr>
1480
- </tbody>
1481
- </table>
1482
- <table id='_a0f8c202-fd34-460c-bd5e-b2f4cc29210d' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1483
- <thead>
1484
- <tr style='background:#A5A5A5;'>
1485
- <th style='vertical-align:top;' class='recommend' colspan='2'>
1486
- <p class='RecommendationTitle'>Requirement 1-1:</p>
1487
- </th>
1488
- </tr>
1489
- </thead>
1490
- <tbody>
1491
- <tr style='background:#C9C9C9;'>
1492
- <td style='vertical-align:top;' class='recommend' colspan='2'>
1493
- <p id='_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7'>Description text</p>
1494
- </td>
1495
- </tr>
1496
- </tbody>
1497
- </table>
1498
- </div>
1499
- <div id='_second_sample'>
1500
- <h2>
1501
- 1.2.
1502
- <span style='mso-tab-count:1'>&#xA0; </span>
1503
- Second sample
1504
- </h2>
1505
- <table id='_9846c486-14e5-4b1c-bb2f-55cc254dd309' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1506
- <thead>
1507
- <tr style='background:#A5A5A5;'>
1508
- <th style='vertical-align:top;' class='recommend' colspan='2'>
1509
- <p class='RecommendationTitle'>Requirement 2:</p>
1510
- </th>
1511
- </tr>
1512
- </thead>
1513
- <tbody>
1514
- <tr>
1515
- <td style='vertical-align:top;' class='recommend' colspan='2'>
1516
- <p>requirement label</p>
1517
- </td>
1518
- </tr>
1519
- </tbody>
1520
- </table>
1521
- <table id='_62de974c-7128-44d6-ba86-99f818f1d467' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1522
- <thead>
1523
- <tr style='background:#A5A5A5;'>
1524
- <th style='vertical-align:top;' class='recommend' colspan='2'>
1525
- <p class='RecommendationTitle'>Requirement 2-1:</p>
1526
- </th>
1527
- </tr>
1528
- </thead>
1529
- <tbody>
1530
- <tr style='background:#C9C9C9;'>
1531
- <td style='vertical-align:top;' class='recommend' colspan='2'>
1532
- <p id='_30b90b08-bd71-4497-bbcc-8c61fbb9f772'>Description text</p>
1533
- </td>
1534
- </tr>
1535
- </tbody>
1536
- </table>
1537
- <table id='_fede5681-71f6-47bb-bc65-7bd0b11acd01' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1538
- <thead>
1539
- <tr style='background:#A5A5A5;'>
1540
- <th style='vertical-align:top;' class='recommend' colspan='2'>
1541
- <p class='RecommendationTitle'>Requirement 2-2:</p>
1542
- </th>
1543
- </tr>
1544
- </thead>
1545
- <tbody>
1546
- <tr>
1547
- <td style='vertical-align:top;' class='recommend' colspan='2'>
1548
- <p id='_8daa3d74-90fd-4a57-9169-de457a68cfda'>Description text</p>
1549
- </td>
1550
- </tr>
1551
- </tbody>
1552
- </table>
1553
- </div>
1554
- </body>
1555
- </html>
1439
+ <html>
1440
+ <head/>
1441
+ <body>
1442
+ <div class='main-section'>
1443
+ <table id='_7830dff8-419e-4b9e-85cf-a063689f44ca' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1444
+ <thead>
1445
+ <tr style='background:#A5A5A5;'>
1446
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
1447
+ <p class='RecommendationTitle'>Requirement 1:</p>
1448
+ </th>
1449
+ </tr>
1450
+ </thead>
1451
+ <tbody>
1452
+ <tr>
1453
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
1454
+ <p>requirement label</p>
1455
+ </td>
1456
+ </tr>
1457
+ </tbody>
1458
+ </table>
1459
+ <table id='_a0f8c202-fd34-460c-bd5e-b2f4cc29210d' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1460
+ <thead>
1461
+ <tr style='background:#A5A5A5;'>
1462
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
1463
+ <p class='RecommendationTitle'>Requirement 1-1:</p>
1464
+ </th>
1465
+ </tr>
1466
+ </thead>
1467
+ <tbody>
1468
+ <tr style='background:#C9C9C9;'>
1469
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
1470
+ <p id='_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7'>Description text</p>
1471
+ </td>
1472
+ </tr>
1473
+ </tbody>
1474
+ </table>
1475
+ </div>
1476
+ <div id='_second_sample'>
1477
+ <h2>
1478
+ 1.2.
1479
+ <span style='mso-tab-count:1'>&#xA0; </span>
1480
+ Second sample
1481
+ </h2>
1482
+ <table id='_9846c486-14e5-4b1c-bb2f-55cc254dd309' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1483
+ <thead>
1484
+ <tr style='background:#A5A5A5;'>
1485
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
1486
+ <p class='RecommendationTitle'>Requirement 2:</p>
1487
+ </th>
1488
+ </tr>
1489
+ </thead>
1490
+ <tbody>
1491
+ <tr>
1492
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
1493
+ <p>requirement label</p>
1494
+ </td>
1495
+ </tr>
1496
+ </tbody>
1497
+ </table>
1498
+ <table id='_62de974c-7128-44d6-ba86-99f818f1d467' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1499
+ <thead>
1500
+ <tr style='background:#A5A5A5;'>
1501
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
1502
+ <p class='RecommendationTitle'>Requirement 2-1:</p>
1503
+ </th>
1504
+ </tr>
1505
+ </thead>
1506
+ <tbody>
1507
+ <tr style='background:#C9C9C9;'>
1508
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
1509
+ <p id='_30b90b08-bd71-4497-bbcc-8c61fbb9f772'>Description text</p>
1510
+ </td>
1511
+ </tr>
1512
+ </tbody>
1513
+ </table>
1514
+ <table id='_fede5681-71f6-47bb-bc65-7bd0b11acd01' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
1515
+ <thead>
1516
+ <tr style='background:#A5A5A5;'>
1517
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
1518
+ <p class='RecommendationTitle'>Requirement 2-2:</p>
1519
+ </th>
1520
+ </tr>
1521
+ </thead>
1522
+ <tbody>
1523
+ <tr>
1524
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
1525
+ <p id='_8daa3d74-90fd-4a57-9169-de457a68cfda'>Description text</p>
1526
+ </td>
1527
+ </tr>
1528
+ </tbody>
1529
+ </table>
1530
+ </div>
1531
+ </body>
1532
+ </html>
1556
1533
  OUTPUT
1557
- end
1534
+ end
1535
+
1558
1536
  end