review 3.1.0 → 5.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (225) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ruby-win.yml +45 -0
  3. data/.github/workflows/ruby.yml +27 -0
  4. data/.rubocop.yml +161 -34
  5. data/.travis.yml +16 -15
  6. data/Dockerfile +21 -5
  7. data/NEWS.ja.md +394 -0
  8. data/NEWS.md +395 -1
  9. data/README.md +10 -7
  10. data/appveyor.yml +1 -3
  11. data/bin/review-catalog-converter +5 -5
  12. data/bin/review-check +10 -12
  13. data/bin/review-checkdep +2 -2
  14. data/bin/review-compile +17 -23
  15. data/bin/review-epubmaker +3 -35
  16. data/bin/review-idgxmlmaker +16 -0
  17. data/bin/review-index +2 -89
  18. data/bin/review-preproc +13 -13
  19. data/bin/review-validate +4 -4
  20. data/bin/review-vol +4 -78
  21. data/doc/config.yml.sample +47 -12
  22. data/doc/config.yml.sample-simple +3 -2
  23. data/doc/format.ja.md +120 -17
  24. data/doc/format.md +119 -27
  25. data/doc/makeindex.ja.md +2 -2
  26. data/doc/pdfmaker.ja.md +43 -1
  27. data/doc/pdfmaker.md +42 -1
  28. data/doc/quickstart.ja.md +45 -25
  29. data/doc/quickstart.md +37 -16
  30. data/lib/epubmaker/content.rb +3 -2
  31. data/lib/epubmaker/epubcommon.rb +34 -27
  32. data/lib/epubmaker/epubv2.rb +5 -6
  33. data/lib/epubmaker/epubv3.rb +21 -18
  34. data/lib/epubmaker/producer.rb +2 -1
  35. data/lib/review/book.rb +2 -2
  36. data/lib/review/book/base.rb +91 -96
  37. data/lib/review/book/bib.rb +21 -0
  38. data/lib/review/book/book_unit.rb +155 -0
  39. data/lib/review/book/chapter.rb +48 -29
  40. data/lib/review/book/index.rb +46 -240
  41. data/lib/review/book/index/item.rb +46 -0
  42. data/lib/review/book/page_metric.rb +7 -7
  43. data/lib/review/book/part.rb +45 -10
  44. data/lib/review/book/volume.rb +4 -5
  45. data/lib/review/builder.rb +172 -56
  46. data/lib/review/catalog.rb +14 -17
  47. data/lib/review/compiler.rb +219 -121
  48. data/lib/review/configure.rb +39 -7
  49. data/lib/review/converter.rb +1 -1
  50. data/lib/review/epub2html.rb +43 -5
  51. data/lib/review/epubmaker.rb +69 -27
  52. data/lib/review/extentions/string.rb +0 -4
  53. data/lib/review/htmlbuilder.rb +112 -101
  54. data/lib/review/htmlutils.rb +9 -13
  55. data/lib/review/i18n.rb +3 -3
  56. data/lib/review/idgxmlbuilder.rb +202 -78
  57. data/lib/review/idgxmlmaker.rb +186 -0
  58. data/lib/review/index_builder.rb +653 -0
  59. data/lib/review/init-web/finish.html +10 -0
  60. data/lib/review/init-web/index.html +190 -0
  61. data/lib/review/init-web/review-layout-design.js +691 -0
  62. data/lib/review/init.rb +129 -46
  63. data/lib/review/latexbuilder.rb +255 -92
  64. data/lib/review/lineinput.rb +1 -1
  65. data/lib/review/location.rb +32 -0
  66. data/lib/review/logger.rb +4 -8
  67. data/lib/review/makerhelper.rb +35 -5
  68. data/lib/review/markdownbuilder.rb +50 -38
  69. data/lib/review/md2inaobuilder.rb +3 -5
  70. data/lib/review/pdfmaker.rb +60 -57
  71. data/lib/review/plaintextbuilder.rb +154 -87
  72. data/lib/review/preprocessor.rb +20 -42
  73. data/lib/review/rstbuilder.rb +57 -38
  74. data/lib/review/sec_counter.rb +13 -0
  75. data/lib/review/textmaker.rb +23 -15
  76. data/lib/review/textutils.rb +76 -2
  77. data/lib/review/tocprinter.rb +230 -102
  78. data/lib/review/topbuilder.rb +139 -60
  79. data/lib/review/update.rb +24 -24
  80. data/lib/review/version.rb +1 -1
  81. data/lib/review/volumeprinter.rb +98 -0
  82. data/lib/review/webmaker.rb +20 -24
  83. data/lib/review/webtocprinter.rb +38 -35
  84. data/lib/review/yamlloader.rb +26 -16
  85. data/review.gemspec +6 -4
  86. data/samples/sample-book/README.md +7 -2
  87. data/samples/sample-book/src/.gitignore +154 -0
  88. data/samples/sample-book/src/config-ebook.yml +4 -0
  89. data/samples/sample-book/src/config-jlreq-ebook.yml +4 -0
  90. data/samples/sample-book/src/config-jlreq.yml +6 -0
  91. data/samples/sample-book/src/config.yml +2 -2
  92. data/samples/sample-book/src/lib/tasks/review.rake +29 -14
  93. data/samples/sample-book/src/lib/tasks/z01_copy_sty.rake +14 -8
  94. data/samples/syntax-book/Gemfile +1 -1
  95. data/samples/syntax-book/ch01.re +4 -2
  96. data/samples/syntax-book/ch02.re +8 -16
  97. data/samples/syntax-book/ch03.re +3 -6
  98. data/samples/syntax-book/config-jlreq-lualatex.yml +4 -0
  99. data/samples/syntax-book/config-jlreq.yml +5 -0
  100. data/samples/syntax-book/config-print.yml +3 -0
  101. data/samples/syntax-book/config.yml +1 -1
  102. data/samples/syntax-book/lib/tasks/review.rake +30 -15
  103. data/samples/syntax-book/lib/tasks/z01_copy_sty.rake +14 -8
  104. data/templates/latex/config.erb +39 -25
  105. data/templates/latex/layout.tex.erb +1 -0
  106. data/templates/latex/review-jlreq/README.md +3 -1
  107. data/templates/latex/review-jlreq/review-base.sty +161 -50
  108. data/templates/latex/review-jlreq/review-jlreq.cls +21 -22
  109. data/templates/latex/review-jlreq/review-style.sty +4 -1
  110. data/templates/latex/review-jsbook/README.md +46 -5
  111. data/templates/latex/review-jsbook/review-base.sty +123 -35
  112. data/templates/latex/review-jsbook/review-jsbook.cls +10 -4
  113. data/templates/latex/review-jsbook/review-style.sty +5 -2
  114. data/templates/opf/epubv3.opf.erb +1 -0
  115. data/templates/web/html/layout-html5.html.erb +3 -3
  116. data/test/assets/test_template.tex +19 -7
  117. data/test/assets/test_template_backmatter.tex +19 -7
  118. data/test/book_test_helper.rb +11 -5
  119. data/test/test_book.rb +124 -79
  120. data/test/test_book_chapter.rb +97 -54
  121. data/test/test_book_part.rb +3 -3
  122. data/test/test_builder.rb +38 -13
  123. data/test/test_catalog.rb +24 -42
  124. data/test/test_catalog_converter_cmd.rb +1 -1
  125. data/test/test_converter.rb +1 -0
  126. data/test/test_epub3maker.rb +2 -2
  127. data/test/test_epubmaker.rb +8 -0
  128. data/test/test_epubmaker_cmd.rb +14 -7
  129. data/test/test_helper.rb +18 -7
  130. data/test/test_htmlbuilder.rb +1491 -205
  131. data/test/test_htmlutils.rb +0 -12
  132. data/test/test_i18n.rb +37 -37
  133. data/test/test_idgxmlbuilder.rb +744 -42
  134. data/test/test_idgxmlmaker_cmd.rb +46 -0
  135. data/test/test_image_finder.rb +52 -70
  136. data/test/test_index.rb +94 -44
  137. data/test/test_indexbuilder.rb +52 -0
  138. data/test/test_latexbuilder.rb +1784 -161
  139. data/test/test_latexbuilder_v2.rb +671 -102
  140. data/test/test_logger.rb +17 -4
  141. data/test/test_makerhelper.rb +2 -14
  142. data/test/test_markdownbuilder.rb +137 -16
  143. data/test/test_md2inaobuilder.rb +32 -9
  144. data/test/test_pdfmaker.rb +30 -12
  145. data/test/test_pdfmaker_cmd.rb +100 -6
  146. data/test/test_plaintextbuilder.rb +791 -30
  147. data/test/test_preprocessor.rb +2 -16
  148. data/test/test_review_ext.rb +2 -1
  149. data/test/test_rstbuilder.rb +274 -27
  150. data/test/test_sec_counter.rb +156 -0
  151. data/test/test_textmaker_cmd.rb +54 -0
  152. data/test/test_textutils.rb +109 -2
  153. data/test/test_topbuilder.rb +724 -34
  154. data/test/test_update.rb +20 -11
  155. data/test/test_webtocprinter.rb +75 -43
  156. data/test/test_yamlloader.rb +13 -0
  157. data/vendor/gentombow/LICENSE +1 -1
  158. data/vendor/gentombow/Makefile +0 -1
  159. data/vendor/gentombow/bounddvi-en.pdf +0 -0
  160. data/vendor/gentombow/bounddvi-en.tex +1 -0
  161. data/vendor/gentombow/bounddvi.pdf +0 -0
  162. data/vendor/gentombow/bounddvi.sty +30 -7
  163. data/vendor/gentombow/bounddvi.tex +1 -0
  164. data/vendor/gentombow/create_archive.sh +1 -0
  165. data/vendor/gentombow/gentombow-ja.pdf +0 -0
  166. data/vendor/gentombow/gentombow-ja.tex +9 -0
  167. data/vendor/gentombow/gentombow.pdf +0 -0
  168. data/vendor/gentombow/gentombow.sty +32 -10
  169. data/vendor/gentombow/gentombow.tex +8 -0
  170. data/vendor/gentombow/tests/gentombow-01-pdfx.tex +8 -0
  171. data/vendor/gentombow/tests/gentombow-02-pdfx.tex +8 -0
  172. data/vendor/jsclasses/LICENSE +1 -1
  173. data/vendor/jsclasses/Makefile +3 -2
  174. data/vendor/jsclasses/create_archive.sh +5 -5
  175. data/vendor/jsclasses/jis/Makefile +3 -2
  176. data/vendor/jsclasses/jis/jsarticle.cls +74 -31
  177. data/vendor/jsclasses/jis/jsbook.cls +74 -31
  178. data/vendor/jsclasses/jis/jsclasses.dtx +176 -36
  179. data/vendor/jsclasses/jis/jsclasses.ins +15 -5
  180. data/vendor/jsclasses/jis/jslogo.dtx +4 -4
  181. data/vendor/jsclasses/jis/jslogo.ins +9 -0
  182. data/vendor/jsclasses/jis/jslogo.sty +4 -16
  183. data/vendor/jsclasses/jis/jspf.cls +73 -30
  184. data/vendor/jsclasses/jis/jsreport.cls +74 -31
  185. data/vendor/jsclasses/jis/jsverb.ins +9 -0
  186. data/vendor/jsclasses/jis/jsverb.sty +1 -13
  187. data/vendor/jsclasses/jis/kiyou.cls +74 -31
  188. data/vendor/jsclasses/jis/minijs.sty +65 -22
  189. data/vendor/jsclasses/jis/okumacro.dtx +4 -5
  190. data/vendor/jsclasses/jis/okumacro.ins +9 -0
  191. data/vendor/jsclasses/jis/okumacro.sty +4 -17
  192. data/vendor/jsclasses/jis/okuverb.ins +9 -0
  193. data/vendor/jsclasses/jis/okuverb.sty +1 -13
  194. data/vendor/jsclasses/jis/winjis.sty +23 -19
  195. data/vendor/jsclasses/jsarticle.cls +74 -31
  196. data/vendor/jsclasses/jsbook.cls +74 -31
  197. data/vendor/jsclasses/jsclasses.dtx +176 -36
  198. data/vendor/jsclasses/jsclasses.ins +15 -5
  199. data/vendor/jsclasses/jsclasses.pdf +0 -0
  200. data/vendor/jsclasses/jslogo.dtx +4 -4
  201. data/vendor/jsclasses/jslogo.ins +9 -0
  202. data/vendor/jsclasses/jslogo.pdf +0 -0
  203. data/vendor/jsclasses/jslogo.sty +4 -16
  204. data/vendor/jsclasses/jspf.cls +73 -30
  205. data/vendor/jsclasses/jsreport.cls +74 -31
  206. data/vendor/jsclasses/jsverb.ins +9 -0
  207. data/vendor/jsclasses/jsverb.pdf +0 -0
  208. data/vendor/jsclasses/jsverb.sty +1 -13
  209. data/vendor/jsclasses/kiyou.cls +74 -31
  210. data/vendor/jsclasses/minijs.sty +68 -22
  211. data/vendor/jsclasses/okumacro.dtx +4 -5
  212. data/vendor/jsclasses/okumacro.ins +9 -0
  213. data/vendor/jsclasses/okumacro.pdf +0 -0
  214. data/vendor/jsclasses/okumacro.sty +4 -17
  215. data/vendor/jsclasses/okuverb.ins +9 -0
  216. data/vendor/jsclasses/okuverb.pdf +0 -0
  217. data/vendor/jsclasses/okuverb.sty +1 -13
  218. data/vendor/jsclasses/tests/relfont.tex +10 -0
  219. data/vendor/jsclasses/winjis.sty +23 -19
  220. metadata +65 -12
  221. data/.rubocop_todo.yml +0 -7
  222. data/lib/review/book/compilable.rb +0 -173
  223. data/lib/review/tocparser.rb +0 -271
  224. data/samples/syntax-book/review-ext.rb +0 -14
  225. data/test/test_tocparser.rb +0 -25
