isodoc 1.1.4 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
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