review 3.0.0 → 4.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-win.yml +39 -0
- data/.github/workflows/ruby.yml +27 -0
- data/.rubocop.yml +50 -12
- data/.travis.yml +17 -8
- data/Dockerfile +21 -5
- data/NEWS.ja.md +358 -0
- data/NEWS.md +358 -1
- data/README.md +11 -8
- data/appveyor.yml +1 -3
- data/bin/review-catalog-converter +4 -4
- data/bin/review-check +8 -8
- data/bin/review-checkdep +1 -1
- data/bin/review-compile +12 -12
- data/bin/review-epubmaker +3 -35
- data/bin/review-idgxmlmaker +16 -0
- data/bin/review-index +2 -89
- data/bin/review-preproc +14 -19
- data/bin/review-validate +3 -3
- data/bin/review-vol +4 -78
- data/doc/LICENSE +1 -1
- data/doc/config.yml.sample +46 -12
- data/doc/config.yml.sample-simple +4 -2
- data/doc/format.ja.md +37 -13
- data/doc/format.md +35 -20
- data/doc/pdfmaker.ja.md +43 -1
- data/doc/pdfmaker.md +42 -1
- data/doc/quickstart.ja.md +46 -26
- data/doc/quickstart.md +38 -17
- data/lib/epubmaker/epubcommon.rb +10 -5
- data/lib/epubmaker/epubv2.rb +1 -1
- data/lib/epubmaker/epubv3.rb +1 -0
- data/lib/epubmaker/producer.rb +4 -2
- data/lib/review/book.rb +1 -1
- data/lib/review/book/base.rb +38 -79
- data/lib/review/book/chapter.rb +18 -3
- data/lib/review/book/compilable.rb +6 -5
- data/lib/review/book/index.rb +69 -101
- data/lib/review/book/index/item.rb +40 -0
- data/lib/review/book/page_metric.rb +7 -7
- data/lib/review/book/part.rb +28 -5
- data/lib/review/book/volume.rb +3 -4
- data/lib/review/builder.rb +105 -44
- data/lib/review/catalog.rb +13 -16
- data/lib/review/compiler.rb +84 -72
- data/lib/review/configure.rb +19 -8
- data/lib/review/epub2html.rb +37 -4
- data/lib/review/epubmaker.rb +62 -7
- data/lib/review/extentions/string.rb +0 -4
- data/lib/review/htmlbuilder.rb +102 -115
- data/lib/review/htmlutils.rb +2 -3
- data/lib/review/i18n.rb +2 -2
- data/lib/review/i18n.yml +9 -0
- data/lib/review/idgxmlbuilder.rb +153 -74
- data/lib/review/idgxmlmaker.rb +191 -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 +125 -34
- data/lib/review/latexbuilder.rb +199 -88
- 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 +24 -5
- data/lib/review/markdownbuilder.rb +31 -37
- data/lib/review/md2inaobuilder.rb +3 -5
- data/lib/review/pdfmaker.rb +44 -22
- data/lib/review/plaintextbuilder.rb +106 -85
- data/lib/review/preprocessor.rb +32 -41
- data/lib/review/rstbuilder.rb +33 -33
- data/lib/review/textmaker.rb +19 -3
- data/lib/review/textutils.rb +76 -2
- data/lib/review/tocprinter.rb +231 -102
- data/lib/review/topbuilder.rb +114 -61
- data/lib/review/update.rb +19 -19
- data/lib/review/version.rb +1 -1
- data/lib/review/volumeprinter.rb +99 -0
- data/lib/review/webmaker.rb +11 -4
- 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/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 +16 -0
- data/templates/latex/layout.tex.erb +4 -0
- data/templates/latex/review-jlreq/review-base.sty +150 -61
- data/templates/latex/review-jlreq/review-jlreq.cls +74 -8
- data/templates/latex/review-jlreq/review-style.sty +4 -1
- data/templates/latex/review-jsbook/README.md +39 -0
- data/templates/latex/review-jsbook/review-base.sty +101 -23
- data/templates/latex/review-jsbook/review-jsbook.cls +28 -5
- 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 +2 -2
- data/test/assets/test_template.tex +24 -3
- data/test/assets/test_template_backmatter.tex +24 -3
- data/test/test_book.rb +75 -21
- data/test/test_book_chapter.rb +4 -2
- data/test/test_book_part.rb +3 -3
- data/test/test_builder.rb +16 -0
- data/test/test_catalog.rb +24 -42
- data/test/test_catalog_converter_cmd.rb +1 -1
- data/test/test_epubmaker_cmd.rb +14 -7
- data/test/test_helper.rb +15 -7
- data/test/test_htmlbuilder.rb +909 -159
- data/test/test_i18n.rb +25 -25
- data/test/test_idgxmlbuilder.rb +395 -38
- data/test/test_idgxmlmaker_cmd.rb +46 -0
- data/test/test_image_finder.rb +52 -70
- data/test/test_index.rb +50 -10
- data/test/test_latexbuilder.rb +1194 -106
- data/test/test_latexbuilder_v2.rb +628 -97
- data/test/test_logger.rb +14 -1
- data/test/test_makerhelper.rb +3 -3
- data/test/test_markdownbuilder.rb +134 -16
- data/test/test_md2inaobuilder.rb +32 -9
- data/test/test_pdfmaker.rb +18 -1
- data/test/test_pdfmaker_cmd.rb +100 -6
- data/test/test_plaintextbuilder.rb +371 -25
- data/test/test_preprocessor.rb +2 -16
- data/test/test_rstbuilder.rb +249 -26
- data/test/test_textmaker_cmd.rb +54 -0
- data/test/test_textutils.rb +109 -2
- data/test/test_topbuilder.rb +546 -31
- data/test/test_update.rb +17 -8
- data/test/test_webtocprinter.rb +66 -34
- data/test/test_yamlloader.rb +13 -0
- data/vendor/jsclasses/LICENSE +1 -1
- data/vendor/jsclasses/jis/jsarticle.cls +53 -14
- data/vendor/jsclasses/jis/jsbook.cls +53 -14
- data/vendor/jsclasses/jis/jsclasses.dtx +84 -25
- data/vendor/jsclasses/jis/jslogo.dtx +4 -4
- data/vendor/jsclasses/jis/jslogo.sty +3 -3
- data/vendor/jsclasses/jis/jspf.cls +52 -13
- data/vendor/jsclasses/jis/jsreport.cls +53 -14
- data/vendor/jsclasses/jis/kiyou.cls +53 -14
- data/vendor/jsclasses/jis/okumacro.dtx +4 -5
- data/vendor/jsclasses/jis/okumacro.sty +3 -4
- data/vendor/jsclasses/jsarticle.cls +53 -14
- data/vendor/jsclasses/jsbook.cls +53 -14
- data/vendor/jsclasses/jsclasses.dtx +84 -25
- data/vendor/jsclasses/jsclasses.pdf +0 -0
- data/vendor/jsclasses/jslogo.dtx +4 -4
- data/vendor/jsclasses/jslogo.pdf +0 -0
- data/vendor/jsclasses/jslogo.sty +3 -3
- data/vendor/jsclasses/jspf.cls +52 -13
- data/vendor/jsclasses/jsreport.cls +53 -14
- data/vendor/jsclasses/kiyou.cls +53 -14
- data/vendor/jsclasses/okumacro.dtx +4 -5
- data/vendor/jsclasses/okumacro.pdf +0 -0
- data/vendor/jsclasses/okumacro.sty +3 -4
- metadata +55 -10
- data/lib/review/tocparser.rb +0 -271
- data/samples/syntax-book/review-ext.rb +0 -14
- data/test/test_tocparser.rb +0 -25
data/doc/LICENSE
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
Copyright (c) 2006-
|
1
|
+
Copyright (c) 2006-2019 Minero Aoki, Kenshi Muto, Masayoshi Takahashi, Masanori Kado.
|
2
2
|
|
3
3
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
4
4
|
of this software and associated documentation files (the "Software"), to deal
|
data/doc/config.yml.sample
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
# このファイルはUTF-8エンコーディングで記述してください。
|
6
6
|
|
7
7
|
# この設定ファイルでサポートするRe:VIEWのバージョン番号。
|
8
|
-
review_version:
|
8
|
+
review_version: 4.0
|
9
9
|
|
10
10
|
# ほかの設定ファイルの継承を指定できる。同じパラメータに異なる値がある場合は、
|
11
11
|
# 呼び出し元の値が優先される。
|
@@ -64,6 +64,8 @@ aut: ["青木峰郎", "武藤健志", "高橋征義", "角征典"]
|
|
64
64
|
# a-trc, trc: 筆記・タイプ作業者
|
65
65
|
# a-trl, trl: 翻訳者
|
66
66
|
|
67
|
+
# contact: 連絡先
|
68
|
+
|
67
69
|
# 刊行日(省略した場合は実行時の日付)
|
68
70
|
# date: 2018-11-11
|
69
71
|
# 発行年月。YYYY-MM-DD形式による配列指定。省略した場合はdateを使用する
|
@@ -72,7 +74,7 @@ aut: ["青木峰郎", "武藤健志", "高橋征義", "角征典"]
|
|
72
74
|
# 日付の後ろを空白文字で区切り、任意の文字列を置くことも可能。
|
73
75
|
# history: [["2016-04-20 v1.0.0版発行", "2018-11-11 v3.0.0版発行"]]
|
74
76
|
# 権利表記(配列で複数指定可)
|
75
|
-
# rights: (C) 2016-
|
77
|
+
# rights: (C) 2016-2020 Re:VIEW Developers
|
76
78
|
# description: 説明
|
77
79
|
# subject: 短い説明用タグ(配列で複数指定可)
|
78
80
|
# type: 書籍のカテゴリーなど(配列で複数指定可)
|
@@ -111,7 +113,7 @@ toclevel: 3
|
|
111
113
|
secnolevel: 2
|
112
114
|
|
113
115
|
# 本文中に目次ページを作成するか。省略した場合はnull (作成しない)
|
114
|
-
|
116
|
+
toc: true
|
115
117
|
|
116
118
|
# EPUB2標準の目次(NCX)以外に物理目次ファイルを作成するか。省略した場合はnull (作成しない)
|
117
119
|
# ePUB3においてはこの設定によらず必ず作成される
|
@@ -137,7 +139,10 @@ secnolevel: 2
|
|
137
139
|
# creditfile: null
|
138
140
|
|
139
141
|
# 奥付を作成するか。デフォルトでは作成されない。trueを指定するとデフォルトの奥付、ファイル名を指定するとそれがcolophon.htmlとしてコピーされる
|
142
|
+
# デフォルトの奥付における各項目の名前(「著 者」など)を変えたいときにはlocale.ymlで文字列を設定する(詳細はdoc/format.ja.mdを参照)
|
140
143
|
# colophon: null
|
144
|
+
# デフォルトの奥付における、各項目の記載順序
|
145
|
+
# colophon_order: ["aut", "csl", "trl", "dsr", "ill", "cov", "edt", "pbl", "contact", "prt"]
|
141
146
|
|
142
147
|
# 裏表紙データファイル (PDFMaker向けにはLaTeXソース断片、EPUBMaker向けにはHTMLファイル)
|
143
148
|
# backcover: null
|
@@ -173,18 +178,34 @@ secnolevel: 2
|
|
173
178
|
# reファイルを格納するディレクトリ。省略した場合は以下 (. はカレントディレクトリを示す)
|
174
179
|
# contentdir: .
|
175
180
|
|
176
|
-
# @<w
|
181
|
+
# @<w>命令で使用する単語ファイルのパス。["common.csv", "mybook.csv"]のように配列指定も可
|
177
182
|
# words_file: words.csv
|
178
183
|
|
179
|
-
#
|
180
|
-
#
|
184
|
+
# //table命令における列の区切り文字。tabs (1文字以上のタブ文字区切り。デフォルト), singletab (1文字のタブ文字区切り), spaces (1文字以上のスペースまたはタブ文字の区切り), verticalbar ("0個以上の空白 | 0個以上の空白"の区切り)
|
185
|
+
# table_row_separator: tabs
|
186
|
+
|
187
|
+
# 複数行から段落を結合する際、前後のUnicode文字種に基づき必要に応じて空白文字を挿入するか
|
188
|
+
# 省略した場合はnull (挿入しない)。別途unicode-eaw gemファイルが必要
|
189
|
+
# join_lines_by_lang: null
|
190
|
+
|
191
|
+
# 図・表・コードリスト・数式のキャプション位置。
|
192
|
+
# 値はtop(上)またはbottom(下)でデフォルトは以下のとおり
|
193
|
+
# caption_position:
|
194
|
+
# image: bottom
|
195
|
+
# table: top
|
196
|
+
# list: top
|
197
|
+
# equation: top
|
198
|
+
|
199
|
+
# review-toc向けのヒント情報
|
200
|
+
# (文字幅を考慮した行数計測には、別途unicode-eaw gemファイルが必要)
|
201
|
+
# ページあたりの行数文字数を用紙サイズで指定する(A5 or B5)
|
181
202
|
# page_metric: A5
|
182
203
|
#
|
183
204
|
# あるいは、配列で指定することもできる
|
184
|
-
# 各数字の意味は、順にリストの行数、リストの1行字数、テキストの行数、テキストの1
|
185
|
-
# page_metric: [40,
|
205
|
+
# 各数字の意味は、順にリストの行数、リストの1行字数、テキストの行数、テキストの1行字数
|
206
|
+
# page_metric: [40,34,29,34]
|
186
207
|
|
187
|
-
# EPUB
|
208
|
+
# EPUB・Web、およびテキスト生成時における数式の画像化指定
|
188
209
|
# TeXの数式を画像化するか。省略した場合はnull (作成しない)
|
189
210
|
# imgmath: true
|
190
211
|
|
@@ -211,14 +232,20 @@ secnolevel: 2
|
|
211
232
|
# pdfcrop_cmd: "pdfcrop --hires %i %o"
|
212
233
|
# PDFから画像化するコマンドのコマンドライン。プレースホルダは
|
213
234
|
# %i: 入力ファイル、%o: 出力ファイル、%O: 出力ファイルから拡張子を除いたもの
|
214
|
-
# %p:
|
215
|
-
# pdfcrop_pixelize_cmd: "pdftocairo
|
235
|
+
# %p: 対象ページ番号、%t: フォーマット
|
236
|
+
# pdfcrop_pixelize_cmd: "pdftocairo -%t -r 90 -f %p -l %p -singlefile %i %O"
|
216
237
|
# pdfcrop_pixelize_cmdが複数ページの処理に対応していない場合に単ページ化するか
|
217
238
|
# extract_singlepage: null
|
218
239
|
# extract_singlepageがtrueの場合に単ページ化するコマンドのコマンドライン
|
219
240
|
# pdfextract_cmd: "pdfjam -q --outfile %o %i %p"
|
220
241
|
# converterにdvipngを指定したときのdvipngコマンドのコマンドライン
|
221
242
|
# dvipng_cmd: "dvipng -T tight -z 9 -p %p -l %p -o %o %i"
|
243
|
+
#
|
244
|
+
# PDFで保存したいときにはたとえば以下のようにする
|
245
|
+
# format: pdf
|
246
|
+
# extract_singlepage: true
|
247
|
+
# pdfextract_cmd: "pdftk A=%i cat A%p output %o"
|
248
|
+
# pdfcrop_pixelize_cmd: "mv %i %o"
|
222
249
|
|
223
250
|
# EPUBにおけるページ送りの送り方向、page-progression-directionの値("ltr"|"rtl"|"default")
|
224
251
|
# direction: "ltr"
|
@@ -306,6 +333,8 @@ epubmaker:
|
|
306
333
|
# @<href>タグでの外部リンクを禁止し、地の文にする(falseで禁止する)
|
307
334
|
# externallink: true
|
308
335
|
#
|
336
|
+
# 脚注に「戻る」リンクを追加する(trueで追加)。脚注の記号および戻るリンクの記号はlocale.ymlで変更可能
|
337
|
+
# back_footnote: null
|
309
338
|
# epubmaker:階層を使うものはここまで
|
310
339
|
|
311
340
|
# LaTeX用のスタイルファイル(styディレクトリ以下に置くこと)
|
@@ -320,7 +349,7 @@ epubmaker:
|
|
320
349
|
# texcommand: "uplatex"
|
321
350
|
#
|
322
351
|
# LaTeXのコマンドに渡すオプションを指定する
|
323
|
-
# texoptions: "-interaction=nonstopmode -file-line-error"
|
352
|
+
# texoptions: "-interaction=nonstopmode -file-line-error -halt-on-error"
|
324
353
|
#
|
325
354
|
# LaTeX用のdvi変換コマンドを指定する(dvipdfmx)
|
326
355
|
# dvicommand: "dvipdfmx"
|
@@ -365,6 +394,9 @@ pdfmaker:
|
|
365
394
|
# 画像のscale=X.Xという指定を画像拡大縮小率からページ最大幅の相対倍率に変換する
|
366
395
|
# image_scale2width: true
|
367
396
|
#
|
397
|
+
# 画像のデフォルトのサイズを、版面横幅合わせではなく、原寸をそのまま利用する
|
398
|
+
# use_original_image_size: null
|
399
|
+
#
|
368
400
|
# PDFやIllustratorファイル(.ai)の画像のBoudingBoxの抽出に指定のボックスを採用する
|
369
401
|
# cropbox(デフォルト), mediabox, artbox, trimbox, bleedboxから選択する。
|
370
402
|
# Illustrator CC以降のIllustratorファイルに対してはmediaboxを指定する必要がある
|
@@ -386,4 +418,6 @@ pdfmaker:
|
|
386
418
|
# makeindex_mecab_opts: "-Oyomi"
|
387
419
|
# 奥付を作成するか。trueを指定するとデフォルトの奥付、ファイル名を指定するとそれがcolophon.htmlとしてコピーされる
|
388
420
|
colophon: true
|
421
|
+
# 表紙挿入時に表紙のページ番号名を「cover」とし、偶数ページ扱いにして大扉前に白ページが入るのを防ぐ。デフォルトはtrue
|
422
|
+
# use_cover_nombre: true
|
389
423
|
# pdfmaker:階層を使うものはここまで
|
@@ -1,5 +1,5 @@
|
|
1
1
|
# simple sample of config.yml
|
2
|
-
review_version:
|
2
|
+
review_version: 4.0
|
3
3
|
|
4
4
|
# debug: true
|
5
5
|
|
@@ -20,9 +20,10 @@ aut: ["Masayoshi Takahashi"]
|
|
20
20
|
# edt: null
|
21
21
|
pbl: "Re:VIEW Publishing inc."
|
22
22
|
prt: "Re:VIEW Printing inc."
|
23
|
+
contact: "https://reviewml.org/"
|
23
24
|
date: 2018-11-11
|
24
25
|
history: [["2012-01-30"],["2016-04-20","2016-05-03"],["2018-11-11"]]
|
25
|
-
rights: (C) 2016-
|
26
|
+
rights: (C) 2016-2020 Re:VIEW Commiters, some rights reserved.
|
26
27
|
description: sample config.yml file for Re:VIEW book
|
27
28
|
urnid: urn:uid:http://reviewml.org/review-sample-book
|
28
29
|
# isbn: null
|
@@ -65,6 +66,7 @@ epubmaker:
|
|
65
66
|
htmlext: xhtml
|
66
67
|
cover_linear: true
|
67
68
|
externallink: true
|
69
|
+
# back_footnote: true
|
68
70
|
|
69
71
|
## for LaTeX
|
70
72
|
|
data/doc/format.ja.md
CHANGED
@@ -20,9 +20,9 @@ Re:VIEW フォーマットの文法について解説します。Re:VIEW フォ
|
|
20
20
|
* 2行以上空けても、1行空きと同じ意味になります。
|
21
21
|
* 空行せずに改行して段落の記述を続ける際、英文の単語間スペースについては考慮されないことに注意してください。Re:VIEW は各行を単純に連結するだけであり、TeX のように前後の単語を判断してスペースを入れるようなことはしません。
|
22
22
|
|
23
|
-
##
|
23
|
+
## 章・節・項・目・段(見出し)
|
24
24
|
|
25
|
-
|
25
|
+
章・節・項・目といった見出しは「`=`」「`==`」「`===`」「`====`」「`=====`」で表します。7 レベル以上は使えません。`=`のあとにはスペースを入れます。
|
26
26
|
|
27
27
|
例:
|
28
28
|
|
@@ -33,9 +33,11 @@ Re:VIEW フォーマットの文法について解説します。Re:VIEW フォ
|
|
33
33
|
|
34
34
|
=== 項のキャプション
|
35
35
|
|
36
|
-
====
|
36
|
+
==== 目のキャプション
|
37
37
|
|
38
|
-
=====
|
38
|
+
===== 段のキャプション
|
39
|
+
|
40
|
+
====== 小段のキャプション
|
39
41
|
```
|
40
42
|
|
41
43
|
見出しは行の先頭から始める必要があります。行頭に空白を入れると、ただの本文と見なされます。
|
@@ -262,11 +264,23 @@ puts "hello world!"
|
|
262
264
|
|
263
265
|
```review
|
264
266
|
//source[/hello/world.rb]{
|
265
|
-
puts "hello world!"
|
267
|
+
puts "hello world!" # キャプションあり
|
268
|
+
//}
|
269
|
+
|
270
|
+
//source{
|
271
|
+
puts "hello world!" # キャプションなし
|
272
|
+
//}
|
273
|
+
|
274
|
+
//source[/hello/world.rb][ruby]{
|
275
|
+
puts "hello world!" # キャプションあり、ハイライトあり
|
276
|
+
//}
|
277
|
+
|
278
|
+
//source[][ruby]{
|
279
|
+
puts "hello world!" # キャプションなし、ハイライトあり
|
266
280
|
//}
|
267
281
|
```
|
268
282
|
|
269
|
-
|
283
|
+
ソースコードの引用は、`//emlist` とほぼ同じです。HTML の CSS などでは区別した表現ができます。
|
270
284
|
|
271
285
|
## 本文中でのソースコード引用
|
272
286
|
|
@@ -310,7 +324,7 @@ V1 --> V6 --|
|
|
310
324
|
//}
|
311
325
|
```
|
312
326
|
|
313
|
-
3番目の引数として、画像の倍率・大きさを指定することができます。今のところ「scale=X」で倍率(X 倍)を指定でき、HTML、TeX ともに紙面(画面)幅に対しての倍率となります(0.5 なら半分の幅になります)。
|
327
|
+
3番目の引数として、画像の倍率・大きさを指定することができます。今のところ「scale=X」で倍率(X 倍)を指定でき、HTML、TeX ともに紙面(画面)幅に対しての倍率となります(0.5 なら半分の幅になります)。3番目の引数をたとえば HTML と TeX で分けたい場合は、`html::style="transform: scale(0.5);",latex::scale=0.5` のように `::` でビルダを明示し、`,` でオプションを区切って指定できます。
|
314
328
|
|
315
329
|
※TeX において原寸からの倍率にしたいときには、`config.yml` に `image_scale2width: false` を指定してください。
|
316
330
|
|
@@ -503,14 +517,13 @@ complexmatrixという識別子に基づく画像ファイルが貼り込まれ
|
|
503
517
|
|
504
518
|
本文中のインライン命令「`@<fn>{site}`」は脚注番号に置換され、「本書のサポートサイト……」という文は実際の脚注に変換されます。
|
505
519
|
|
506
|
-
注意: TeX PDF
|
520
|
+
注意: TeX PDF において、コラムの中で脚注を利用する場合、`//footnote` 行はコラムの終わり(`==[/column]` など)の後ろに記述することをお勧めします。Re:VIEW の標準提供のコラム表現では問題ありませんが、サードパーティのコラムの実装によってはおかしな採番表現になることがあります。
|
507
521
|
|
508
522
|
### footnotetext オプション
|
523
|
+
TeX PDF において、コラム以外の `//note` などの囲み記事の中で「`@<fn>{~}`」を使うには、`footnotetext` オプションを使う必要があります。
|
509
524
|
|
510
525
|
`footnotetext` オプションを使うには、`config.yml` ファイルに`footnotetext: true` を追加します。
|
511
526
|
|
512
|
-
これで PDF のコラムや表のなかでも脚注が使えるようになります。
|
513
|
-
|
514
527
|
ただし、通常の脚注(footnote)ではなく、footnotemark と footnotetext を使うため、本文と脚注が別ページに分かれる可能性があるなど、いろいろな制約があります。また、採番が別々になるため、footnote と footnotemark/footnotetext を両立させることはできません。
|
515
528
|
|
516
529
|
## 参考文献の定義
|
@@ -636,8 +649,8 @@ imgmath_options:
|
|
636
649
|
pdfcrop_cmd: "pdfcrop --hires %i %o"
|
637
650
|
# PDFから画像化するコマンドのコマンドライン。プレースホルダは
|
638
651
|
# %i: 入力ファイル、%o: 出力ファイル、%O: 出力ファイルから拡張子を除いたもの
|
639
|
-
# %p:
|
640
|
-
pdfcrop_pixelize_cmd: "pdftocairo
|
652
|
+
# %p: 対象ページ番号、%t: フォーマット
|
653
|
+
pdfcrop_pixelize_cmd: "pdftocairo -%t -r 90 -f %p -l %p -singlefile %i %O"
|
641
654
|
# pdfcrop_pixelize_cmdが複数ページの処理に対応していない場合に単ページ化するか
|
642
655
|
extract_singlepage: null
|
643
656
|
# 単ページ化するコマンドのコマンドライン
|
@@ -671,6 +684,17 @@ imgmath_options:
|
|
671
684
|
pdfcrop_pixelize_cmd: "sips -s format png --out %o %i"
|
672
685
|
```
|
673
686
|
|
687
|
+
textmaker 向けに PDF 形式の数式ファイルを作成したいときには、たとえば以下のように設定します(ページの抽出には pdftk を利用)。
|
688
|
+
|
689
|
+
```
|
690
|
+
imgmath: true
|
691
|
+
imgmath_options:
|
692
|
+
format: pdf
|
693
|
+
extract_singlepage: true
|
694
|
+
pdfextract_cmd: "pdftk A=%i cat A%p output %o"
|
695
|
+
pdfcrop_pixelize_cmd: "mv %i %o"
|
696
|
+
```
|
697
|
+
|
674
698
|
Re:VIEW 2 以前の dvipng の設定に合わせるには、次のようにします。
|
675
699
|
|
676
700
|
```
|
@@ -778,7 +802,7 @@ Web ハイパーリンクを記述するには、リンクに `@
|
|
778
802
|
"i18n","""i""nternationalizatio""n"""
|
779
803
|
```
|
780
804
|
|
781
|
-
単語ファイルのファイルパスは、`config.yml` に `words_file: ファイルパス`
|
805
|
+
単語ファイルのファイルパスは、`config.yml` に `words_file: ファイルパス` で指定します。`word_file: ["common.csv", "mybook.csv"]` のように複数のファイルも指定可能です(同一のキーがあるときには後に指定したファイルの値が優先されます)。
|
782
806
|
|
783
807
|
例:
|
784
808
|
|
data/doc/format.md
CHANGED
@@ -24,7 +24,7 @@ Two empty lines or more are same as one empty line.
|
|
24
24
|
|
25
25
|
## Chapter, Section, Subsection (headings)
|
26
26
|
|
27
|
-
Chapters, sections, subsections, subsubsections use `=`, `==`, `===`, `====`,
|
27
|
+
Chapters, sections, subsections, subsubsections use `=`, `==`, `===`, `====`, `=====`, and `======`.
|
28
28
|
You should add one or more spaces after `=`.
|
29
29
|
|
30
30
|
Usage:
|
@@ -39,6 +39,8 @@ Usage:
|
|
39
39
|
==== 4th level
|
40
40
|
|
41
41
|
===== 5th level
|
42
|
+
|
43
|
+
====== 6th level
|
42
44
|
```
|
43
45
|
|
44
46
|
Headings should not have any spaces before title; if line head has space, it is as paragraph.
|
@@ -96,11 +98,11 @@ Nested itemize is like ` **`, ` ***`.
|
|
96
98
|
Usage:
|
97
99
|
|
98
100
|
```
|
99
|
-
* 1st item
|
100
|
-
** nested 1st item
|
101
|
-
* 2nd item
|
102
|
-
** nested 2nd item
|
103
|
-
* 3rd item
|
101
|
+
* 1st item
|
102
|
+
** nested 1st item
|
103
|
+
* 2nd item
|
104
|
+
** nested 2nd item
|
105
|
+
* 3rd item
|
104
106
|
```
|
105
107
|
|
106
108
|
In itemize, you must write one more space character at line head.
|
@@ -116,34 +118,34 @@ They aren't nested.
|
|
116
118
|
Usage:
|
117
119
|
|
118
120
|
```
|
119
|
-
1. 1st condition
|
120
|
-
2. 2nd condition
|
121
|
-
3. 3rd condition
|
121
|
+
1. 1st condition
|
122
|
+
2. 2nd condition
|
123
|
+
3. 3rd condition
|
122
124
|
```
|
123
125
|
|
124
126
|
The value of Number is ignored.
|
125
127
|
|
126
128
|
```
|
127
|
-
1. 1st condition
|
128
|
-
1. 2nd condition
|
129
|
-
1. 3rd condition
|
129
|
+
1. 1st condition
|
130
|
+
1. 2nd condition
|
131
|
+
1. 3rd condition
|
130
132
|
```
|
131
133
|
|
132
134
|
You must write one more space character at line head like itemize.
|
133
135
|
|
134
136
|
## Definition List
|
135
137
|
|
136
|
-
Definition list (dl in HTML)
|
138
|
+
Definition list (dl in HTML) uses ` : ` and indented lines.
|
137
139
|
|
138
140
|
Usage:
|
139
141
|
|
140
142
|
```review
|
141
|
-
: Alpha
|
143
|
+
: Alpha
|
142
144
|
RISC CPU made by DEC.
|
143
|
-
: POWER
|
145
|
+
: POWER
|
144
146
|
RSIC CPU made by IBM and Motolora.
|
145
147
|
POWER PC is delivered from this.
|
146
|
-
: SPARC
|
148
|
+
: SPARC
|
147
149
|
RISC CPU made by SUN.
|
148
150
|
```
|
149
151
|
|
@@ -353,6 +355,7 @@ V1 --> V6 --|
|
|
353
355
|
```
|
354
356
|
|
355
357
|
The third option is used to define the scale of images. `scale=X` is scaling for page width (`scale=0.5` makes image width to be half of page width).
|
358
|
+
If you'd like to use different values for each builders, such as HTML and TeX, you can specify the target builders using `::`. Example: `html::style="transform: scale(0.5);",latex::scale=0.5`
|
356
359
|
|
357
360
|
When you want to refer images such as "see figure 1.", you can use
|
358
361
|
inline reference markup like `@<img>{unixhistory}`.
|
@@ -544,9 +547,10 @@ You should get and install it before reading the book.
|
|
544
547
|
`@<fn>{site}` in source are replaced by footnote marks, and the phrase "support site of .."
|
545
548
|
is in footnotes.
|
546
549
|
|
547
|
-
Note that
|
550
|
+
Note that in LATEXBuilder, it is highly recommended to place `//footnote` after the end line of column (`==[/column]`) to avoid problems when using third party's style file.
|
548
551
|
|
549
552
|
### `footnotetext` option
|
553
|
+
Note that in LATEXBuilder, you should use `footnotetext` option to use `@<fn>{...}` in `//note` or other short column blocks.
|
550
554
|
|
551
555
|
By adding `footnotetext:true` in config.yml, you can use footnote in tables and short notes.
|
552
556
|
|
@@ -680,8 +684,8 @@ imgmath_options:
|
|
680
684
|
pdfcrop_cmd: "pdfcrop --hires %i %o"
|
681
685
|
# imaging command.
|
682
686
|
# %i: filename for input %o: filename for output %O: filename for output without the extension
|
683
|
-
# %p: page number
|
684
|
-
pdfcrop_pixelize_cmd: "pdftocairo
|
687
|
+
# %p: page number, %t: format
|
688
|
+
pdfcrop_pixelize_cmd: "pdftocairo -%t -r 90 -f %p -l %p -singlefile %i %O"
|
685
689
|
# whether to generate a single PDF page for pdfcrop_pixelize_cmd.
|
686
690
|
extract_singlepage: null
|
687
691
|
# command line to generate a single PDF page file.
|
@@ -715,6 +719,17 @@ imgmath_options:
|
|
715
719
|
pdfcrop_pixelize_cmd: "sips -s format png --out %o %i"
|
716
720
|
```
|
717
721
|
|
722
|
+
To create PDF math images:
|
723
|
+
|
724
|
+
```
|
725
|
+
imgmath: true
|
726
|
+
imgmath_options:
|
727
|
+
format: pdf
|
728
|
+
extract_singlepage: true
|
729
|
+
pdfextract_cmd: "pdftk A=%i cat A%p output %o"
|
730
|
+
pdfcrop_pixelize_cmd: "mv %i %o"
|
731
|
+
```
|
732
|
+
|
718
733
|
To set the same setting as Re:VIEW 2:
|
719
734
|
|
720
735
|
```
|
@@ -836,7 +851,7 @@ This word file is a CSV file with extension .csv. This first columns is the key,
|
|
836
851
|
"i18n","""i""nternationalizatio""n"""
|
837
852
|
```
|
838
853
|
|
839
|
-
Specify the word file path in `words_file` parameter of `config.yml`.
|
854
|
+
Specify the word file path in `words_file` parameter of `config.yml`. You can specify multiple word files as `word_file: ["common.csv", "mybook.csv"]`.
|
840
855
|
|
841
856
|
Usage:
|
842
857
|
|
data/doc/pdfmaker.ja.md
CHANGED
@@ -109,6 +109,48 @@ Re:VIEW 3.0 から review-jlreq.cls という別のクラスファイルも用
|
|
109
109
|
|
110
110
|
その他の詳細な設定については、sty フォルダにある README.md を参照してください。
|
111
111
|
|
112
|
+
### カスタムパラメータの引き渡し
|
113
|
+
|
114
|
+
技術的な都合で、config.yml の YAML 設定から TeX のマクロへの変換はすべての設定について行われるわけではなく、ごく限られた値のみに制限しています。これは Re:VIEW 内部の `config.erb` ( https://github.com/kmuto/review/blob/master/templates/latex/config.erb ) の ERB スクリプトによって処理されており、この挙動を変更することは許容していません。
|
115
|
+
|
116
|
+
任意の YAML 設定を TeX に引き渡すには、`config.erb` と同様に YAML から TeX への変換を行う固有の ERB スクリプトを作成して配置します。このためには、プロジェクトフォルダに `layouts` フォルダを作成し、そこに固有の ERB スクリプトを `config-local.tex.erb` という名前で置きます。
|
117
|
+
|
118
|
+
`config-local.tex.erb` は `config.erb` の評価・埋め込みの後、評価・埋め込みされます。
|
119
|
+
|
120
|
+
config.yml を次のようにして、これを TeX に渡したいとします。
|
121
|
+
|
122
|
+
```
|
123
|
+
mycustom:
|
124
|
+
mystring: HELLO_#1
|
125
|
+
mybool: true
|
126
|
+
```
|
127
|
+
|
128
|
+
`layouts/config-local.tex.erb` はたとえば次のようになります。
|
129
|
+
|
130
|
+
```
|
131
|
+
\def\mystring{<%= escape(@config['mycustom']['mystring']) %>}
|
132
|
+
<%- if @config['mycustom']['mybool'] -%>
|
133
|
+
\def\mybool{true}
|
134
|
+
<%- end -%>
|
135
|
+
```
|
136
|
+
|
137
|
+
次のように展開されます。
|
138
|
+
```
|
139
|
+
…
|
140
|
+
\makeatother
|
141
|
+
%% BEGIN: config-local.tex.erb
|
142
|
+
\def\mystring{HELLO\textunderscore{}\#1}
|
143
|
+
\def\mybool{true}
|
144
|
+
%% END: config-local.tex.erb
|
145
|
+
|
146
|
+
\usepackage{reviewmacro}
|
147
|
+
…
|
148
|
+
```
|
149
|
+
|
150
|
+
こうして定義されたマクロを sty ファイルなどで参照します。
|
151
|
+
|
152
|
+
なお、ERB での YAML 解析、および TeX マクロの記述において誤りがあると、極めてわかりにくいエラーになることがあります。`--debug` オプション付きで実行して展開された `__REVIEW_BOOK__.tex` を確認して原因を調査するのがよいでしょう。
|
153
|
+
|
112
154
|
## Re:VIEW 2.0 以前の情報
|
113
155
|
|
114
156
|
### upLaTeX について
|
@@ -121,7 +163,7 @@ LaTeX コンパイラコマンドおよびオプションについて、Re:VIEW
|
|
121
163
|
|
122
164
|
```yaml
|
123
165
|
texcommand: uplatex
|
124
|
-
texoptions: "-interaction=nonstopmode -file-line-error"
|
166
|
+
texoptions: "-interaction=nonstopmode -file-line-error -halt-on-error"
|
125
167
|
texdocumentclass: ["jsbook", "uplatex,oneside"]
|
126
168
|
dvicommand: dvipdfmx
|
127
169
|
dvioptions: "-d 5"
|