@@ -0,0 +1,46 @@
1
+ require 'test_helper'
2
+ require 'tmpdir'
3
+ require 'fileutils'
4
+ require 'yaml'
5
+ require 'rbconfig'
6
+ require 'open3'
7
+
8
+ REVIEW_IDGXMLMAKER = File.expand_path('../bin/review-idgxmlmaker', File.dirname(__FILE__))
9
+
10
+ class IDGXMLMakerCmdTest < Test::Unit::TestCase
11
+ def setup
12
+ @tmpdir1 = Dir.mktmpdir
13
+
14
+ @old_rubylib = ENV['RUBYLIB']
15
+ ENV['RUBYLIB'] = File.expand_path('../lib', File.dirname(__FILE__))
16
+ end
17
+
18
+ def teardown
19
+ FileUtils.rm_rf(@tmpdir1)
20
+ ENV['RUBYLIB'] = @old_rubylib
21
+ end
22
+
23
+ def common_buildidgxml(bookdir, configfile, targetfile, option)
24
+ if /mswin|mingw|cygwin/ !~ RUBY_PLATFORM
25
+ config = prepare_samplebook(@tmpdir1, bookdir, nil, configfile)
26
+ builddir = File.join(@tmpdir1, config['bookname'] + '-idgxml')
27
+ assert !File.exist?(builddir)
28
+
29
+ ruby_cmd = File.join(RbConfig::CONFIG['bindir'], RbConfig::CONFIG['ruby_install_name']) + RbConfig::CONFIG['EXEEXT']
30
+ Dir.chdir(@tmpdir1) do
31
+ _o, e, s = Open3.capture3("#{ruby_cmd} -S #{REVIEW_IDGXMLMAKER} #{option} #{configfile}")
32
+ assert_equal '', e
33
+ assert s.success?
34
+ end
35
+ assert File.exist?(File.join(@tmpdir1, targetfile))
36
+ end
37
+ end
38
+
39
+ def test_idgxmlmaker_cmd_samplebook
40
+ common_buildidgxml('sample-book/src', 'config.yml', 'book-idgxml/ch01.xml', nil)
41
+ end
42
+
43
+ def test_idgxmlmaker_cmd_syntaxbook
44
+ common_buildidgxml('syntax-book', 'config.yml', 'syntax-book-idgxml/ch01.xml', nil)
45
+ end
46
+ end
@@ -7,93 +7,75 @@ class ImageFinderTest < Test::Unit::TestCase
7
7
  include ReVIEW
