review 4.1.0 → 5.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (259) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ruby-tex.yml +35 -0
  3. data/.github/workflows/ruby-win.yml +19 -9
  4. data/.github/workflows/ruby.yml +7 -3
  5. data/.rubocop.yml +138 -34
  6. data/NEWS.ja.md +285 -0
  7. data/NEWS.md +285 -1
  8. data/README.md +7 -6
  9. data/Rakefile +7 -2
  10. data/bin/review +2 -4
  11. data/bin/review-catalog-converter +4 -4
  12. data/bin/review-check +8 -12
  13. data/bin/review-checkdep +2 -5
  14. data/bin/review-compile +18 -34
  15. data/bin/review-epub2html +1 -4
  16. data/bin/review-epubmaker +3 -4
  17. data/bin/review-idgxmlmaker +1 -3
  18. data/bin/review-index +5 -86
  19. data/bin/review-init +1 -4
  20. data/bin/review-pdfmaker +1 -3
  21. data/bin/review-preproc +30 -38
  22. data/bin/review-textmaker +1 -3
  23. data/bin/review-update +1 -4
  24. data/bin/review-validate +4 -4
  25. data/bin/review-vol +5 -82
  26. data/bin/review-webmaker +1 -3
  27. data/doc/config.yml.sample +45 -11
  28. data/doc/config.yml.sample-simple +3 -3
  29. data/doc/format.ja.md +103 -13
  30. data/doc/format.md +104 -16
  31. data/doc/makeindex.ja.md +2 -2
  32. data/doc/pdfmaker.ja.md +42 -0
  33. data/doc/pdfmaker.md +41 -0
  34. data/doc/quickstart.ja.md +19 -6
  35. data/doc/quickstart.md +18 -6
  36. data/doc/writing_vertical.ja.md +6 -0
  37. data/lib/review.rb +1 -1
  38. data/lib/review/book.rb +2 -2
  39. data/lib/review/book/base.rb +67 -29
  40. data/lib/review/book/bib.rb +21 -0
  41. data/lib/review/book/book_unit.rb +158 -0
  42. data/lib/review/book/chapter.rb +33 -26
  43. data/lib/review/book/index.rb +24 -185
  44. data/lib/review/book/index/item.rb +7 -1
  45. data/lib/review/book/page_metric.rb +7 -7
  46. data/lib/review/book/part.rb +26 -11
  47. data/lib/review/book/volume.rb +5 -5
  48. data/lib/review/builder.rb +121 -52
  49. data/lib/review/call_hook.rb +20 -0
  50. data/lib/review/catalog.rb +3 -2
  51. data/lib/review/compiler.rb +230 -111
  52. data/lib/review/configure.rb +91 -7
  53. data/lib/review/converter.rb +1 -1
  54. data/lib/review/epub2html.rb +6 -1
  55. data/lib/review/epubmaker.rb +124 -152
  56. data/lib/review/epubmaker/content.rb +113 -0
  57. data/lib/review/epubmaker/epubcommon.rb +372 -0
  58. data/lib/review/epubmaker/epubv2.rb +178 -0
  59. data/lib/review/epubmaker/epubv3.rb +231 -0
  60. data/lib/review/epubmaker/producer.rb +167 -0
  61. data/lib/review/epubmaker/reviewheaderlistener.rb +12 -2
  62. data/lib/review/epubmaker/zip_exporter.rb +84 -0
  63. data/lib/review/exception.rb +13 -0
  64. data/lib/review/htmlbuilder.rb +176 -89
  65. data/lib/review/htmlutils.rb +8 -11
  66. data/lib/review/i18n.rb +2 -1
  67. data/lib/review/idgxmlbuilder.rb +165 -75
  68. data/lib/review/idgxmlmaker.rb +24 -28
  69. data/lib/review/img_math.rb +238 -0
  70. data/lib/review/index_builder.rb +645 -0
  71. data/lib/review/init.rb +9 -17
  72. data/lib/review/latexbox.rb +58 -0
  73. data/lib/review/latexbuilder.rb +193 -75
  74. data/lib/review/latexutils.rb +9 -1
  75. data/lib/review/lineinput.rb +112 -2
  76. data/lib/review/loggable.rb +27 -0
  77. data/lib/review/logger.rb +90 -3
  78. data/lib/review/makerhelper.rb +17 -188
  79. data/lib/review/markdownbuilder.rb +54 -4
  80. data/lib/review/pdfmaker.rb +76 -84
  81. data/lib/review/plaintextbuilder.rb +106 -22
  82. data/lib/review/preprocessor.rb +107 -303
  83. data/lib/review/preprocessor/directive.rb +35 -0
  84. data/lib/review/preprocessor/line.rb +34 -0
  85. data/lib/review/preprocessor/repository.rb +177 -0
  86. data/lib/review/rstbuilder.rb +27 -8
  87. data/lib/review/sec_counter.rb +14 -0
  88. data/lib/review/template.rb +11 -1
  89. data/lib/review/textmaker.rb +27 -32
  90. data/lib/review/textutils.rb +3 -12
  91. data/lib/review/tocprinter.rb +242 -97
  92. data/lib/review/topbuilder.rb +98 -31
  93. data/lib/review/update.rb +12 -13
  94. data/lib/review/version.rb +1 -1
  95. data/lib/review/volumeprinter.rb +97 -0
  96. data/lib/review/webmaker.rb +40 -47
  97. data/lib/review/webtocprinter.rb +39 -35
  98. data/lib/review/yamlloader.rb +2 -1
  99. data/review.gemspec +5 -3
  100. data/samples/sample-book/src/config-epub2.yml +1 -1
  101. data/samples/sample-book/src/config.yml +3 -3
  102. data/samples/sample-book/src/lib/tasks/review.rake +19 -1
  103. data/samples/sample-book/src/lib/tasks/z01_copy_sty.rake +2 -1
  104. data/samples/syntax-book/Gemfile +1 -1
  105. data/samples/syntax-book/ch01.re +1 -1
  106. data/samples/syntax-book/ch02.re +21 -6
  107. data/samples/syntax-book/ch03.re +1 -1
  108. data/samples/syntax-book/config.yml +1 -1
  109. data/samples/syntax-book/images/img3-2.png +0 -0
  110. data/samples/syntax-book/lib/tasks/z01_copy_sty.rake +2 -1
  111. data/templates/html/_colophon.html.erb +23 -0
  112. data/templates/html/_colophon_history.html.erb +9 -0
  113. data/templates/html/_cover.html.erb +10 -0
  114. data/templates/html/_part_body.html.erb +6 -0
  115. data/templates/html/_titlepage.html.erb +20 -0
  116. data/templates/html/layout-html5.html.erb +6 -0
  117. data/templates/html/layout-xhtml1.html.erb +6 -0
  118. data/templates/latex/config.erb +35 -23
  119. data/templates/latex/review-jlreq/README.md +3 -1
  120. data/templates/latex/review-jlreq/review-base.sty +36 -23
  121. data/templates/latex/review-jlreq/review-jlreq.cls +18 -25
  122. data/templates/latex/review-jlreq/review-style.sty +6 -1
  123. data/templates/latex/review-jlreq/review-tcbox.sty +348 -0
  124. data/templates/latex/review-jlreq/reviewmacro.sty +5 -0
  125. data/templates/latex/review-jsbook/README.md +7 -5
  126. data/templates/latex/review-jsbook/review-base.sty +40 -24
  127. data/templates/latex/review-jsbook/review-jsbook.cls +13 -3
  128. data/templates/latex/review-jsbook/review-style.sty +6 -1
  129. data/templates/latex/review-jsbook/review-tcbox.sty +348 -0
  130. data/templates/latex/review-jsbook/reviewmacro.sty +5 -0
  131. data/templates/opf/epubv2.opf.erb +7 -7
  132. data/templates/opf/epubv3.opf.erb +7 -7
  133. data/templates/opf/opf_manifest_epubv2.opf.erb +10 -0
  134. data/templates/opf/opf_manifest_epubv3.opf.erb +10 -0
  135. data/templates/opf/opf_metainfo_epubv2.opf.erb +17 -0
  136. data/templates/opf/opf_metainfo_epubv3.opf.erb +49 -0
  137. data/templates/opf/opf_tocx_epubv2.opf.erb +9 -0
  138. data/templates/opf/opf_tocx_epubv3.opf.erb +17 -0
  139. data/templates/web/html/layout-html5.html.erb +9 -8
  140. data/templates/web/html/layout-xhtml1.html.erb +6 -0
  141. data/test/assets/header_listener.html +35 -0
  142. data/test/assets/img_math/img1.png +0 -0
  143. data/test/assets/img_math/img2.png +0 -0
  144. data/test/assets/img_math/img3.png +0 -0
  145. data/test/assets/syntax_book_index_detail.txt +58 -0
  146. data/test/assets/test_template.tex +6 -3
  147. data/test/assets/test_template_backmatter.tex +6 -3
  148. data/test/book_test_helper.rb +11 -5
  149. data/test/run_test.rb +1 -1
  150. data/test/test_book.rb +54 -63
  151. data/test/test_book_chapter.rb +95 -54
  152. data/test/test_book_part.rb +3 -3
  153. data/test/test_builder.rb +29 -20
  154. data/test/test_catalog_converter_cmd.rb +1 -1
  155. data/test/test_converter.rb +1 -0
  156. data/test/test_epub3maker.rb +170 -126
  157. data/test/test_epubmaker.rb +254 -129
  158. data/test/test_epubmaker_cmd.rb +15 -4
  159. data/test/test_helper.rb +12 -5
  160. data/test/test_htmlbuilder.rb +926 -76
  161. data/test/test_htmlutils.rb +0 -12
  162. data/test/test_i18n.rb +33 -33
  163. data/test/test_idgxmlbuilder.rb +531 -20
  164. data/test/test_idgxmlmaker_cmd.rb +7 -3
  165. data/test/test_img_math.rb +111 -0
  166. data/test/test_index.rb +62 -52
  167. data/test/test_indexbuilder.rb +52 -0
  168. data/test/test_latexbuilder.rb +891 -20
  169. data/test/test_latexbuilder_v2.rb +56 -10
  170. data/test/test_lineinput.rb +20 -93
  171. data/test/test_logger.rb +7 -7
  172. data/test/test_makerhelper.rb +0 -12
  173. data/test/test_markdownbuilder.rb +32 -0
  174. data/test/test_pdfmaker.rb +100 -11
  175. data/test/test_pdfmaker_cmd.rb +3 -3
  176. data/test/test_plaintextbuilder.rb +546 -32
  177. data/test/test_preprocessor.rb +188 -1
  178. data/test/test_review_ext.rb +2 -1
  179. data/test/test_reviewheaderlistener.rb +49 -0
  180. data/test/test_rstbuilder.rb +25 -1
  181. data/test/test_sec_counter.rb +156 -0
  182. data/test/test_template.rb +12 -2
  183. data/test/test_textmaker_cmd.rb +5 -1
  184. data/test/test_tocprinter.rb +46 -0
  185. data/test/test_topbuilder.rb +324 -20
  186. data/test/test_update.rb +44 -44
  187. data/test/test_webtocprinter.rb +75 -43
  188. data/test/test_zip_exporter.rb +5 -6
  189. data/vendor/gentombow/LICENSE +1 -1
  190. data/vendor/gentombow/Makefile +0 -1
  191. data/vendor/gentombow/bounddvi-en.pdf +0 -0
  192. data/vendor/gentombow/bounddvi-en.tex +1 -0
  193. data/vendor/gentombow/bounddvi.pdf +0 -0
  194. data/vendor/gentombow/bounddvi.sty +30 -7
  195. data/vendor/gentombow/bounddvi.tex +1 -0
  196. data/vendor/gentombow/create_archive.sh +1 -0
  197. data/vendor/gentombow/gentombow-ja.pdf +0 -0
  198. data/vendor/gentombow/gentombow-ja.tex +9 -0
  199. data/vendor/gentombow/gentombow.pdf +0 -0
  200. data/vendor/gentombow/gentombow.sty +32 -10
  201. data/vendor/gentombow/gentombow.tex +8 -0
  202. data/vendor/gentombow/tests/gentombow-01-pdfx.tex +8 -0
  203. data/vendor/gentombow/tests/gentombow-02-pdfx.tex +8 -0
  204. data/vendor/jsclasses/Makefile +3 -2
  205. data/vendor/jsclasses/create_archive.sh +5 -5
  206. data/vendor/jsclasses/jis/Makefile +3 -2
  207. data/vendor/jsclasses/jis/jsarticle.cls +22 -18
  208. data/vendor/jsclasses/jis/jsbook.cls +22 -18
  209. data/vendor/jsclasses/jis/jsclasses.dtx +94 -13
  210. data/vendor/jsclasses/jis/jsclasses.ins +15 -5
  211. data/vendor/jsclasses/jis/jslogo.ins +9 -0
  212. data/vendor/jsclasses/jis/jslogo.sty +1 -13
  213. data/vendor/jsclasses/jis/jspf.cls +22 -18
  214. data/vendor/jsclasses/jis/jsreport.cls +22 -18
  215. data/vendor/jsclasses/jis/jsverb.ins +9 -0
  216. data/vendor/jsclasses/jis/jsverb.sty +1 -13
  217. data/vendor/jsclasses/jis/kiyou.cls +22 -18
  218. data/vendor/jsclasses/jis/minijs.sty +65 -22
  219. data/vendor/jsclasses/jis/okumacro.ins +9 -0
  220. data/vendor/jsclasses/jis/okumacro.sty +1 -13
  221. data/vendor/jsclasses/jis/okuverb.ins +9 -0
  222. data/vendor/jsclasses/jis/okuverb.sty +1 -13
  223. data/vendor/jsclasses/jis/winjis.sty +23 -19
  224. data/vendor/jsclasses/jsarticle.cls +22 -18
  225. data/vendor/jsclasses/jsbook.cls +22 -18
  226. data/vendor/jsclasses/jsclasses.dtx +94 -13
  227. data/vendor/jsclasses/jsclasses.ins +15 -5
  228. data/vendor/jsclasses/jsclasses.pdf +0 -0
  229. data/vendor/jsclasses/jslogo.ins +9 -0
  230. data/vendor/jsclasses/jslogo.pdf +0 -0
  231. data/vendor/jsclasses/jslogo.sty +1 -13
  232. data/vendor/jsclasses/jspf.cls +22 -18
  233. data/vendor/jsclasses/jsreport.cls +22 -18
  234. data/vendor/jsclasses/jsverb.ins +9 -0
  235. data/vendor/jsclasses/jsverb.pdf +0 -0
  236. data/vendor/jsclasses/jsverb.sty +1 -13
  237. data/vendor/jsclasses/kiyou.cls +22 -18
  238. data/vendor/jsclasses/minijs.sty +68 -22
  239. data/vendor/jsclasses/okumacro.ins +9 -0
  240. data/vendor/jsclasses/okumacro.pdf +0 -0
  241. data/vendor/jsclasses/okumacro.sty +1 -13
  242. data/vendor/jsclasses/okuverb.ins +9 -0
  243. data/vendor/jsclasses/okuverb.pdf +0 -0
  244. data/vendor/jsclasses/okuverb.sty +1 -13
  245. data/vendor/jsclasses/tests/relfont.tex +10 -0
  246. data/vendor/jsclasses/winjis.sty +23 -19
  247. metadata +106 -22
  248. data/.rubocop_todo.yml +0 -7
  249. data/lib/epubmaker.rb +0 -23
  250. data/lib/epubmaker/content.rb +0 -110
  251. data/lib/epubmaker/epubcommon.rb +0 -441
  252. data/lib/epubmaker/epubv2.rb +0 -143
  253. data/lib/epubmaker/epubv3.rb +0 -233
  254. data/lib/epubmaker/producer.rb +0 -375
  255. data/lib/epubmaker/zip_exporter.rb +0 -81
  256. data/lib/lineinput.rb +0 -155
  257. data/lib/review/book/compilable.rb +0 -178
  258. data/lib/review/tocparser.rb +0 -275
  259. data/test/test_tocparser.rb +0 -25
