Skip to content

Commit

Permalink
Merge branch 'master' into news410
Browse files Browse the repository at this point in the history
  • Loading branch information
kmuto committed Dec 29, 2019
2 parents 2273a37 + 4d4370d commit ef6fedd
Show file tree
Hide file tree
Showing 21 changed files with 336 additions and 146 deletions.
4 changes: 2 additions & 2 deletions doc/config.yml.sample
Original file line number Diff line number Diff line change
Expand Up @@ -181,8 +181,8 @@ toc: true
# @<w>命令で使用する単語ファイルのパス
# words_file: words.csv

# //table命令における列の区切り文字 (Rubyの正規表現)。''で囲むこと
# table_split_regexp: '\t+'
# //table命令における列の区切り文字。tabs (1文字以上のタブ文字区切り。デフォルト), singletab (1文字のタブ文字区切り), spaces (1文字以上のスペースまたはタブ文字の区切り), verticalbar ("0個以上の空白 | 0個以上の空白"の区切り)
# table_row_separator: tabs

# review-vol向けのヒント情報
# 1ページの行数文字数と1kbごとのページ数を用紙サイズで指定する(A5 or B5)
Expand Down
16 changes: 14 additions & 2 deletions doc/format.ja.md
Original file line number Diff line number Diff line change
Expand Up @@ -264,11 +264,23 @@ puts "hello world!"

```review
//source[/hello/world.rb]{
puts "hello world!"
puts "hello world!" # キャプションあり
//}
//source{
puts "hello world!" # キャプションなし
//}
//source[/hello/world.rb][ruby]{
puts "hello world!" # キャプションあり、ハイライトあり
//}
//source[][ruby]{
puts "hello world!" # キャプションなし、ハイライトあり
//}
```

ソースコードの引用は、キャプションを付けた `//emlist` とほぼ同じです。HTML の CSS などでは区別した表現ができます。
ソースコードの引用は、`//emlist` とほぼ同じです。HTML の CSS などでは区別した表現ができます。

## 本文中でのソースコード引用

Expand Down
63 changes: 40 additions & 23 deletions doc/quickstart.ja.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,11 @@ Re:VIEW は GNU Lesser General Public License Version 2.1 に基づいて配布

このドキュメントでは、Re:VIEW のセットアップから変換の例までを簡単に説明します。

このドキュメントは、Re:VIEW 3.0 に基づいています。
このドキュメントは、Re:VIEW 4.0 に基づいています。

## セットアップ

Re:VIEW は Ruby 言語で記述されており、Linux/Unix 互換システムで動作します。macOS および Windows Cygwin でも動作可能です。Ruby gem あるいは Git のいずれかを使ってダウンロード・展開します。
Re:VIEW は Ruby 言語で記述されており、Linux/Unix 互換システムで動作します。macOS および Windows でも動作可能です。Ruby gem あるいは Git のいずれかを使ってダウンロード・展開します。

なお、Re:VIEW フォーマット自体は文字で表現されたタグが付いている以外は単なるテキストファイルなので、エディタ、OS については UTF-8 文字エンコーディングさえ使用できれば制限はありません。