8
8
 
9
9
  def setup
10
+ if ENV['GITHUB_WORKSPACE']
11
+ ENV['TMPDIR'] = File.join(ENV['GITHUB_WORKSPACE'], 'tmp_review')
12
+ FileUtils.mkdir_p(ENV['TMPDIR'])
13
+ end
14
+ @dir = Dir.mktmpdir
10
15
  end
11
16
 
12
- def test_find_path_pattern1
13
- dir = Dir.mktmpdir
14
- begin
15
- path = File.join(dir, 'builder/ch01/foo.jpg')
16
- FileUtils.mkdir_p(File.dirname(path))
17
- FileUtils.touch(path)
18
-
19
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
20
- assert_equal(path, finder.find_path('foo'))
21
- ensure
22
- FileUtils.remove_entry_secure dir
17
+ def teardown
18
+ if @dir
19
+ FileUtils.remove_entry_secure(@dir)
23
20
  end
24
21
  end
25
22
 
23
+ def test_find_path_pattern1
24
+ path = File.join(@dir, 'builder/ch01/foo.jpg')
25
+ FileUtils.mkdir_p(File.dirname(path))
26
+ FileUtils.touch(path)
27
+
28
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
29
+
30
+ assert_equal(path, finder.find_path('foo'))
31
+ end
32
+
26
33
  def test_find_path_pattern2