@@ -5,14 +5,14 @@ require 'yaml'
5
5
  require 'rbconfig'
6
6
  require 'open3'
7
7
 
8
- REVIEW_IDGXMLMAKER = File.expand_path('../bin/review-idgxmlmaker', File.dirname(__FILE__))
8
+ REVIEW_IDGXMLMAKER = File.expand_path('../bin/review-idgxmlmaker', __dir__)
9
9
 
10
10
  class IDGXMLMakerCmdTest < Test::Unit::TestCase
11
11
  def setup
12
12
  @tmpdir1 = Dir.mktmpdir
13
13
 
14
14
  @old_rubylib = ENV['RUBYLIB']
15
- ENV['RUBYLIB'] = File.expand_path('../lib', File.dirname(__FILE__))
15
+ ENV['RUBYLIB'] = File.expand_path('../lib', __dir__)
16
16
  end
17
17
 
18
18
  def teardown
@@ -29,7 +29,11 @@ class IDGXMLMakerCmdTest < Test::Unit::TestCase
29
29
  ruby_cmd = File.join(RbConfig::CONFIG['bindir'], RbConfig::CONFIG['ruby_install_name']) + RbConfig::CONFIG['EXEEXT']
30
30
  Dir.chdir(@tmpdir1) do
31
31
  _o, e, s = Open3.capture3("#{ruby_cmd} -S #{REVIEW_IDGXMLMAKER} #{option} #{configfile}")