Expand All @@ -34,7 +34,7 @@ Ruby gem の bin ディレクトリにパスを通すようにしておいてく
$ gem update review
```

Gemfile を使っている場合は、以下の行を Gemfile に追加して、`bundle`コマンドを実行します。
Gemfile を使っている場合は、以下の行を Gemfile に追加して、`bundle` コマンドを実行します。

```Gemfile
gem 'review'
Expand All @@ -58,29 +58,37 @@ review というディレクトリに展開されるので、review/bin にパ
$ git pull
```

## Re:VIEW ドキュメントの作成
## Re:VIEW プロジェクトの作成

### 雛型の作成
review-init コマンドを使って、雛型となる作業フォルダを作成できます
review-init コマンドを使って、雛型となるプロジェクトフォルダを作成できます

```
$ review-init ドキュメント名
$ review-init プロジェクト名
```

これで指定のドキュメント名のフォルダが用意され、中に次のようなファイルが置かれます
TeX を利用した PDF 作成を目的としているならば、雛型の作成時に、Web ブラウザによるウィザードモードで基本版面設計を行うことができます。これには `-w` オプションを付けます

* ドキュメント名を冠した「.re」拡張子を持つファイル(Re:VIEW フォーマットテキストファイル)
```
$ review-init -w プロジェクト名
```

http://localhost:18000」に Web ブラウザでアクセスし、文字数×行数および余白を調整できます。

これで指定のプロジェクト名のフォルダが用意され、中に次のようなファイルが置かれます。

* プロジェクト名を冠した「.re」拡張子を持つファイル(Re:VIEW フォーマットテキストファイル)
* config.yml : 設定ファイル
* config-ebook.yml : 電子ブック用設定ファイル(ウィザードモード使用時)
* catalog.yml : カタログファイル(目次構成)
* Rakefile : rake コマンドのルールファイル
* images : 画像の配置フォルダ
* layouts : レイアウトファイルの配置フォルダ
* style.css : サンプルスタイルシート
* sty : スタイルファイル配置フォルダ(TeX 用)
* doc : 本ドキュメントを含む使い方のドキュメント
* lib : 主に rake コマンドの詳細ルールファイル

review-init コマンドによらず、独自に作業フォルダを作成してもかまいません
review-init コマンドによらず、独自にプロジェクトフォルダを作成してもかまいません

### Re:VIEW テキストの作成と変換

Expand Down Expand Up @@ -115,28 +123,37 @@ review-init コマンドによらず、独自に作業フォルダを作成し

テキストファイルの文字エンコーディングには、UTF-8 を使用してください。

### PDF 化と EPUB 化、プレインテキスト化
### PDF 化と EPUB 化、プレインテキスト化、XML 化

review-*maker コマンドで一括して変換作成ができます。

review-pdfmaker コマンドで PDF ブックの作成、review-epubmaker コマンドで EPUB ファイルの作成、review-textmaker コマンドでプレインテキストの作成ができます。
- review-pdfmaker コマンド:PDF ブックの作成
- review-epubmaker コマンド:EPUB ファイルの作成
- review-textmaker コマンド:プレインテキストの作成
- review-idgxmlmaker コマンド:InDesign XML の作成

PDF を作成するには、TeXLive2012 以上の環境が必要です。EPUB を作成するには、rubyzip gem あるいは zip コマンドが必要です(MathML も使いたいときには、 [MathML ライブラリ](http://www.hinet.mydns.jp/?mathml.rb)も必要です)。

いずれのコマンドも、必要な設定情報を記した YAML 形式ファイルを引数に指定して実行します。review-init コマンドで作成した環境には、デフォルトで config.yml として用意されているので、これを利用します。

```bash
$ review-pdfmaker config.yml ←PDFの作成
$ review-epubmaker config.yml ←EPUBの作成
$ review-textmaker config.yml ←テキストの作成(装飾情報あり)
$ review-textmaker -n config.yml ←テキストの作成(装飾情報なし)
$ review-pdfmaker config.yml ←PDFの作成
$ review-pdfmaker config-ebook.yml ←電子ブック設定でのPDFの作成
$ review-epubmaker config.yml ←EPUBの作成
$ review-textmaker config.yml ←テキストの作成(装飾情報あり)
$ review-textmaker -n config.yml ←テキストの作成(装飾情報なし)
$ review-idgxmlmaker config.yml ←InDesign XMLの作成
```

rake コマンドを利用できるなら、次のように実行することもできます。

```bash
$ rake pdf ←PDFの作成
$ REVIEW_CONFIG_FILE=config-ebook.yml rake pdf ←電子ブック設定でのPDFの作成
$ rake epub ←EPUBの作成
$ rake text ←テキストの作成(装飾情報あり)
$ rake plaintext ←テキストの作成(装飾情報なし)
$ rake idgxml ←InDesign XMLの作成
```

config.yml のサンプルについては以下を参照してください。
Expand Down Expand Up @@ -177,7 +194,7 @@ Re:VIEW の使用実例については、https://github.com/reviewml/review-samp
$ review-compile --target text sample.re > sample.txt ←テキストにする
$ review-compile --target html sample.re > sample.html ←HTMLにする
$ review-compile --target latex sample.re > sample.tex ←LaTeXにする
$ review-compile --target idgxml sample.re > sample.xml ←XMLにする
$ review-compile --target idgxml sample.re > sample.xml ←InDesign XMLにする
$ review-compile --target markdown sample.re > sample.md ←Markdownにする
```