27
- dir = Dir.mktmpdir
28
- begin
29
- path = File.join(dir, 'builder/ch01-foo.jpg')
30
- FileUtils.mkdir_p(File.dirname(path))
31
- FileUtils.touch(path)
32
-
33
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
34
- assert_equal(path, finder.find_path('foo'))
35
- ensure
36
- FileUtils.remove_entry_secure dir
37
- end
34
+ path = File.join(@dir, 'builder/ch01-foo.jpg')
35
+ FileUtils.mkdir_p(File.dirname(path))
36
+ FileUtils.touch(path)
37
+
38
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
39
+ assert_equal(path, finder.find_path('foo'))
38
40
  end
39
41
 
40
42
  def test_find_path_pattern3
41
- dir = Dir.mktmpdir
42
- begin
43
- path = File.join(dir, 'builder/foo.jpg')
44
- FileUtils.mkdir_p(File.dirname(path))
45
- FileUtils.touch(path)
46
-
47
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
48
- assert_equal(path, finder.find_path('foo'))
49
- ensure
50
- FileUtils.remove_entry_secure dir
51
- end
43
+ path = File.join(@dir, 'builder/foo.jpg')
44
+ FileUtils.mkdir_p(File.dirname(path))
45
+ FileUtils.touch(path)
46
+
47
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
48
+ assert_equal(path, finder.find_path('foo'))
52
49
  end