32
- STDERR.puts e unless e.empty?
32
+ if defined?(ReVIEW::TTYLogger)
33
+ assert_match(/SUCCESS/, e)
34
+ else
35
+ assert_equal '', e
36
+ end
33
37
  assert s.success?
34
38
  end
35
39
  assert File.exist?(File.join(@tmpdir1, targetfile))
@@ -0,0 +1,111 @@
1
+ require 'test_helper'
2
+ require 'review/htmlbuilder'
3
+ require 'review/img_math'
4
+ require 'mini_magick'
5
+
6
+ class ImgMathTest < Test::Unit::TestCase
7
+ def setup
8
+ @config = ReVIEW::Configure.values
9
+ @tmpdir = Dir.mktmpdir
10
+ @config.merge!(
11
+ 'math_format' => 'imgmath',
12
+ 'texcommand' => 'uplatex',
13
+ 'imagedir' => @tmpdir
14
+ )
15
+ @config['imgmath_options']['fontsize'] = 24
16
+ @img_math = ReVIEW::ImgMath.new(@config)
17
+ end
18
+
19
+ def teardown
20
+ @img_math.cleanup_mathimg
21
+ FileUtils.rm_rf(@tmpdir)
22
+ end
23
+
24
+ def test_defer_math_image_pathname
25
+ str1 = '$A > B \\gg C$'
26
+ key1 = Digest::SHA256.hexdigest(str1)
27
+ img_path1 = @img_math.defer_math_image(str1, key1)
28
+
29
+ assert_equal "_gen_#{key1}.png", File.basename(img_path1)
30
+ end
31
+
32
+ def test_defer_math_image
33
+ unless support_latex_in_tests?
34
+ $stderr.puts 'skip test_defer_math_image'
35
+ return true
36
+ end
37
+
38
+ str1 = '$\\sum_{i=1}^nf_n(x) \\in \\mathbb{R}$'
39
+ key1 = Digest::SHA256.hexdigest(str1)
40
+ img_path1 = @img_math.defer_math_image(str1, key1)
41
+ str2 = '$\\sum_{i=1}^nf_n(X) \\in \\mathbb{R}$'
42
+ key2 = Digest::SHA256.hexdigest(str2)
43
+ img_path2 = @img_math.defer_math_image(str2, key2)
44
+ @img_math.make_math_images
45
+
46
+ assert File.exist?(img_path1)
47
+ assert File.exist?(img_path2)
48
+
49
+ val1 = compare_images(img_path1, File.join(assets_dir, 'img_math/img1.png'))
50
+ assert_equal 0, val1
51
+
52
+ val2 = compare_images(img_path2, File.join(assets_dir, 'img_math/img2.png'))
53
+ assert_equal 0, val2
54
+
55
+ val3 = compare_images(img_path1, img_path2)
56
+ assert val3 > 100
57
+ end
58
+
59
+ def test_make_math_image_pathname
60
+ unless support_latex_in_tests?
61
+ $stderr.puts 'skip test_make_math_image_pathname'
62
+ return true
63
+ end
64
+
65
+ str1 = '$A > B \\gg C$'
66
+ key1 = Digest::SHA256.hexdigest(str1)
67
+ img_path1 = @img_math.make_math_image(str1, key1)
68
+
69
+ assert_equal "_gen_#{key1}.png", File.basename(img_path1)
70
+ end
71
+
72
+ def test_make_math_image
73
+ unless support_latex_in_tests?
74
+ $stderr.puts 'skip test_make_math_image'
75
+ return true
76
+ end
77
+ str1 = '$A > B \\gg C$'
78
+ key1 = Digest::SHA256.hexdigest(str1)
79
+ img_path1 = @img_math.make_math_image(str1, key1)
80
+
81
+ assert File.exist?(img_path1)
82
+
83
+ val1 = compare_images(img_path1, File.join(assets_dir, 'img_math/img3.png'))
84
+ assert val1 < 10
85
+ end
86
+
87
+ private
88
+
89
+ def compare_images(image1, image2)
90
+ compare = MiniMagick::Tool::Compare.new(whiny: false)
91
+ compare << '-fuzz'
92
+ compare << '10%'
93
+ compare.metric('AE')
94
+ compare << image1
95
+ compare << image2
96
+ compare << File.join(@tmpdir, 'diff.jpg')
97
+
98
+ compare.call do |_, dist, _|
99
+ return dist.to_i
100
+ end
101
+ end
102
+
103
+ def support_latex_in_tests?
104
+ begin
105
+ `uplatex -v`
106
+ true
107
+ rescue
108
+ false
109
+ end
110
+ end
111
+ end
data/test/test_index.rb CHANGED
@@ -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.lines.to_a, 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.lines, 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.lines.to_a, 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.lines.to_a, 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.lines.to_a, 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.lines.to_a, 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.lines.to_a, 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.lines.to_a, 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.lines.to_a, 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,13 +216,12 @@ 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.lines.to_a, 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
211
223
 