Expand Down Expand Up @@ -206,14 +223,14 @@ $ review-vol
$ review-index --level 掘り下げる見出しレベル数 -a
```

## ドキュメントフォルダを新しい Re:VIEW バージョンに追従する方法
## プロジェクトフォルダを新しい Re:VIEW バージョンに追従する方法

Re:VIEW は定期的に更新されています。おおむね後方互換性を保持していますが、新しいバージョン固有の機能を利用したいときには、ドキュメントフォルダを新しいバージョンに更新する review-update コマンドを利用します。
Re:VIEW は定期的に更新されています。おおむね後方互換性を保持していますが、新しいバージョン固有の機能を利用したいときには、プロジェクトフォルダを新しいバージョンに更新する review-update コマンドを利用します。

```bash
$ review-update
** review-update はプロジェクトを 3.0.0 に更新します **
config.yml: 'review_version''3.0' に更新しますか? [y]/n ←Enterで実行
** review-update はプロジェクトを 4.0.0 に更新します **
config.yml: 'review_version''4.0' に更新しますか? [y]/n ←Enterで実行
Rakefile は Re:VIEW バージョンのもの (/.../review/samples/sample-book/src/Rakefile) で置き換えられます。本当に進めますか? [y]/n
lib/tasks/review.rake は Re:VIEW バージョンのもの (/.../review/samples/sample-book/src/lib/tasks/review.rake) で置き換えられます。本当に進めますか? [y]/n
INFO: 新しいファイル /.../sty/plistings.sty が作成されました。
Expand All @@ -229,9 +246,9 @@ INFO: 新しいファイル /.../sty/gentombow.sty が作成されました。

## クレジット

Re:VIEW は、青木峰郎によって最初に作成されました。武藤健志がこの開発・保守を引き継ぎ、2019年2月時点では、武藤健志、高橋征義、角征典が開発・保守を継続しています。
Re:VIEW は、青木峰郎によって最初に作成されました。武藤健志がこの開発・保守を引き継ぎ、2019年12月時点では、武藤健志、高橋征義、角征典が開発・保守を継続しています。

バグ・パッチの報告、開発者用メーリングリストなどについての情報は
バグ・パッチの報告、その他の情報は

* http://reviewml.org/
* https://github.com/kmuto/review/wiki
Expand Down
48 changes: 33 additions & 15 deletions doc/quickstart.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ Re:VIEW is free software under the terms of the GNU Lesser General Public Licens

This article describes how to setup Re:VIEW and use it.

The supported version of the article is Re:VIEW 3.0.
The supported version of the article is Re:VIEW 4.0.

## Set up Re:VIEW

Expand Down Expand Up @@ -59,7 +59,7 @@ $ git pull

## Writing Re:VIEW Document

### Generating template fiels
### Generating template files

After setup, you can use `review-init` command to generate Re:VIEW project directory.

