review 4.1.0 → 5.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/ruby-tex.yml +35 -0
- data/.github/workflows/ruby-win.yml +19 -9
- data/.github/workflows/ruby.yml +7 -3
- data/.rubocop.yml +138 -34
- data/NEWS.ja.md +285 -0
- data/NEWS.md +285 -1
- data/README.md +7 -6
- data/Rakefile +7 -2
- data/bin/review +2 -4
- data/bin/review-catalog-converter +4 -4
- data/bin/review-check +8 -12
- data/bin/review-checkdep +2 -5
- data/bin/review-compile +18 -34
- data/bin/review-epub2html +1 -4
- data/bin/review-epubmaker +3 -4
- data/bin/review-idgxmlmaker +1 -3
- data/bin/review-index +5 -86
- data/bin/review-init +1 -4
- data/bin/review-pdfmaker +1 -3
- data/bin/review-preproc +30 -38
- data/bin/review-textmaker +1 -3
- data/bin/review-update +1 -4
- data/bin/review-validate +4 -4
- data/bin/review-vol +5 -82
- data/bin/review-webmaker +1 -3
- data/doc/config.yml.sample +45 -11
- data/doc/config.yml.sample-simple +3 -3
- data/doc/format.ja.md +103 -13
- data/doc/format.md +104 -16
- data/doc/makeindex.ja.md +2 -2
- data/doc/pdfmaker.ja.md +42 -0
- data/doc/pdfmaker.md +41 -0
- data/doc/quickstart.ja.md +19 -6
- data/doc/quickstart.md +18 -6
- data/doc/writing_vertical.ja.md +6 -0
- data/lib/review.rb +1 -1
- data/lib/review/book.rb +2 -2
- data/lib/review/book/base.rb +67 -29
- data/lib/review/book/bib.rb +21 -0
- data/lib/review/book/book_unit.rb +158 -0
- data/lib/review/book/chapter.rb +33 -26
- data/lib/review/book/index.rb +24 -185
- data/lib/review/book/index/item.rb +7 -1
- data/lib/review/book/page_metric.rb +7 -7
- data/lib/review/book/part.rb +26 -11
- data/lib/review/book/volume.rb +5 -5
- data/lib/review/builder.rb +121 -52
- data/lib/review/call_hook.rb +20 -0
- data/lib/review/catalog.rb +3 -2
- data/lib/review/compiler.rb +230 -111
- data/lib/review/configure.rb +91 -7
- data/lib/review/converter.rb +1 -1
- data/lib/review/epub2html.rb +6 -1
- data/lib/review/epubmaker.rb +124 -152
- data/lib/review/epubmaker/content.rb +113 -0
- data/lib/review/epubmaker/epubcommon.rb +372 -0
- data/lib/review/epubmaker/epubv2.rb +178 -0
- data/lib/review/epubmaker/epubv3.rb +231 -0
- data/lib/review/epubmaker/producer.rb +167 -0
- data/lib/review/epubmaker/reviewheaderlistener.rb +12 -2
- data/lib/review/epubmaker/zip_exporter.rb +84 -0
- data/lib/review/exception.rb +13 -0
- data/lib/review/htmlbuilder.rb +176 -89
- data/lib/review/htmlutils.rb +8 -11
- data/lib/review/i18n.rb +2 -1
- data/lib/review/idgxmlbuilder.rb +165 -75
- data/lib/review/idgxmlmaker.rb +24 -28
- data/lib/review/img_math.rb +238 -0
- data/lib/review/index_builder.rb +645 -0
- data/lib/review/init.rb +9 -17
- data/lib/review/latexbox.rb +58 -0
- data/lib/review/latexbuilder.rb +193 -75
- data/lib/review/latexutils.rb +9 -1
- data/lib/review/lineinput.rb +112 -2
- data/lib/review/loggable.rb +27 -0
- data/lib/review/logger.rb +90 -3
- data/lib/review/makerhelper.rb +17 -188
- data/lib/review/markdownbuilder.rb +54 -4
- data/lib/review/pdfmaker.rb +76 -84
- data/lib/review/plaintextbuilder.rb +106 -22
- data/lib/review/preprocessor.rb +107 -303
- data/lib/review/preprocessor/directive.rb +35 -0
- data/lib/review/preprocessor/line.rb +34 -0
- data/lib/review/preprocessor/repository.rb +177 -0
- data/lib/review/rstbuilder.rb +27 -8
- data/lib/review/sec_counter.rb +14 -0
- data/lib/review/template.rb +11 -1
- data/lib/review/textmaker.rb +27 -32
- data/lib/review/textutils.rb +3 -12
- data/lib/review/tocprinter.rb +242 -97
- data/lib/review/topbuilder.rb +98 -31
- data/lib/review/update.rb +12 -13
- data/lib/review/version.rb +1 -1
- data/lib/review/volumeprinter.rb +97 -0
- data/lib/review/webmaker.rb +40 -47
- data/lib/review/webtocprinter.rb +39 -35
- data/lib/review/yamlloader.rb +2 -1
- data/review.gemspec +5 -3
- data/samples/sample-book/src/config-epub2.yml +1 -1
- data/samples/sample-book/src/config.yml +3 -3
- data/samples/sample-book/src/lib/tasks/review.rake +19 -1
- data/samples/sample-book/src/lib/tasks/z01_copy_sty.rake +2 -1
- data/samples/syntax-book/Gemfile +1 -1
- data/samples/syntax-book/ch01.re +1 -1
- data/samples/syntax-book/ch02.re +21 -6
- data/samples/syntax-book/ch03.re +1 -1
- data/samples/syntax-book/config.yml +1 -1
- data/samples/syntax-book/images/img3-2.png +0 -0
- data/samples/syntax-book/lib/tasks/z01_copy_sty.rake +2 -1
- data/templates/html/_colophon.html.erb +23 -0
- data/templates/html/_colophon_history.html.erb +9 -0
- data/templates/html/_cover.html.erb +10 -0
- data/templates/html/_part_body.html.erb +6 -0
- data/templates/html/_titlepage.html.erb +20 -0
- data/templates/html/layout-html5.html.erb +6 -0
- data/templates/html/layout-xhtml1.html.erb +6 -0
- data/templates/latex/config.erb +35 -23
- data/templates/latex/review-jlreq/README.md +3 -1
- data/templates/latex/review-jlreq/review-base.sty +36 -23
- data/templates/latex/review-jlreq/review-jlreq.cls +18 -25
- data/templates/latex/review-jlreq/review-style.sty +6 -1
- data/templates/latex/review-jlreq/review-tcbox.sty +348 -0
- data/templates/latex/review-jlreq/reviewmacro.sty +5 -0
- data/templates/latex/review-jsbook/README.md +7 -5
- data/templates/latex/review-jsbook/review-base.sty +40 -24
- data/templates/latex/review-jsbook/review-jsbook.cls +13 -3
- data/templates/latex/review-jsbook/review-style.sty +6 -1
- data/templates/latex/review-jsbook/review-tcbox.sty +348 -0
- data/templates/latex/review-jsbook/reviewmacro.sty +5 -0
- data/templates/opf/epubv2.opf.erb +7 -7
- data/templates/opf/epubv3.opf.erb +7 -7
- data/templates/opf/opf_manifest_epubv2.opf.erb +10 -0
- data/templates/opf/opf_manifest_epubv3.opf.erb +10 -0
- data/templates/opf/opf_metainfo_epubv2.opf.erb +17 -0
- data/templates/opf/opf_metainfo_epubv3.opf.erb +49 -0
- data/templates/opf/opf_tocx_epubv2.opf.erb +9 -0
- data/templates/opf/opf_tocx_epubv3.opf.erb +17 -0
- data/templates/web/html/layout-html5.html.erb +9 -8
- data/templates/web/html/layout-xhtml1.html.erb +6 -0
- data/test/assets/header_listener.html +35 -0
- data/test/assets/img_math/img1.png +0 -0
- data/test/assets/img_math/img2.png +0 -0
- data/test/assets/img_math/img3.png +0 -0
- data/test/assets/syntax_book_index_detail.txt +58 -0
- data/test/assets/test_template.tex +6 -3
- data/test/assets/test_template_backmatter.tex +6 -3
- data/test/book_test_helper.rb +11 -5
- data/test/run_test.rb +1 -1
- data/test/test_book.rb +54 -63
- data/test/test_book_chapter.rb +95 -54
- data/test/test_book_part.rb +3 -3
- data/test/test_builder.rb +29 -20
- data/test/test_catalog_converter_cmd.rb +1 -1
- data/test/test_converter.rb +1 -0
- data/test/test_epub3maker.rb +170 -126
- data/test/test_epubmaker.rb +254 -129
- data/test/test_epubmaker_cmd.rb +15 -4
- data/test/test_helper.rb +12 -5
- data/test/test_htmlbuilder.rb +926 -76
- data/test/test_htmlutils.rb +0 -12
- data/test/test_i18n.rb +33 -33
- data/test/test_idgxmlbuilder.rb +531 -20
- data/test/test_idgxmlmaker_cmd.rb +7 -3
- data/test/test_img_math.rb +111 -0
- data/test/test_index.rb +62 -52
- data/test/test_indexbuilder.rb +52 -0
- data/test/test_latexbuilder.rb +891 -20
- data/test/test_latexbuilder_v2.rb +56 -10
- data/test/test_lineinput.rb +20 -93
- data/test/test_logger.rb +7 -7
- data/test/test_makerhelper.rb +0 -12
- data/test/test_markdownbuilder.rb +32 -0
- data/test/test_pdfmaker.rb +100 -11
- data/test/test_pdfmaker_cmd.rb +3 -3
- data/test/test_plaintextbuilder.rb +546 -32
- data/test/test_preprocessor.rb +188 -1
- data/test/test_review_ext.rb +2 -1
- data/test/test_reviewheaderlistener.rb +49 -0
- data/test/test_rstbuilder.rb +25 -1
- data/test/test_sec_counter.rb +156 -0
- data/test/test_template.rb +12 -2
- data/test/test_textmaker_cmd.rb +5 -1
- data/test/test_tocprinter.rb +46 -0
- data/test/test_topbuilder.rb +324 -20
- data/test/test_update.rb +44 -44
- data/test/test_webtocprinter.rb +75 -43
- data/test/test_zip_exporter.rb +5 -6
- data/vendor/gentombow/LICENSE +1 -1
- data/vendor/gentombow/Makefile +0 -1
- data/vendor/gentombow/bounddvi-en.pdf +0 -0
- data/vendor/gentombow/bounddvi-en.tex +1 -0
- data/vendor/gentombow/bounddvi.pdf +0 -0
- data/vendor/gentombow/bounddvi.sty +30 -7
- data/vendor/gentombow/bounddvi.tex +1 -0
- data/vendor/gentombow/create_archive.sh +1 -0
- data/vendor/gentombow/gentombow-ja.pdf +0 -0
- data/vendor/gentombow/gentombow-ja.tex +9 -0
- data/vendor/gentombow/gentombow.pdf +0 -0
- data/vendor/gentombow/gentombow.sty +32 -10
- data/vendor/gentombow/gentombow.tex +8 -0
- data/vendor/gentombow/tests/gentombow-01-pdfx.tex +8 -0
- data/vendor/gentombow/tests/gentombow-02-pdfx.tex +8 -0
- data/vendor/jsclasses/Makefile +3 -2
- data/vendor/jsclasses/create_archive.sh +5 -5
- data/vendor/jsclasses/jis/Makefile +3 -2
- data/vendor/jsclasses/jis/jsarticle.cls +22 -18
- data/vendor/jsclasses/jis/jsbook.cls +22 -18
- data/vendor/jsclasses/jis/jsclasses.dtx +94 -13
- data/vendor/jsclasses/jis/jsclasses.ins +15 -5
- data/vendor/jsclasses/jis/jslogo.ins +9 -0
- data/vendor/jsclasses/jis/jslogo.sty +1 -13
- data/vendor/jsclasses/jis/jspf.cls +22 -18
- data/vendor/jsclasses/jis/jsreport.cls +22 -18
- data/vendor/jsclasses/jis/jsverb.ins +9 -0
- data/vendor/jsclasses/jis/jsverb.sty +1 -13
- data/vendor/jsclasses/jis/kiyou.cls +22 -18
- data/vendor/jsclasses/jis/minijs.sty +65 -22
- data/vendor/jsclasses/jis/okumacro.ins +9 -0
- data/vendor/jsclasses/jis/okumacro.sty +1 -13
- data/vendor/jsclasses/jis/okuverb.ins +9 -0
- data/vendor/jsclasses/jis/okuverb.sty +1 -13
- data/vendor/jsclasses/jis/winjis.sty +23 -19
- data/vendor/jsclasses/jsarticle.cls +22 -18
- data/vendor/jsclasses/jsbook.cls +22 -18
- data/vendor/jsclasses/jsclasses.dtx +94 -13
- data/vendor/jsclasses/jsclasses.ins +15 -5
- data/vendor/jsclasses/jsclasses.pdf +0 -0
- data/vendor/jsclasses/jslogo.ins +9 -0
- data/vendor/jsclasses/jslogo.pdf +0 -0
- data/vendor/jsclasses/jslogo.sty +1 -13
- data/vendor/jsclasses/jspf.cls +22 -18
- data/vendor/jsclasses/jsreport.cls +22 -18
- data/vendor/jsclasses/jsverb.ins +9 -0
- data/vendor/jsclasses/jsverb.pdf +0 -0
- data/vendor/jsclasses/jsverb.sty +1 -13
- data/vendor/jsclasses/kiyou.cls +22 -18
- data/vendor/jsclasses/minijs.sty +68 -22
- data/vendor/jsclasses/okumacro.ins +9 -0
- data/vendor/jsclasses/okumacro.pdf +0 -0
- data/vendor/jsclasses/okumacro.sty +1 -13
- data/vendor/jsclasses/okuverb.ins +9 -0
- data/vendor/jsclasses/okuverb.pdf +0 -0
- data/vendor/jsclasses/okuverb.sty +1 -13
- data/vendor/jsclasses/tests/relfont.tex +10 -0
- data/vendor/jsclasses/winjis.sty +23 -19
- metadata +106 -22
- data/.rubocop_todo.yml +0 -7
- data/lib/epubmaker.rb +0 -23
- data/lib/epubmaker/content.rb +0 -110
- data/lib/epubmaker/epubcommon.rb +0 -441
- data/lib/epubmaker/epubv2.rb +0 -143
- data/lib/epubmaker/epubv3.rb +0 -233
- data/lib/epubmaker/producer.rb +0 -375
- data/lib/epubmaker/zip_exporter.rb +0 -81
- data/lib/lineinput.rb +0 -155
- data/lib/review/book/compilable.rb +0 -178
- data/lib/review/tocparser.rb +0 -275
- 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',
|
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',
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
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
|
-
|
56
|
-
|
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
|
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
|
-
|
73
|
-
|
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
|
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
|
-
|
91
|
-
|
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
|
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
|
-
|
110
|
-
|
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
|
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
|
-
|
126
|
-
|
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
|
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
|
-
|
141
|
-
|
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
|
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
|
-
|
159
|
-
|
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
|
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
|
-
|
176
|
-
|
177
|
-
|
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
|
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
|
-
|
192
|
-
|
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
|
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
|
-
|
207
|
-
|
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
|
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
|
-
|
224
|
-
|
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
|
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
|
-
|
244
|
-
|
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
|