212
- def test_headeline_index11
224
+ def test_headline_index11
213
225
  src = <<-EOB
214
226
  = chap1
215
227
  ==[nodisp] sec01
@@ -220,9 +232,8 @@ class IndexTest < Test::Unit::TestCase
220
232
  ==[nonum] sec03
221
233
  == sec04
222
234
  EOB
223
- book = Book::Base.load
224
- chap = Book::Chapter.new(book, 1, '-', nil)
225
- index = Book::HeadlineIndex.parse(src.lines.to_a, chap)
235
+ compile_block(src)
236
+ index = @chapter.headline_index
226
237
  assert_equal nil, index['sec01'].number
227
238
  assert_equal nil, index['sec02'].number
228
239
  assert_equal [1], index['sec1'].number
@@ -232,7 +243,7 @@ class IndexTest < Test::Unit::TestCase
232
243
  assert_equal [2], index['sec04'].number
233
244
  end
234
245
 
235
- def test_headeline_index12
246
+ def test_headline_index12
236
247
  src = <<-EOB
237
248
  = chap1
238
249
  == A
@@ -240,9 +251,8 @@ class IndexTest < Test::Unit::TestCase
240
251
  ==[nonum] B
241
252
  === B2
242
253
  EOB
243
- book = Book::Base.load
244
- chap = Book::Chapter.new(book, 1, '-', nil)
245
- index = Book::HeadlineIndex.parse(src.lines.to_a, chap)
254
+ compile_block(src)
255
+ index = @chapter.headline_index
246
256
  assert_equal [1], index['A'].number