53
50
 
54
51
  def test_find_path_pattern4
55
- dir = Dir.mktmpdir
56
- begin
57
- path = File.join(dir, 'ch01/foo.jpg')
58
- FileUtils.mkdir_p(File.dirname(path))
59
- FileUtils.touch(path)
60
-
61
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
62
- assert_equal(path, finder.find_path('foo'))
63
- ensure
64
- FileUtils.remove_entry_secure dir
65
- end
52
+ path = File.join(@dir, 'ch01/foo.jpg')
53
+ FileUtils.mkdir_p(File.dirname(path))
54
+ FileUtils.touch(path)
55
+
56
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
57
+ assert_equal(path, finder.find_path('foo'))
66
58
  end
67
59
 
68
60
  def test_find_path_pattern5
69
- dir = Dir.mktmpdir
70
- begin
71
- path = File.join(dir, 'ch01-foo.jpg')
72
- FileUtils.mkdir_p(File.dirname(path))
73
- FileUtils.touch(path)
74
-
75
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
76
- assert_equal(path, finder.find_path('foo'))
77
- ensure
78
- FileUtils.remove_entry_secure dir
79
- end
61
+ path = File.join(@dir, 'ch01-foo.jpg')
62
+ FileUtils.mkdir_p(File.dirname(path))
63
+ FileUtils.touch(path)
64
+
65
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
66
+ assert_equal(path, finder.find_path('foo'))
80
67
  end
81
68
 
82
69
  def test_find_path_dir_symlink