Expand All @@ -72,14 +72,23 @@ $ ls hello
Rakefile catalog.yml config.yml hello.re images/ layouts/ sty/ style.css
```

If your purpose is to create a PDF using TeX, it is a good idea to use the wizard mode for basic layouting in a web browser. Add `-w` option to review-init.

(notice: currently wizard UI supports only Japanese language)

```bash
$ review-init -w hello
(access http://localhost:18000 on Web browser)
```

In `hello` directory, many files are generated.

* `*.re` : Re:VIEW format file.
* config.yml : configuration file
* config-ebook.yml : configuration file for ebook (when using the wizard mode)
* catalog.yml : catalog file (for TOC)
* Rakefile : rule file for `rake` command
* images : folder for images
* layouts : forlder for layout files
* style.css : sample stylesheet
* sty : style files for LaTeX
* doc : various documents (including this document)
Expand Down Expand Up @@ -116,29 +125,38 @@ The web site of Re:VIEW is @<tt>{https://reviewml.org/}.

You should use UTF-8 as encodings in text files.

### generating PDF, EPUB, and plain-text
### generating PDF, EPUB, plain-text, and InDesign XML

To convert files in the project, use review-*maker command.

You can generate a PDF file with `review-pdfmaker` command. Also you can generate an EPUB file with `review-epubmaker` command, and can generate an plain-text file with 'review-textmaker' command.
- review-pdfmaker: generate PDF
- review-epubmaker: generate EPUB
- review-textmaker: genrate plaintext
- review-idgxmlmaker: genrate InDesign XML

To generate PDF, you should install TeXLive 2012 or later. To generate EPUB, you should install zip command.
To generate PDF, you should install TeXLive 2012 or later. To generate EPUB, you should install zip command.
When you want to use MathML, you should install [MathML library](http://www.hinet.mydns.jp/?mathml.rb)

Each maker need `config.yml`, configuration YAML files. `review-init` command generates `config.yml` in default.
Each maker need `config.yml`, configuration YAML files. `review-init` command generates `config.yml` in default.

```bash
$ review-pdfmaker config.yml ## generate PDF
$ review-epubmaker config.yml ## generate EPUB
$ review-textmaker config.yml ## generate text with decoration
$ review-textmaker -n config.yml ## generate text without decoration
$ review-pdfmaker config.yml ## generate PDF
$ review-pdfmaker config-ebook.yml ## generate PDF (for ebook)
$ review-epubmaker config.yml ## generate EPUB
$ review-textmaker config.yml ## generate text with decoration
$ review-textmaker -n config.yml ## generate text without decoration
$ review-idgxmlmaker config.yml ## generate InDesign XML
```

You also can generate them with Rake.

```bash
$ rake pdf ## generate PDF
$ REVIEW_CONFIG_FILE=config-ebook.yml rake pdf ## generate PDF (for ebook)
$ rake epub ## generate EPUB
$ rake text ## generate text with decoration
$ rake plaintext ## generate text without decoration
$ rake idgxml ## generate InDesign XML
```

There is a sample YAML file [config.yml.sample](https://github.com/kmuto/review/blob/master/doc/config.yml.sample) in the same directory of this document.
Expand Down Expand Up @@ -210,12 +228,12 @@ $ review-index --level <heading level> -a

## how to update the document folder to the new Re:VIEW version

Re:VIEW is updated regularly. We Re:VIEW team watch the backward compatibility carefully, but if you want to use the features in the new version, you can use review-update command to update the document folder.
Re:VIEW is updated regularly. We Re:VIEW team watch the backward compatibility carefully, but if you want to use the features in the new version, you can use review-update command to update the project folder.

```bash
$ review-update
** review-update updates your project to 3.0.0 **
config.yml: Update 'review_version' to '3.0'? [y]/n
** review-update updates your project to 4.0.0 **
config.yml: Update 'review_version' to '4.0'? [y]/n
Rakefile will be overridden with Re:VIEW version (/.../review/samples/sample-book/src/Rakefile). Do you really proceed? [y]/n
lib/tasks/review.rake will be overridden with Re:VIEW version (/.../review/samples/sample-book/src/lib/tasks/review.rake). Do you really proceed? [y]/n
INFO: new file /.../sty/plistings.sty is created.
Expand All @@ -231,7 +249,7 @@ Finished.

## Copyright

The original author of Re:VIEW is Minero Aoki. The current maintainer is Kenshi Muto(@kmuto), and committers are Masayoshi Takahashi and Masanori Kado (February 2019).
The original author of Re:VIEW is Minero Aoki. The current maintainer is Kenshi Muto(@kmuto), and committers are Masayoshi Takahashi and Masanori Kado (December 2019).

If you want to report bugs and patches, or to get more information, see:

Expand Down
21 changes: 14 additions & 7 deletions lib/review/builder.rb
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ def listnum(lines, id, caption, lang = nil)
listnum_body(lines, lang)
end

def source(lines, caption, lang = nil)
def source(lines, caption = nil, lang = nil)
source_header(caption)
source_body(lines, lang)
end
Expand Down Expand Up @@ -179,11 +179,18 @@ def table(lines, id = nil, caption = nil)
table_end
end

def table_split_regexp
begin
Regexp.new(@book.config['table_split_regexp'])
rescue RegexpError
error "invalid regular expression in 'table_split_regexp' parameter."
def table_row_separator_regexp
case @book.config['table_row_separator']
when 'tabs'
Regexp.new('\t+')
when 'singletab'
Regexp.new('\t')
when 'spaces'
Regexp.new('\s+')
when 'verticalbar'
Regexp.new('\s*\\' + escape('|') + '\s*')
else
error "Unknown value for 'table_row_separator', shold be: tabs, singletab, spaces, verticalbar"
end
end

Expand All @@ -195,7 +202,7 @@ def parse_table_rows(lines)
sepidx ||= idx
next
end
rows.push(line.strip.split(table_split_regexp).map { |s| s.sub(/\A\./, '') })
rows.push(line.strip.split(table_row_separator_regexp).map { |s| s.sub(/\A\./, '') })
end
rows = adjust_n_cols(rows)
error 'no rows in the table' if rows.empty?
Expand Down
2 changes: 1 addition & 1 deletion lib/review/configure.rb
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ def self.values
'colophon_order' => %w[aut csl trl dsr ill cov edt pbl contact prt],
'externallink' => true,
'join_lines_by_lang' => nil, # experimental. default should be nil
'table_split_regexp' => '\t+',
'table_row_separator' => 'tabs',
# for IDGXML
'tableopt' => nil,
'listinfo' => nil,
Expand Down
10 changes: 5 additions & 5 deletions lib/review/idgxmlbuilder.rb
Original file line number Diff line number Diff line change
Expand Up @@ -499,7 +499,7 @@ def parse_table_rows(lines)
else
rows.push(line.gsub(/\t\.\t/, "\t\t").gsub(/\t\.\.\t/, "\t.\t").gsub(/\t\.\Z/, "\t").gsub(/\t\.\.\Z/, "\t.").gsub(/\A\./, ''))
end
col2 = rows[rows.length - 1].split(table_split_regexp).length
col2 = rows[rows.length - 1].split(table_row_separator_regexp).length
@col = col2 if col2 > @col
end
error 'no rows in the table' if rows.empty?
Expand Down Expand Up @@ -533,7 +533,7 @@ def table_rows(sepidx, rows)
puts %Q(<tr type="header">#{rows.shift}</tr>)
else
i = 0
rows.shift.split(table_split_regexp).each_with_index do |cell, x|
rows.shift.split(table_row_separator_regexp).each_with_index do |cell, x|
print %Q(<td xyh="#{x + 1},#{y + 1},#{sepidx}" aid:table="cell" aid:theader="1" aid:crows="1" aid:ccols="1" aid:ccolwidth="#{sprintf('%.3f', cellwidth[i])}">#{cell.sub('DUMMYCELLSPLITTER', '')}</td>)
i += 1
end
Expand All @@ -548,7 +548,7 @@ def trputs(tablewidth, rows, cellwidth, sepidx)
if tablewidth
rows.each_with_index do |row, y|
i = 0
row.split(table_split_regexp).each_with_index do |cell, x|
row.split(table_row_separator_regexp).each_with_index do |cell, x|
print %Q(<td xyh="#{x + 1},#{y + 1 + sepidx},#{sepidx}" aid:table="cell" aid:crows="1" aid:ccols="1" aid:ccolwidth="#{sprintf('%.3f', cellwidth[i])}">#{cell.sub('DUMMYCELLSPLITTER', '')}</td>)
i += 1
end
Expand Down Expand Up @@ -593,7 +593,7 @@ def emtable(lines, caption = nil)
end

def imgtable(lines, id, caption = nil, metric = nil)
if @chapter.image(id).bound?
if @chapter.image_bound?(id)
metrics = parse_metric('idgxml', metric)
puts '<table>'
table_header(id, caption) if caption.present?
Expand Down Expand Up @@ -1146,7 +1146,7 @@ def inline_title(id)
error "unknown chapter: #{id}"
end

def source(lines, caption, lang = nil)
def source(lines, caption = nil, lang = nil)
puts '<source>'
source_header(caption)
source_body(lines, lang)
Expand Down
Loading

0 comments on commit ef6fedd

Please sign in to comment.