review 4.0.0 → 5.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (268) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ruby-tex.yml +31 -0
  3. data/.github/workflows/ruby-win.yml +45 -0
  4. data/.github/workflows/ruby.yml +27 -0
  5. data/.rubocop.yml +141 -38
  6. data/Dockerfile +21 -5
  7. data/NEWS.ja.md +338 -1
  8. data/NEWS.md +339 -2
  9. data/README.md +11 -7
  10. data/Rakefile +7 -2
  11. data/appveyor.yml +0 -20
  12. data/bin/review +2 -4
  13. data/bin/review-catalog-converter +4 -4
  14. data/bin/review-check +8 -12
  15. data/bin/review-checkdep +2 -5
  16. data/bin/review-compile +11 -20
  17. data/bin/review-epub2html +1 -4
  18. data/bin/review-epubmaker +3 -4
  19. data/bin/review-idgxmlmaker +1 -3
  20. data/bin/review-index +5 -86
  21. data/bin/review-init +1 -4
  22. data/bin/review-pdfmaker +1 -3
  23. data/bin/review-preproc +3 -5
  24. data/bin/review-textmaker +1 -3
  25. data/bin/review-update +1 -4
  26. data/bin/review-validate +5 -5
  27. data/bin/review-vol +5 -82
  28. data/bin/review-webmaker +1 -3
  29. data/doc/config.yml.sample +55 -12
  30. data/doc/config.yml.sample-simple +4 -3
  31. data/doc/format.ja.md +119 -17
  32. data/doc/format.md +106 -17
  33. data/doc/makeindex.ja.md +2 -2
  34. data/doc/pdfmaker.ja.md +42 -0
  35. data/doc/pdfmaker.md +41 -0
  36. data/doc/quickstart.ja.md +55 -25
  37. data/doc/quickstart.md +47 -17
  38. data/lib/review.rb +1 -1
  39. data/lib/review/book.rb +2 -2
  40. data/lib/review/book/base.rb +69 -30
  41. data/lib/review/book/bib.rb +21 -0
  42. data/lib/review/book/book_unit.rb +158 -0
  43. data/lib/review/book/chapter.rb +33 -26
  44. data/lib/review/book/index.rb +39 -206
  45. data/lib/review/book/index/item.rb +8 -2
  46. data/lib/review/book/page_metric.rb +7 -7
  47. data/lib/review/book/part.rb +26 -11
  48. data/lib/review/book/volume.rb +5 -5
  49. data/lib/review/builder.rb +124 -27
  50. data/lib/review/call_hook.rb +20 -0
  51. data/lib/review/catalog.rb +3 -2
  52. data/lib/review/compiler.rb +197 -91
  53. data/lib/review/configure.rb +95 -9
  54. data/lib/review/converter.rb +1 -1
  55. data/lib/review/epub2html.rb +6 -1
  56. data/lib/review/epubmaker.rb +116 -117
  57. data/lib/review/epubmaker/content.rb +113 -0
  58. data/lib/review/epubmaker/epubcommon.rb +372 -0
  59. data/lib/review/epubmaker/epubv2.rb +178 -0
  60. data/lib/review/epubmaker/epubv3.rb +231 -0
  61. data/lib/review/epubmaker/producer.rb +168 -0
  62. data/lib/review/epubmaker/reviewheaderlistener.rb +12 -2
  63. data/lib/review/epubmaker/zip_exporter.rb +84 -0
  64. data/lib/review/exception.rb +6 -0
  65. data/lib/review/extentions/string.rb +0 -4
  66. data/lib/review/htmlbuilder.rb +132 -87
  67. data/lib/review/htmlutils.rb +8 -11
  68. data/lib/review/i18n.rb +2 -1
  69. data/lib/review/idgxmlbuilder.rb +156 -76
  70. data/lib/review/idgxmlmaker.rb +22 -18
  71. data/lib/review/img_math.rb +245 -0
  72. data/lib/review/index_builder.rb +654 -0
  73. data/lib/review/init.rb +17 -18
  74. data/lib/review/latexbox.rb +58 -0
  75. data/lib/review/latexbuilder.rb +173 -43
  76. data/lib/review/latexutils.rb +9 -1
  77. data/lib/review/lineinput.rb +112 -2
  78. data/lib/review/logger.rb +42 -3
  79. data/lib/review/makerhelper.rb +12 -187
  80. data/lib/review/markdownbuilder.rb +51 -2
  81. data/lib/review/pdfmaker.rb +78 -73
  82. data/lib/review/plaintextbuilder.rb +98 -14
  83. data/lib/review/preprocessor.rb +18 -12
  84. data/lib/review/rstbuilder.rb +28 -9
  85. data/lib/review/sec_counter.rb +14 -0
  86. data/lib/review/template.rb +6 -0
  87. data/lib/review/textmaker.rb +21 -19
  88. data/lib/review/textutils.rb +3 -12
  89. data/lib/review/tocprinter.rb +242 -97
  90. data/lib/review/topbuilder.rb +91 -24
  91. data/lib/review/update.rb +12 -13
  92. data/lib/review/version.rb +1 -1
  93. data/lib/review/volumeprinter.rb +97 -0
  94. data/lib/review/webmaker.rb +34 -33
  95. data/lib/review/webtocprinter.rb +39 -35
  96. data/lib/review/yamlloader.rb +2 -1
  97. data/review.gemspec +5 -3
  98. data/samples/sample-book/src/.gitignore +1 -0
  99. data/samples/sample-book/src/config-ebook.yml +4 -0
  100. data/samples/sample-book/src/config-epub2.yml +1 -1
  101. data/samples/sample-book/src/config-jlreq-ebook.yml +4 -0
  102. data/samples/sample-book/src/config.yml +3 -3
  103. data/samples/sample-book/src/lib/tasks/review.rake +26 -6
  104. data/samples/syntax-book/Gemfile +1 -1
  105. data/samples/syntax-book/ch01.re +3 -1
  106. data/samples/syntax-book/ch02.re +28 -21
  107. data/samples/syntax-book/ch03.re +1 -1
  108. data/samples/syntax-book/config-jlreq-lualatex.yml +4 -0
  109. data/samples/syntax-book/config-print.yml +3 -0
  110. data/samples/syntax-book/config.yml +1 -1
  111. data/samples/syntax-book/images/img3-2.png +0 -0
  112. data/samples/syntax-book/lib/tasks/review.rake +23 -8
  113. data/templates/html/_colophon.html.erb +23 -0
  114. data/templates/html/_colophon_history.html.erb +9 -0
  115. data/templates/html/_cover.html.erb +10 -0
  116. data/templates/html/_part_body.html.erb +6 -0
  117. data/templates/html/_titlepage.html.erb +20 -0
  118. data/templates/html/layout-html5.html.erb +6 -0
  119. data/templates/html/layout-xhtml1.html.erb +6 -0
  120. data/templates/latex/config.erb +41 -29
  121. data/templates/latex/review-jlreq/README.md +3 -1
  122. data/templates/latex/review-jlreq/review-base.sty +47 -22
  123. data/templates/latex/review-jlreq/review-jlreq.cls +25 -24
  124. data/templates/latex/review-jlreq/review-style.sty +6 -1
  125. data/templates/latex/review-jlreq/review-tcbox.sty +348 -0
  126. data/templates/latex/review-jlreq/reviewmacro.sty +5 -0
  127. data/templates/latex/review-jsbook/README.md +7 -5
  128. data/templates/latex/review-jsbook/review-base.sty +47 -21
  129. data/templates/latex/review-jsbook/review-jsbook.cls +12 -2
  130. data/templates/latex/review-jsbook/review-style.sty +6 -1
  131. data/templates/latex/review-jsbook/review-tcbox.sty +348 -0
  132. data/templates/latex/review-jsbook/reviewmacro.sty +5 -0
  133. data/templates/opf/epubv2.opf.erb +7 -7
  134. data/templates/opf/epubv3.opf.erb +7 -7
  135. data/templates/opf/opf_manifest_epubv2.opf.erb +10 -0
  136. data/templates/opf/opf_manifest_epubv3.opf.erb +10 -0
  137. data/templates/opf/opf_metainfo_epubv2.opf.erb +17 -0
  138. data/templates/opf/opf_metainfo_epubv3.opf.erb +49 -0
  139. data/templates/opf/opf_tocx_epubv2.opf.erb +9 -0
  140. data/templates/opf/opf_tocx_epubv3.opf.erb +17 -0
  141. data/templates/web/html/layout-html5.html.erb +9 -8
  142. data/templates/web/html/layout-xhtml1.html.erb +6 -0
  143. data/test/assets/header_listener.html +35 -0
  144. data/test/assets/img_math/img1.png +0 -0
  145. data/test/assets/img_math/img2.png +0 -0
  146. data/test/assets/img_math/img3.png +0 -0
  147. data/test/assets/syntax_book_index_detail.txt +58 -0
  148. data/test/assets/test_template.tex +12 -9
  149. data/test/assets/test_template_backmatter.tex +12 -9
  150. data/test/book_test_helper.rb +11 -5
  151. data/test/run_test.rb +1 -1
  152. data/test/test_book.rb +62 -63
  153. data/test/test_book_chapter.rb +99 -56
  154. data/test/test_book_part.rb +3 -3
  155. data/test/test_builder.rb +24 -15
  156. data/test/test_catalog.rb +1 -0
  157. data/test/test_catalog_converter_cmd.rb +1 -1
  158. data/test/test_converter.rb +1 -0
  159. data/test/test_epub3maker.rb +170 -126
  160. data/test/test_epubmaker.rb +249 -129
  161. data/test/test_epubmaker_cmd.rb +14 -7
  162. data/test/test_helper.rb +23 -11
  163. data/test/test_htmlbuilder.rb +956 -76
  164. data/test/test_htmlutils.rb +0 -12
  165. data/test/test_i18n.rb +33 -33
  166. data/test/test_idgxmlbuilder.rb +568 -10
  167. data/test/test_idgxmlmaker_cmd.rb +50 -0
  168. data/test/test_image_finder.rb +52 -70
  169. data/test/test_img_math.rb +111 -0
  170. data/test/test_index.rb +62 -52
  171. data/test/test_indexbuilder.rb +52 -0
  172. data/test/test_latexbuilder.rb +1056 -30
  173. data/test/test_latexbuilder_v2.rb +52 -12
  174. data/test/test_lineinput.rb +20 -93
  175. data/test/test_logger.rb +7 -7
  176. data/test/test_makerhelper.rb +0 -12
  177. data/test/test_markdownbuilder.rb +32 -0
  178. data/test/test_pdfmaker.rb +100 -11
  179. data/test/test_pdfmaker_cmd.rb +101 -7
  180. data/test/test_plaintextbuilder.rb +531 -25
  181. data/test/test_review_ext.rb +2 -1
  182. data/test/test_reviewheaderlistener.rb +49 -0
  183. data/test/test_rstbuilder.rb +25 -1
  184. data/test/test_sec_counter.rb +156 -0
  185. data/test/test_template.rb +12 -2
  186. data/test/test_textmaker_cmd.rb +58 -0
  187. data/test/test_tocprinter.rb +46 -0
  188. data/test/test_topbuilder.rb +365 -10
  189. data/test/test_update.rb +44 -44
  190. data/test/test_webtocprinter.rb +75 -43
  191. data/test/test_zip_exporter.rb +5 -6
  192. data/vendor/gentombow/LICENSE +1 -1
  193. data/vendor/gentombow/Makefile +0 -1
  194. data/vendor/gentombow/bounddvi-en.pdf +0 -0
  195. data/vendor/gentombow/bounddvi-en.tex +1 -0
  196. data/vendor/gentombow/bounddvi.pdf +0 -0
  197. data/vendor/gentombow/bounddvi.sty +30 -7
  198. data/vendor/gentombow/bounddvi.tex +1 -0
  199. data/vendor/gentombow/create_archive.sh +1 -0
  200. data/vendor/gentombow/gentombow-ja.pdf +0 -0
  201. data/vendor/gentombow/gentombow-ja.tex +9 -0
  202. data/vendor/gentombow/gentombow.pdf +0 -0
  203. data/vendor/gentombow/gentombow.sty +32 -10
  204. data/vendor/gentombow/gentombow.tex +8 -0
  205. data/vendor/gentombow/tests/gentombow-01-pdfx.tex +8 -0
  206. data/vendor/gentombow/tests/gentombow-02-pdfx.tex +8 -0
  207. data/vendor/jsclasses/LICENSE +1 -1
  208. data/vendor/jsclasses/Makefile +3 -2
  209. data/vendor/jsclasses/create_archive.sh +5 -5
  210. data/vendor/jsclasses/jis/Makefile +3 -2
  211. data/vendor/jsclasses/jis/jsarticle.cls +74 -31
  212. data/vendor/jsclasses/jis/jsbook.cls +74 -31
  213. data/vendor/jsclasses/jis/jsclasses.dtx +176 -36
  214. data/vendor/jsclasses/jis/jsclasses.ins +15 -5
  215. data/vendor/jsclasses/jis/jslogo.dtx +4 -4
  216. data/vendor/jsclasses/jis/jslogo.ins +9 -0
  217. data/vendor/jsclasses/jis/jslogo.sty +4 -16
  218. data/vendor/jsclasses/jis/jspf.cls +73 -30
  219. data/vendor/jsclasses/jis/jsreport.cls +74 -31
  220. data/vendor/jsclasses/jis/jsverb.ins +9 -0
  221. data/vendor/jsclasses/jis/jsverb.sty +1 -13
  222. data/vendor/jsclasses/jis/kiyou.cls +74 -31
  223. data/vendor/jsclasses/jis/minijs.sty +65 -22
  224. data/vendor/jsclasses/jis/okumacro.dtx +4 -5
  225. data/vendor/jsclasses/jis/okumacro.ins +9 -0
  226. data/vendor/jsclasses/jis/okumacro.sty +4 -17
  227. data/vendor/jsclasses/jis/okuverb.ins +9 -0
  228. data/vendor/jsclasses/jis/okuverb.sty +1 -13
  229. data/vendor/jsclasses/jis/winjis.sty +23 -19
  230. data/vendor/jsclasses/jsarticle.cls +74 -31
  231. data/vendor/jsclasses/jsbook.cls +74 -31
  232. data/vendor/jsclasses/jsclasses.dtx +176 -36
  233. data/vendor/jsclasses/jsclasses.ins +15 -5
  234. data/vendor/jsclasses/jsclasses.pdf +0 -0
  235. data/vendor/jsclasses/jslogo.dtx +4 -4
  236. data/vendor/jsclasses/jslogo.ins +9 -0
  237. data/vendor/jsclasses/jslogo.pdf +0 -0
  238. data/vendor/jsclasses/jslogo.sty +4 -16
  239. data/vendor/jsclasses/jspf.cls +73 -30
  240. data/vendor/jsclasses/jsreport.cls +74 -31
  241. data/vendor/jsclasses/jsverb.ins +9 -0
  242. data/vendor/jsclasses/jsverb.pdf +0 -0
  243. data/vendor/jsclasses/jsverb.sty +1 -13
  244. data/vendor/jsclasses/kiyou.cls +74 -31
  245. data/vendor/jsclasses/minijs.sty +68 -22
  246. data/vendor/jsclasses/okumacro.dtx +4 -5
  247. data/vendor/jsclasses/okumacro.ins +9 -0
  248. data/vendor/jsclasses/okumacro.pdf +0 -0
  249. data/vendor/jsclasses/okumacro.sty +4 -17
  250. data/vendor/jsclasses/okuverb.ins +9 -0
  251. data/vendor/jsclasses/okuverb.pdf +0 -0
  252. data/vendor/jsclasses/okuverb.sty +1 -13
  253. data/vendor/jsclasses/tests/relfont.tex +10 -0
  254. data/vendor/jsclasses/winjis.sty +23 -19
  255. metadata +109 -20
  256. data/.rubocop_todo.yml +0 -7
  257. data/lib/epubmaker.rb +0 -23
  258. data/lib/epubmaker/content.rb +0 -110
  259. data/lib/epubmaker/epubcommon.rb +0 -441
  260. data/lib/epubmaker/epubv2.rb +0 -143
  261. data/lib/epubmaker/epubv3.rb +0 -233
  262. data/lib/epubmaker/producer.rb +0 -375
  263. data/lib/epubmaker/zip_exporter.rb +0 -81
  264. data/lib/lineinput.rb +0 -155
  265. data/lib/review/book/compilable.rb +0 -178
  266. data/lib/review/tocparser.rb +0 -271
  267. data/samples/syntax-book/review-ext.rb +0 -14
  268. data/test/test_tocparser.rb +0 -25
@@ -0,0 +1,50 @@
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', __dir__)
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', __dir__)
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
+ if defined?(ReVIEW::TTYLogger)
33
+ assert_match(/SUCCESS/, e)
34
+ else
35
+ assert_equal '', e
36
+ end
37
+ assert s.success?
38
+ end
39
+ assert File.exist?(File.join(@tmpdir1, targetfile))
40
+ end
41
+ end
42
+
43
+ def test_idgxmlmaker_cmd_samplebook
44
+ common_buildidgxml('sample-book/src', 'config.yml', 'book-idgxml/ch01.xml', nil)
45
+ end
46
+
47
+ def test_idgxmlmaker_cmd_syntaxbook
48
+ common_buildidgxml('syntax-book', 'config.yml', 'syntax-book-idgxml/ch01.xml', nil)
49
+ end
50
+ 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
@@ -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, 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,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, 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, 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, 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