247
257
  assert_equal [1, 1], index['A2'].number
248
258
  assert_equal nil, index['B'].number
@@ -0,0 +1,52 @@
1
+ require 'test_helper'
2
+ require 'review/builder'
3
+
4
+ require 'review/book'
5
+
6
+ class MockCompiler
7
+ def text(s)
8
+ [:text, s]
9
+ end
10
+ end
11
+
12
+ class IndexBuidlerTest < Test::Unit::TestCase
13
+ include ReVIEW
14
+
15
+ def setup
16
+ @b = IndexBuilder.new
17
+ chap = ReVIEW::Book::Chapter.new(nil, nil, '-', nil)
18
+ @b.bind(MockCompiler.new, chap, nil)
19
+ end
20
+
21
+ def test_initialize
22
+ assert IndexBuilder.new
23
+ end
24
+
25
+ def test_check_id
26
+ io = StringIO.new
27
+ @b.instance_eval { @logger = ReVIEW::Logger.new(io) }
28
+ @b.check_id('ABC')
29
+ assert_match('', io.string)
30
+
31
+ %w(# % \\ { } [ ] ~ / $ ' " | * ? & < > `).each do |c|
32
+ io = StringIO.new
33
+ @b.instance_eval { @logger = ReVIEW::Logger.new(io) }
34
+ @b.check_id("id#{c}")
35
+ assert_match(/deprecated ID: `#{Regexp.escape(c)}` in `id#{Regexp.escape(c)}`/, io.string)
36
+ end
37
+ io = StringIO.new
38
+ @b.instance_eval { @logger = ReVIEW::Logger.new(io) }
39
+ @b.check_id('A B C#')
40
+ assert_match(/deprecated ID: ` ` in `A B C#`/, io.string)
41
+
42
+ io = StringIO.new
43
+ @b.instance_eval { @logger = ReVIEW::Logger.new(io) }
44
+ @b.check_id("A\tB")
45
+ assert_match(/deprecated ID: `\t` in `A\tB`/, io.string)
46
+
47
+ io = StringIO.new
48
+ @b.instance_eval { @logger = ReVIEW::Logger.new(io) }
49
+ @b.check_id('.ABC')
50
+ assert_match(/deprecated ID: `.ABC` begins from `.`/, io.string)
51
+ end
52
+ end