83
- dir = Dir.mktmpdir
84
- begin
85
- path_src = File.join(dir, 'src')
86
- path_dst = File.join(dir, 'ch01')
87
- FileUtils.mkdir_p(path_src)
88
- FileUtils.symlink(path_src, path_dst)
89
- path_srcimg = File.join(path_src, 'foo.jpg')
90
- path_dstimg = File.join(path_dst, 'foo.jpg')
91
- FileUtils.touch(path_srcimg)
92
-
93
- finder = ReVIEW::Book::ImageFinder.new(dir, 'ch01', 'builder', ['.jpg'])
94
- assert_equal(path_dstimg, finder.find_path('foo'))
95
- ensure
96
- FileUtils.remove_entry_secure dir
97
- end
70
+ path_src = File.join(@dir, 'src')
71
+ path_dst = File.join(@dir, 'ch01')
72
+ FileUtils.mkdir_p(path_src)
73
+ FileUtils.symlink(path_src, path_dst)
74
+ path_srcimg = File.join(path_src, 'foo.jpg')
75
+ path_dstimg = File.join(path_dst, 'foo.jpg')
76
+ FileUtils.touch(path_srcimg)
77
+
78
+ finder = ReVIEW::Book::ImageFinder.new(@dir, 'ch01', 'builder', ['.jpg'])
79
+ assert_equal(path_dstimg, finder.find_path('foo'))
98
80
  end
99
81
  end
@@ -1,11 +1,28 @@
1
1
  require 'test_helper'
2
+ require 'review/compiler'
2
3
  require 'review/book'
3
4
  require 'review/book/index'
5
+ require 'review/topbuilder'
6
+ require 'review/i18n'
4
7
 
5
8
  class IndexTest < Test::Unit::TestCase
6
9
  include ReVIEW
10
+
11
+ def setup
12
+ @builder = TOPBuilder.new
13
+ @config = ReVIEW::Configure.create(config: { 'secnolevel' => 2, 'language' => 'ja' })
14
+ @book = Book::Base.new(config: @config)
15
+ @compiler = ReVIEW::Compiler.new(@builder)
16
+ @chapter = Book::Chapter.new(@book, 1, '-', nil, StringIO.new)
17
+ location = Location.new(nil, nil)
18
+ @builder.bind(@compiler, @chapter, location)
19
+
20
+ I18n.setup(@config['language'])
21
+ end
22
+
7
23
  def test_footnote_index
8
- fn = Book::FootnoteIndex.parse(['//footnote[foo][bar]'])
24
+ compile_block("//footnote[foo][bar]\n")
25
+ fn = @chapter.footnote_index
9
26
  items = fn.to_a
10
27
  item = items[0]
11
28
  assert_equal 'foo', item.id
@@ -13,7 +30,8 @@ class IndexTest < Test::Unit::TestCase
13
30
  end
14
31
 
15
32
  def test_footnote_index_with_escape
16
- fn = Book::FootnoteIndex.parse(['//footnote[foo][bar[\]buz]'])
33
+ compile_block('//footnote[foo][bar[\]buz]' + "\n")
34
+ fn = @chapter.footnote_index
17
35
  items = fn.to_a
18
36
  item = items[0]
19
37
  assert_equal 'foo', item.id
@@ -21,7 +39,8 @@ class IndexTest < Test::Unit::TestCase
21
39
  end
22
40
 
23
41
  def test_footnote_index_with_escape2
24
- fn = Book::FootnoteIndex.parse(['//footnote[foo][bar\\a\\$buz]'])
42
+ compile_block('//footnote[foo][bar\\a\\$buz]' + "\n")
43
+ fn = @chapter.footnote_index
25
44
  items = fn.to_a
26
45
  item = items[0]
27
46
  assert_equal 'foo', item.id
@@ -29,7 +48,8 @@ class IndexTest < Test::Unit::TestCase
29
48
  end
30
49
 
31
50
  def test_footnote_index_key?
32
- fn = Book::FootnoteIndex.parse(['//footnote[foo][bar]'])
51
+ compile_block('//footnote[foo][bar]' + "\n")
52
+ fn = @chapter.footnote_index
33
53
  assert_equal true, fn.key?('foo')
34
54
 
35
55
  ## for compatibility
@@ -38,7 +58,7 @@ class IndexTest < Test::Unit::TestCase
38
58
  # rubocop:enable Style/PreferredHashMethods
39
59
  end
40
60
 
41
- def test_headeline_index
61
+ def test_headline_index
42
62
  src = <<-EOB
