review 3.1.0 → 5.0.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-win.yml +45 -0
- data/.github/workflows/ruby.yml +27 -0
- data/.rubocop.yml +161 -34
- data/.travis.yml +16 -15
- data/Dockerfile +21 -5
- data/NEWS.ja.md +394 -0
- data/NEWS.md +395 -1
- data/README.md +10 -7
- data/appveyor.yml +1 -3
- data/bin/review-catalog-converter +5 -5
- data/bin/review-check +10 -12
- data/bin/review-checkdep +2 -2
- data/bin/review-compile +17 -23
- data/bin/review-epubmaker +3 -35
- data/bin/review-idgxmlmaker +16 -0
- data/bin/review-index +2 -89
- data/bin/review-preproc +13 -13
- data/bin/review-validate +4 -4
- data/bin/review-vol +4 -78
- data/doc/config.yml.sample +47 -12
- data/doc/config.yml.sample-simple +3 -2
- data/doc/format.ja.md +120 -17
- data/doc/format.md +119 -27
- data/doc/makeindex.ja.md +2 -2
- data/doc/pdfmaker.ja.md +43 -1
- data/doc/pdfmaker.md +42 -1
- data/doc/quickstart.ja.md +45 -25
- data/doc/quickstart.md +37 -16
- data/lib/epubmaker/content.rb +3 -2
- data/lib/epubmaker/epubcommon.rb +34 -27
- data/lib/epubmaker/epubv2.rb +5 -6
- data/lib/epubmaker/epubv3.rb +21 -18
- data/lib/epubmaker/producer.rb +2 -1
- data/lib/review/book.rb +2 -2
- data/lib/review/book/base.rb +91 -96
- data/lib/review/book/bib.rb +21 -0
- data/lib/review/book/book_unit.rb +155 -0
- data/lib/review/book/chapter.rb +48 -29
- data/lib/review/book/index.rb +46 -240
- data/lib/review/book/index/item.rb +46 -0
- data/lib/review/book/page_metric.rb +7 -7
- data/lib/review/book/part.rb +45 -10
- data/lib/review/book/volume.rb +4 -5
- data/lib/review/builder.rb +172 -56
- data/lib/review/catalog.rb +14 -17
- data/lib/review/compiler.rb +219 -121
- data/lib/review/configure.rb +39 -7
- data/lib/review/converter.rb +1 -1
- data/lib/review/epub2html.rb +43 -5
- data/lib/review/epubmaker.rb +69 -27
- data/lib/review/extentions/string.rb +0 -4
- data/lib/review/htmlbuilder.rb +112 -101
- data/lib/review/htmlutils.rb +9 -13
- data/lib/review/i18n.rb +3 -3
- data/lib/review/idgxmlbuilder.rb +202 -78
- data/lib/review/idgxmlmaker.rb +186 -0
- data/lib/review/index_builder.rb +653 -0
- data/lib/review/init-web/finish.html +10 -0
- data/lib/review/init-web/index.html +190 -0
- data/lib/review/init-web/review-layout-design.js +691 -0
- data/lib/review/init.rb +129 -46
- data/lib/review/latexbuilder.rb +255 -92
- data/lib/review/lineinput.rb +1 -1
- data/lib/review/location.rb +32 -0
- data/lib/review/logger.rb +4 -8
- data/lib/review/makerhelper.rb +35 -5
- data/lib/review/markdownbuilder.rb +50 -38
- data/lib/review/md2inaobuilder.rb +3 -5
- data/lib/review/pdfmaker.rb +60 -57
- data/lib/review/plaintextbuilder.rb +154 -87
- data/lib/review/preprocessor.rb +20 -42
- data/lib/review/rstbuilder.rb +57 -38
- data/lib/review/sec_counter.rb +13 -0
- data/lib/review/textmaker.rb +23 -15
- data/lib/review/textutils.rb +76 -2
- data/lib/review/tocprinter.rb +230 -102
- data/lib/review/topbuilder.rb +139 -60
- data/lib/review/update.rb +24 -24
- data/lib/review/version.rb +1 -1
- data/lib/review/volumeprinter.rb +98 -0
- data/lib/review/webmaker.rb +20 -24
- data/lib/review/webtocprinter.rb +38 -35
- data/lib/review/yamlloader.rb +26 -16
- data/review.gemspec +6 -4
- data/samples/sample-book/README.md +7 -2
- data/samples/sample-book/src/.gitignore +154 -0
- data/samples/sample-book/src/config-ebook.yml +4 -0
- data/samples/sample-book/src/config-jlreq-ebook.yml +4 -0
- data/samples/sample-book/src/config-jlreq.yml +6 -0
- data/samples/sample-book/src/config.yml +2 -2
- data/samples/sample-book/src/lib/tasks/review.rake +29 -14
- data/samples/sample-book/src/lib/tasks/z01_copy_sty.rake +14 -8
- data/samples/syntax-book/Gemfile +1 -1
- data/samples/syntax-book/ch01.re +4 -2
- data/samples/syntax-book/ch02.re +8 -16
- data/samples/syntax-book/ch03.re +3 -6
- data/samples/syntax-book/config-jlreq-lualatex.yml +4 -0
- data/samples/syntax-book/config-jlreq.yml +5 -0
- data/samples/syntax-book/config-print.yml +3 -0
- data/samples/syntax-book/config.yml +1 -1
- data/samples/syntax-book/lib/tasks/review.rake +30 -15
- data/samples/syntax-book/lib/tasks/z01_copy_sty.rake +14 -8
- data/templates/latex/config.erb +39 -25
- data/templates/latex/layout.tex.erb +1 -0
- data/templates/latex/review-jlreq/README.md +3 -1
- data/templates/latex/review-jlreq/review-base.sty +161 -50
- data/templates/latex/review-jlreq/review-jlreq.cls +21 -22
- data/templates/latex/review-jlreq/review-style.sty +4 -1
- data/templates/latex/review-jsbook/README.md +46 -5
- data/templates/latex/review-jsbook/review-base.sty +123 -35
- data/templates/latex/review-jsbook/review-jsbook.cls +10 -4
- data/templates/latex/review-jsbook/review-style.sty +5 -2
- data/templates/opf/epubv3.opf.erb +1 -0
- data/templates/web/html/layout-html5.html.erb +3 -3
- data/test/assets/test_template.tex +19 -7
- data/test/assets/test_template_backmatter.tex +19 -7
- data/test/book_test_helper.rb +11 -5
- data/test/test_book.rb +124 -79
- data/test/test_book_chapter.rb +97 -54
- data/test/test_book_part.rb +3 -3
- data/test/test_builder.rb +38 -13
- data/test/test_catalog.rb +24 -42
- data/test/test_catalog_converter_cmd.rb +1 -1
- data/test/test_converter.rb +1 -0
- data/test/test_epub3maker.rb +2 -2
- data/test/test_epubmaker.rb +8 -0
- data/test/test_epubmaker_cmd.rb +14 -7
- data/test/test_helper.rb +18 -7
- data/test/test_htmlbuilder.rb +1491 -205
- data/test/test_htmlutils.rb +0 -12
- data/test/test_i18n.rb +37 -37
- data/test/test_idgxmlbuilder.rb +744 -42
- data/test/test_idgxmlmaker_cmd.rb +46 -0
- data/test/test_image_finder.rb +52 -70
- data/test/test_index.rb +94 -44
- data/test/test_indexbuilder.rb +52 -0
- data/test/test_latexbuilder.rb +1784 -161
- data/test/test_latexbuilder_v2.rb +671 -102
- data/test/test_logger.rb +17 -4
- data/test/test_makerhelper.rb +2 -14
- data/test/test_markdownbuilder.rb +137 -16
- data/test/test_md2inaobuilder.rb +32 -9
- data/test/test_pdfmaker.rb +30 -12
- data/test/test_pdfmaker_cmd.rb +100 -6
- data/test/test_plaintextbuilder.rb +791 -30
- data/test/test_preprocessor.rb +2 -16
- data/test/test_review_ext.rb +2 -1
- data/test/test_rstbuilder.rb +274 -27
- data/test/test_sec_counter.rb +156 -0
- data/test/test_textmaker_cmd.rb +54 -0
- data/test/test_textutils.rb +109 -2
- data/test/test_topbuilder.rb +724 -34
- data/test/test_update.rb +20 -11
- data/test/test_webtocprinter.rb +75 -43
- data/test/test_yamlloader.rb +13 -0
- 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/LICENSE +1 -1
- 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 +74 -31
- data/vendor/jsclasses/jis/jsbook.cls +74 -31
- data/vendor/jsclasses/jis/jsclasses.dtx +176 -36
- data/vendor/jsclasses/jis/jsclasses.ins +15 -5
- data/vendor/jsclasses/jis/jslogo.dtx +4 -4
- data/vendor/jsclasses/jis/jslogo.ins +9 -0
- data/vendor/jsclasses/jis/jslogo.sty +4 -16
- data/vendor/jsclasses/jis/jspf.cls +73 -30
- data/vendor/jsclasses/jis/jsreport.cls +74 -31
- data/vendor/jsclasses/jis/jsverb.ins +9 -0
- data/vendor/jsclasses/jis/jsverb.sty +1 -13
- data/vendor/jsclasses/jis/kiyou.cls +74 -31
- data/vendor/jsclasses/jis/minijs.sty +65 -22
- data/vendor/jsclasses/jis/okumacro.dtx +4 -5
- data/vendor/jsclasses/jis/okumacro.ins +9 -0
- data/vendor/jsclasses/jis/okumacro.sty +4 -17
- 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 +74 -31
- data/vendor/jsclasses/jsbook.cls +74 -31
- data/vendor/jsclasses/jsclasses.dtx +176 -36
- data/vendor/jsclasses/jsclasses.ins +15 -5
- data/vendor/jsclasses/jsclasses.pdf +0 -0
- data/vendor/jsclasses/jslogo.dtx +4 -4
- data/vendor/jsclasses/jslogo.ins +9 -0
- data/vendor/jsclasses/jslogo.pdf +0 -0
- data/vendor/jsclasses/jslogo.sty +4 -16
- data/vendor/jsclasses/jspf.cls +73 -30
- data/vendor/jsclasses/jsreport.cls +74 -31
- 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 +74 -31
- data/vendor/jsclasses/minijs.sty +68 -22
- data/vendor/jsclasses/okumacro.dtx +4 -5
- data/vendor/jsclasses/okumacro.ins +9 -0
- data/vendor/jsclasses/okumacro.pdf +0 -0
- data/vendor/jsclasses/okumacro.sty +4 -17
- 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 +65 -12
- data/.rubocop_todo.yml +0 -7
- data/lib/review/book/compilable.rb +0 -173
- data/lib/review/tocparser.rb +0 -271
- data/samples/syntax-book/review-ext.rb +0 -14
- 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
|
data/test/test_image_finder.rb
CHANGED
@@ -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
|
13
|
-
dir
|
14
|
-
|
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
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
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
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
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
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
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
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
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
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
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
|
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, 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, 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, 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, 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, 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, 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, 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, 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,9 +216,46 @@ 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, 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
|