43
63
  = chap1
44
64
  == sec1-1
@@ -52,14 +72,13 @@ class IndexTest < Test::Unit::TestCase
52
72
  == sec1-3
53
73
  ==== sec1-3-0-1
54
74
  EOB
55
- book = Book::Base.load
56
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
57
- index = Book::HeadlineIndex.parse(src, chap)
75
+ compile_block(src)
76
+ index = @chapter.headline_index
58
77
  assert_equal [2, 2], index['sec1-2|sec1-2-2'].number
59
78
  assert_equal '1.2.2', index.number('sec1-2|sec1-2-2')
60
79
  end
61
80
 
62
- def test_headeline_index2
81
+ def test_headline_index2
63
82
  src = <<-EOB
64
83
  = chap1
65
84
  == sec1-1
@@ -69,14 +88,13 @@ class IndexTest < Test::Unit::TestCase
69
88
  == sec1-3
70
89
  === sec1-3-1
71
90
  EOB
72
- book = Book::Base.load
73
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
74
- index = Book::HeadlineIndex.parse(src, chap)
91
+ compile_block(src)
92
+ index = @chapter.headline_index
75
93
  assert_equal [3, 1], index['sec1-3|sec1-3-1'].number
76
94
  assert_equal '1.3.1', index.number('sec1-3|sec1-3-1')
77
95
  end
78
96
 
79
- def test_headeline_index3
97
+ def test_headline_index3
80
98
  src = <<-EOB
81
99
  = chap1
82
100
  == sec1-1
@@ -87,9 +105,8 @@ class IndexTest < Test::Unit::TestCase
87
105
  == sec1-3
88
106
  === sec1-3-1
89
107
  EOB
90
- book = Book::Base.load
91
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
92
- index = Book::HeadlineIndex.parse(src, chap)
108
+ compile_block(src)
109
+ index = @chapter.headline_index
93
110
  assert_equal [2, 2], index['sec1-2|sec1-2-2'].number
94
111
  assert_equal '1.2.2', index.number('sec1-2|sec1-2-2')
95
112
 
@@ -97,7 +114,7 @@ class IndexTest < Test::Unit::TestCase
97
114
  assert_equal '1.3.1', index.number('sec1-3|sec1-3-1')
98
115
  end
99
116
 
100
- def test_headeline_index4
117
+ def test_headline_index4
101
118
  src = <<-EOB
102
119
  = chap1
103
120
  ====[column] c1
@@ -106,14 +123,13 @@ class IndexTest < Test::Unit::TestCase
106
123
  === sec1-2-1
107
124
  === sec1-2-2
108
125
  EOB
109
- book = Book::Base.load
110
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
111
- index = Book::HeadlineIndex.parse(src, chap)
126
+ compile_block(src)
127
+ index = @chapter.headline_index
112
128
  assert_equal [2, 2], index['sec1-2|sec1-2-2'].number
113
129
  assert_equal '1.2.2', index.number('sec1-2|sec1-2-2')
114
130
  end
115
131
 
116
- def test_headeline_index5
132
+ def test_headline_index5
117
133
  src = <<-EOB
118
134
  = chap1
119
135
  ====[column] c1
@@ -122,14 +138,13 @@ class IndexTest < Test::Unit::TestCase
122
138
  === sec1-2-1
123
139
  === sec1-2-2
124
140
  EOB
125
- book = Book::Base.load
126
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
127
- index = Book::HeadlineIndex.parse(src, chap)
141
+ compile_block(src)
142
+ index = @chapter.headline_index
128
143
  assert_equal [2, 2], index['sec1-2-2'].number
129
144
  assert_equal '1.2.2', index.number('sec1-2-2')
130
145
  end
131
146
 
132
- def test_headeline_index6
147
+ def test_headline_index6
133
148
  src = <<-EOB
134
149
  = chap1
135
150
  == sec1
@@ -137,34 +152,33 @@ class IndexTest < Test::Unit::TestCase
137
152
  == sec2
138
153
 
139
154
  EOB
140
- book = Book::Base.load
141
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
142
- index = Book::HeadlineIndex.parse(src, chap)
155
+ compile_block(src)
156
+ index = @chapter.headline_index
143
157
  assert_equal [1, 1], index['target'].number
144
158
  assert_equal '1.1.1', index.number('target')
145
159
  end
146
160
 
147
- def test_headeline_index7
161
+ def test_headline_index7
148
162
  src = <<-EOB
149
163
  = chap1
150
164
  == sec1
151
165
  === target
152
166
  ^-- dummy target
167
+
153
168
  == sec2
154
169
  === target
155
170
  ^-- real target but it cannot be detected, because there is another one.
156
171
 
157
172
  EOB
158
- book = Book::Base.load
159
- chap = Book::Chapter.new(book, 1, '-', nil) # dummy
160
- index = Book::HeadlineIndex.parse(src, chap)
173
+ compile_block(src)
174
+ index = @chapter.headline_index
161
175
 
162
176
  assert_raise ReVIEW::KeyError do
163
177
  assert_equal [1, 1], index['target'].number
164
178
  end
165
179
  end
166
180
 
167
- def test_headeline_index8
181
+ def test_headline_index8
168
182
  src = <<-EOB
169
183
  = chap1
170
184
  == sec1
@@ -172,13 +186,13 @@ class IndexTest < Test::Unit::TestCase
172
186
  ==== sec1-1-1
173
187
 
174
188
  EOB
175
- book = Book::Base.load
176
- chap = Book::Chapter.new(book, 1, '-', nil)
177
- index = Book::HeadlineIndex.parse(src, chap)
189
+ compile_block(src)
190
+ index = @chapter.headline_index
191
+
178
192
  assert_equal '1.1.1', index.number('sec1-1')
179
193
  end
180
194
 
181
- def test_headeline_index9
195
+ def test_headline_index9
182
196
  src = <<-EOB
183
197
  = chap1
184
198
  == sec1
@@ -188,13 +202,12 @@ class IndexTest < Test::Unit::TestCase
188
202
  ==== sec1-1-1
189
203
  === sec1-2
190
204
  EOB
191
- book = Book::Base.load
192
- chap = Book::Chapter.new(book, 1, '-', nil)
193
- index = Book::HeadlineIndex.parse(src, chap)
205
+ compile_block(src)
206
+ index = @chapter.headline_index
194
207
  assert_equal [1, 1, 1], index['sec1-1-1'].number
195
208
  end
196
209
 
197
- def test_headeline_index10
210
+ def test_headline_index10
198
211
  src = <<-EOB
199
212
  = chap1
200
213
  == sec1
@@ -203,9 +216,46 @@ class IndexTest < Test::Unit::TestCase
203
216
  ==== sec1-1-1
204
217
  === sec1-2
205
218
  EOB
206
- book = Book::Base.load
207
- chap = Book::Chapter.new(book, 1, '-', nil)
208
- index = Book::HeadlineIndex.parse(src, chap)
219
+ compile_block(src)
220
+ index = @chapter.headline_index
209
221
  assert_equal [1, 1, 1], index['sec1-1-1'].number
210
222
  end
223
+
224
+ def test_headline_index11
225
+ src = <<-EOB
226
+ = chap1
227
+ ==[nodisp] sec01
228
+ ==[notoc] sec02
229
+ == sec1
230
+ ===[nodisp] sec1-0
231
+ === sec1-1
232
+ ==[nonum] sec03
233
+ == sec04
234
+ EOB
235
+ compile_block(src)
236
+ index = @chapter.headline_index
237
+ assert_equal nil, index['sec01'].number
238
+ assert_equal nil, index['sec02'].number
239
+ assert_equal [1], index['sec1'].number
240
+ assert_equal nil, index['sec1-0'].number
241
+ assert_equal [1, 1], index['sec1-1'].number
242
+ assert_equal nil, index['sec03'].number
243
+ assert_equal [2], index['sec04'].number
244
+ end
245
+
246
+ def test_headline_index12
247
+ src = <<-EOB
248
+ = chap1
249
+ == A
250
+ === A2
251
+ ==[nonum] B
252
+ === B2
253
+ EOB
254
+ compile_block(src)
255
+ index = @chapter.headline_index
256
+ assert_equal [1], index['A'].number
257
+ assert_equal [1, 1], index['A2'].number
258
+ assert_equal nil, index['B'].number
259
+ assert_equal [1, 2], index['B2'].number
260
+ end
211
261
  end