review 2.3.0 → 2.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (160) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +90 -66
  3. data/.travis.yml +1 -1
  4. data/Gemfile +0 -1
  5. data/NEWS.ja.md +82 -0
  6. data/NEWS.md +83 -0
  7. data/README.md +5 -3
  8. data/Rakefile +8 -8
  9. data/bin/review +1 -5
  10. data/bin/review-catalog-converter +22 -27
  11. data/bin/review-check +36 -43
  12. data/bin/review-checkdep +10 -15
  13. data/bin/review-compile +37 -55
  14. data/bin/review-epubmaker +4 -5
  15. data/bin/review-index +21 -29
  16. data/bin/review-init +26 -37
  17. data/bin/review-pdfmaker +0 -2
  18. data/bin/review-preproc +25 -45
  19. data/bin/review-validate +19 -18
  20. data/bin/review-vol +15 -27
  21. data/doc/config.yml.sample +5 -2
  22. data/doc/format.ja.md +20 -1
  23. data/doc/format.md +21 -5
  24. data/doc/images/review-generate.png +0 -0
  25. data/lib/epubmaker.rb +1 -3
  26. data/lib/epubmaker/content.rb +24 -27
  27. data/lib/epubmaker/epubcommon.rb +135 -148
  28. data/lib/epubmaker/epubv2.rb +39 -46
  29. data/lib/epubmaker/epubv3.rb +93 -103
  30. data/lib/epubmaker/producer.rb +138 -151
  31. data/lib/epubmaker/zip_exporter.rb +21 -26
  32. data/lib/review/book.rb +3 -6
  33. data/lib/review/book/base.rb +78 -103
  34. data/lib/review/book/chapter.rb +36 -40
  35. data/lib/review/book/compilable.rb +28 -31
  36. data/lib/review/book/image_finder.rb +6 -13
  37. data/lib/review/book/index.rb +100 -121
  38. data/lib/review/book/page_metric.rb +2 -7
  39. data/lib/review/book/part.rb +18 -20
  40. data/lib/review/book/volume.rb +9 -13
  41. data/lib/review/builder.rb +81 -116
  42. data/lib/review/catalog.rb +15 -19
  43. data/lib/review/compiler.rb +64 -83
  44. data/lib/review/configure.rb +87 -97
  45. data/lib/review/converter.rb +2 -7
  46. data/lib/review/epubbuilder.rb +1 -3
  47. data/lib/review/epubmaker.rb +213 -205
  48. data/lib/review/exception.rb +2 -4
  49. data/lib/review/extentions.rb +0 -1
  50. data/lib/review/extentions/hash.rb +2 -2
  51. data/lib/review/extentions/string.rb +5 -30
  52. data/lib/review/htmlbuilder.rb +320 -375
  53. data/lib/review/htmltoc.rb +4 -7
  54. data/lib/review/htmlutils.rb +29 -32
  55. data/lib/review/i18n.rb +33 -44
  56. data/lib/review/i18n.yml +3 -3
  57. data/lib/review/idgxmlbuilder.rb +309 -345
  58. data/lib/review/latexbuilder.rb +175 -212
  59. data/lib/review/latexindex.rb +2 -8
  60. data/lib/review/latexutils.rb +33 -43
  61. data/lib/review/lineinput.rb +1 -1
  62. data/lib/review/logger.rb +21 -0
  63. data/lib/review/makerhelper.rb +1 -4
  64. data/lib/review/markdownbuilder.rb +44 -53
  65. data/lib/review/md2inaobuilder.rb +6 -12
  66. data/lib/review/pdfmaker.rb +143 -173
  67. data/lib/review/preprocessor.rb +64 -101
  68. data/lib/review/rstbuilder.rb +126 -158
  69. data/lib/review/sec_counter.rb +18 -34
  70. data/lib/review/template.rb +4 -5
  71. data/lib/review/textbuilder.rb +2 -3
  72. data/lib/review/textutils.rb +7 -13
  73. data/lib/review/tocparser.rb +31 -56
  74. data/lib/review/tocprinter.rb +26 -52
  75. data/lib/review/topbuilder.rb +219 -247
  76. data/lib/review/unfold.rb +15 -24
  77. data/lib/review/version.rb +1 -1
  78. data/lib/review/webmaker.rb +75 -99
  79. data/lib/review/webtocprinter.rb +15 -20
  80. data/lib/review/yamlloader.rb +13 -15
  81. data/review.gemspec +20 -22
  82. data/templates/latex/layout.tex.erb +2 -2
  83. data/templates/opf/epubv2.opf.erb +7 -7
  84. data/templates/opf/epubv3.opf.erb +7 -7
  85. data/templates/web/html/layout-html5.html.erb +2 -2
  86. data/test/assets/black.eps +280 -0
  87. data/test/assets/fit.png +0 -0
  88. data/test/assets/large.gif +0 -0
  89. data/test/assets/large.jpg +0 -0
  90. data/test/assets/large.png +0 -0
  91. data/test/assets/large.svg +65 -0
  92. data/test/assets/test_template.tex +1 -1
  93. data/test/book_test_helper.rb +2 -2
  94. data/test/run_test.rb +4 -4
  95. data/test/sample-book/src/Rakefile +21 -22
  96. data/test/syntax-book/Gemfile +4 -0
  97. data/test/syntax-book/Rakefile +72 -0
  98. data/test/syntax-book/appA.re +22 -0
  99. data/test/syntax-book/bib.re +6 -0
  100. data/test/syntax-book/catalog.yml +15 -0
  101. data/test/syntax-book/ch01.re +136 -0
  102. data/test/syntax-book/ch02.re +351 -0
  103. data/test/syntax-book/ch03.re +82 -0
  104. data/test/syntax-book/config.yml +35 -0
  105. data/test/syntax-book/images/ball.png +0 -0
  106. data/test/syntax-book/images/cover.jpg +0 -0
  107. data/test/syntax-book/images/fractal.png +0 -0
  108. data/test/syntax-book/images/img3-1.png +0 -0
  109. data/test/syntax-book/images/inlineicon.jpg +0 -0
  110. data/test/syntax-book/images/logic.png +0 -0
  111. data/test/syntax-book/images/logic2.png +0 -0
  112. data/test/syntax-book/images/puzzle.jpg +0 -0
  113. data/test/syntax-book/images/table.jpg +0 -0
  114. data/test/syntax-book/part2.re +6 -0
  115. data/test/syntax-book/pre01.re +26 -0
  116. data/test/syntax-book/review-ext.rb +14 -0
  117. data/test/syntax-book/sty/jumoline.sty +310 -0
  118. data/test/syntax-book/sty/reviewmacro.sty +39 -0
  119. data/test/syntax-book/style.css +494 -0
  120. data/test/syntax-book/syntax.dic +2 -0
  121. data/test/test_book.rb +106 -111
  122. data/test/test_book_chapter.rb +21 -22
  123. data/test/test_book_part.rb +3 -5
  124. data/test/test_builder.rb +11 -22
  125. data/test/test_catalog.rb +17 -18
  126. data/test/test_catalog_converter_cmd.rb +5 -5
  127. data/test/test_compiler.rb +18 -16
  128. data/test/test_configure.rb +35 -38
  129. data/test/test_converter.rb +3 -4
  130. data/test/test_epub3maker.rb +136 -117
  131. data/test/test_epubmaker.rb +107 -114
  132. data/test/test_epubmaker_cmd.rb +2 -4
  133. data/test/test_extentions_hash.rb +32 -33
  134. data/test/test_helper.rb +9 -11
  135. data/test/test_htmlbuilder.rb +454 -420
  136. data/test/test_htmltoc.rb +8 -12
  137. data/test/test_htmlutils.rb +0 -2
  138. data/test/test_i18n.rb +159 -150
  139. data/test/test_idgxmlbuilder.rb +190 -197
  140. data/test/test_image_finder.rb +21 -22
  141. data/test/test_index.rb +24 -29
  142. data/test/test_latexbuilder.rb +274 -264
  143. data/test/test_lineinput.rb +7 -10
  144. data/test/test_location.rb +7 -7
  145. data/test/test_makerhelper.rb +13 -25
  146. data/test/test_markdownbuilder.rb +23 -26
  147. data/test/test_md2inaobuilder.rb +8 -11
  148. data/test/test_pdfmaker.rb +114 -123
  149. data/test/test_pdfmaker_cmd.rb +1 -3
  150. data/test/test_review_ext.rb +3 -5
  151. data/test/test_rstbuilder.rb +92 -97
  152. data/test/test_template.rb +3 -7
  153. data/test/test_textutils.rb +27 -27
  154. data/test/test_tocparser.rb +2 -2
  155. data/test/test_topbuilder.rb +98 -103
  156. data/test/test_webtocprinter.rb +5 -6
  157. data/test/test_yamlloader.rb +42 -42
  158. data/test/test_zip_exporter.rb +12 -18
  159. metadata +86 -9
  160. data/lib/review/ewbbuilder.rb +0 -382
@@ -1,6 +1,4 @@
1
1
  #!/usr/bin/env ruby
2
- # encoding: utf-8
3
-
4
2
  # Copyright (c) 2010-2017 Kenshi Muto and Masayoshi Takahashi
5
3
  #
6
4
  # This program is free software.
@@ -1,9 +1,7 @@
1
1
  #!/usr/bin/env ruby
2
2
  #
3
- # $Id: review-preproc 3761 2007-12-31 07:20:09Z aamine $
4
- #
5
3
  # Copyright (c) 2010-2014 Minero Aoki, Kenshi Muto
6
- # Copyright (c) 1999-2007 Minero Aoki
4
+ # 1999-2007 Minero Aoki
7
5
  #
8
6
  # This program is free software.
9
7
  # You can distribute or modify this program under the terms of
@@ -20,6 +18,7 @@ require 'review/preprocessor'
20
18
  require 'review/unfold'
21
19
  require 'review/version'
22
20
  require 'review/extentions'
21
+ require 'review/logger'
23
22
  require 'lineinput'
24
23
  require 'stringio'
25
24
  require 'fileutils'
@@ -36,11 +35,12 @@ rescue Errno::EPIPE
36
35
  end
37
36
 
38
37
  def main
39
- if File.file?("review-preproc-ext.rb")
40
- if ENV["REVIEW_SAFE_MODE"].to_i & 2 > 0
41
- warn "review-preproc-ext.rb is prohibited in safe mode. ignored."
38
+ @logger = ReVIEW.logger
39
+ if File.file?('review-preproc-ext.rb')
40
+ if ENV['REVIEW_SAFE_MODE'].to_i & 2 > 0
41
+ @logger.warn 'review-preproc-ext.rb is prohibited in safe mode. ignored.'
42
42
  else
43
- Kernel.load File.expand_path("review-preproc-ext.rb")
43
+ Kernel.load File.expand_path('review-preproc-ext.rb')
44
44
  end
45
45
  end
46
46
 
@@ -49,31 +49,21 @@ def main
49
49
  mode = :output
50
50
  opts = OptionParser.new
51
51
  opts.version = ReVIEW::VERSION
52
- opts.banner = "Usage: #{File.basename($0)} [-c|-d|-s|--replace] [<file>...]"
53
- opts.on('-c', '--check', 'Check if preprocess is needed.') {
54
- mode = :check
55
- }
56
- opts.on('-d', '--diff', 'Show diff from current file.') {
57
- mode = :diff
58
- }
59
- opts.on('--replace', 'Replace file by preprocessed one.') {
60
- mode = :replace
61
- }
62
- opts.on('-s', '--strip', 'Strip preprocessor tags.') {
63
- mode = :strip
64
- }
65
- opts.on('--final', 'Unfold text and strip preprocessor tags. (deprecated)') {
66
- mode = :final
67
- }
68
- opts.on('--tabwidth=WIDTH', "Replace tabs with space characters. (0: don't replace)") {|width| param["tabwidth"] = width.to_i }
69
- opts.on('--help', 'Print this message and quit.') {
52
+ opts.banner = "Usage: #{File.basename($PROGRAM_NAME)} [-c|-d|-s|--replace] [<file>...]"
53
+ opts.on('-c', '--check', 'Check if preprocess is needed.') { mode = :check }
54
+ opts.on('-d', '--diff', 'Show diff from current file.') { mode = :diff }
55
+ opts.on('--replace', 'Replace file by preprocessed one.') { mode = :replace }
56
+ opts.on('-s', '--strip', 'Strip preprocessor tags.') { mode = :strip }
57
+ opts.on('--final', 'Unfold text and strip preprocessor tags. (deprecated)') { mode = :final }
58
+ opts.on('--tabwidth=WIDTH', "Replace tabs with space characters. (0: don't replace)") { |width| param['tabwidth'] = width.to_i }
59
+ opts.on('--help', 'Print this message and quit.') do
70
60
  puts opts.help
71
61
  exit 0
72
- }
62
+ end
73
63
  begin
74
64
  opts.parse!
75
65
  rescue OptionParser::ParseError => err
76
- $stderr.puts err.message
66
+ @logger.error err.message
77
67
  $stderr.puts opts.help
78
68
  exit 1
79
69
  end
@@ -84,9 +74,7 @@ def main
84
74
  current_file = path
85
75
  case mode
86
76
  when :output
87
- File.open(path) {|f|
88
- pp.process f, $stdout
89
- }
77
+ File.open(path) { |f| pp.process f, $stdout }
90
78
  when :replace
91
79
  File.write "#{path}.pptmp", preproc(pp, path)
92
80
  File.rename "#{path}.pptmp", path
@@ -103,38 +91,30 @@ def main
103
91
  FileUtils.rm_f tmp
104
92
  end
105
93
  when :strip
106
- File.open(path) {|f|
107
- ReVIEW::Preprocessor::Strip.new(f).each do |line|
108
- puts line
109
- end
110
- }
94
+ File.open(path) do |f|
95
+ ReVIEW::Preprocessor::Strip.new(f).each { |line| puts line }
96
+ end
111
97
  when :final
112
98
  u = ReVIEW::Unfold.new
113
- File.open(path) {|f|
114
- u.unfold ReVIEW::Preprocessor::Strip.new(f), $stdout
115
- }
99
+ File.open(path) { |f| u.unfold ReVIEW::Preprocessor::Strip.new(f), $stdout }
116
100
  else
117
101
  raise "must not happen: #{mode}"
118
102
  end
119
103
  end
120
104
  rescue ReVIEW::Error => err
121
105
  raise if $DEBUG
122
- $stderr.puts err.message
106
+ @logger.error err.message
123
107
  exit 1
124
108
  end
125
109
 
126
110
  def preproc(pp, path)
127
111
  buf = StringIO.new
128
- File.open(path) {|f|
129
- pp.process f, buf
130
- }
112
+ File.open(path) { |f| pp.process f, buf }
131
113
  buf.string
132
114
  end
133
115
 
134
116
  def File.write(path, str)
135
- File.open(path, 'w') {|f|
136
- f.write str
137
- }
117
+ File.open(path, 'w') { |f| f.write str }
138
118
  end
139
119
 
140
120
  sigmain
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env ruby
2
- # Copyright (c) 2010-2016 Kenshi Muto
2
+ # Copyright (c) 2010-2017 Kenshi Muto
3
3
  #
4
4
  # This program is free software
5
5
  # You can distribute or modify this program under the terms of
@@ -8,45 +8,46 @@
8
8
  #
9
9
 
10
10
  # simple validator for Re:VIEW
11
+ require 'pathname'
12
+
13
+ bindir = Pathname.new(__FILE__).realpath.dirname
14
+ $LOAD_PATH.unshift((bindir + '../lib').realpath)
15
+ require 'review/logger'
11
16
 
12
17
  block = nil
13
18
  maxcolcount = 0
14
19
  colcount = 0
15
20
  ln = 0
16
21
 
17
- ARGF.each {|line|
22
+ @logger = ReVIEW.logger
23
+
24
+ ARGF.each do |line|
18
25
  ln += 1
19
- if line =~ /\A\/\/([a-z]+)\{\s*\Z/ || line =~ /\A\/\/([a-z]+)\[.+?\{\s*\Z/
26
+ if line =~ %r{\A//([a-z]+)\{\s*\Z} || line =~ %r{\A//([a-z]+)\[.+?\{\s*\Z}
20
27
  # block
21
28
  new_block = $1
22
- puts "#{ln}: block #{new_block} started, but previous block #{block} didn't close yet." unless block.nil?
29
+ @logger.warn "#{ln}: block #{new_block} started, but previous block #{block} didn't close yet." if block
23
30
  block = new_block
24
- elsif line =~ /\A\/\/\}/
25
- puts "#{ln}: block ended, but not opened." if block.nil?
31
+ elsif line =~ %r{\A//\}}
32
+ @logger.warn "#{ln}: block ended, but not opened." if block.nil?
26
33
  block = nil
27
34
  maxcolcount = 0
28
35
  colcount = 0
29
36
  elsif line =~ /\A(\d+\.)\s+/
30
37
  # number
31
- unless ["list", "emlist", "listnum", "emlistnum", "cmd", "image", "table"].include?(block)
32
- puts "#{ln}: found '#{$1}' without the head space. Is it correct?"
33
- end
38
+ @logger.warn "#{ln}: found '#{$1}' without the head space. Is it correct?" unless %w[list emlist listnum emlistnum cmd image table].include?(block)
34
39
  elsif line =~ /\A\*\s+/
35
40
  # itemize
36
- unless ["list", "emlist", "listnum", "emlistnum", "cmd", "image", "table"].include?(block)
37
- puts "#{ln}: found '*' without the head space. Is it correct?"
38
- end
41
+ @logger.warn "#{ln}: found '*' without the head space. Is it correct?" unless %w[list emlist listnum emlistnum cmd image table].include?(block)
39
42
  elsif line =~ /\A\s+(\d+\.)\s+/ && line =~ /\A\s+\*\s+/
40
- unless ["list", "emlist", "listnum", "emlistnum", "cmd", "image", "table"].include?(block)
41
- puts "#{ln}: found itemized list or numbered list in #{block}. Is it correct?"
42
- end
43
- elsif block == "table"
43
+ @logger.warn "#{ln}: found itemized list or numbered list in #{block}. Is it correct?" unless Tw[list emlist listnum emlistnum cmd image table].include?(block)
44
+ elsif block == 'table'
44
45
  next if line.start_with?('#@')
45
46
  if line !~ /\A\-\-\-\-\-/
46
47
  # table
47
48
  colcount = line.split("\t").size
48
49
  maxcolcount = colcount if maxcolcount == 0
49
- puts "#{ln}: the number of table columns seems mismatch. (#{maxcolcount} != #{colcount})" if colcount != maxcolcount
50
+ @logger.warn "#{ln}: the number of table columns seems mismatch. (#{maxcolcount} != #{colcount})" if colcount != maxcolcount
50
51
  end
51
52
  end
52
- }
53
+ end
@@ -1,8 +1,7 @@
1
1
  #!/usr/bin/env ruby
2
2
  #
3
- # $Id: review-vol 3901 2008-02-11 20:04:59Z aamine $
4
- #
5
- # Copyright (c) 2003-2014 Minero Aoki
3
+ # Copyright (c) 2014-2017 Minero Aoki, Kenshi Muto
4
+ # 2003-2014 Minero Aoki
6
5
  #
7
6
  # This program is free software.
8
7
  # You can distribute or modify this program under the terms of
@@ -21,6 +20,7 @@ require 'optparse'
21
20
  include ReVIEW::TextUtils
22
21
 
23
22
  def main
23
+ @logger = ReVIEW.logger
24
24
  @config = ReVIEW::Configure.values
25
25
 
26
26
  part_sensitive = false
@@ -28,55 +28,43 @@ def main
28
28
  yamlfile = nil
29
29
  opts = OptionParser.new
30
30
  opts.version = ReVIEW::VERSION
31
- opts.on('--yaml=YAML', 'Read configurations from YAML file.') do |yaml|
32
- yamlfile = yaml
33
- end
34
- opts.on('-P', '--part-sensitive', 'Prints volume of each parts.') {
35
- part_sensitive = true
36
- }
37
- opts.on('--directory=DIR', 'Compile all chapters in DIR.') {|path|
38
- basedir = path
39
- }
40
- opts.on('--help', 'Print this message and quit') {
31
+ opts.on('--yaml=YAML', 'Read configurations from YAML file.') { |yaml| yamlfile = yaml }
32
+ opts.on('-P', '--part-sensitive', 'Prints volume of each parts.') { part_sensitive = true }
33
+ opts.on('--directory=DIR', 'Compile all chapters in DIR.') { |path| basedir = path }
34
+ opts.on('--help', 'Print this message and quit') do
41
35
  puts opts.help
42
36
  exit 0
43
- }
37
+ end
44
38
  begin
45
39
  opts.parse!
46
40
  rescue OptionParser::ParseError => err
47
- $stderr.puts err.message
41
+ @logger.error err.message
48
42
  $stderr.puts opts.help
49
43
  exit 1
50
44
  end
51
45
 
52
46
  book = basedir ? ReVIEW::Book.load(basedir) : ReVIEW::Book::Base.load
53
47
  book.config = @config
54
- if yamlfile
55
- book.load_config(yamlfile)
56
- end
48
+ book.load_config(yamlfile) if yamlfile
57
49
 
58
50
  if part_sensitive
59
- sep = ""
51
+ sep = ''
60
52
  book.each_part do |part|
61
53
  print sep
62
54
  sep = "\n"
63
55
  puts "Part #{part.number} #{part.name}" if part.number
64
- part.each_chapter do |chap|
65
- print_chapter_volume chap
66
- end
56
+ part.each_chapter { |chap| print_chapter_volume chap }
67
57
  puts ' --------------------'
68
58
  print_volume part.volume
69
59
  end
70
60
  else
71
- book.each_chapter do |chap|
72
- print_chapter_volume chap
73
- end
61
+ book.each_chapter { |chap| print_chapter_volume chap }
74
62
  end
75
63
  puts '============================='
76
- print_volume book.volume #puts "Total #{book.volume}"
64
+ print_volume book.volume # puts "Total #{book.volume}"
77
65
  rescue ReVIEW::ApplicationError, Errno::ENOENT => err
78
66
  raise if $DEBUG
79
- $stderr.puts "#{File.basename($0)}: #{err.message}"
67
+ @logger.error "#{File.basename($PROGRAM_NAME)}: #{err.message}"
80
68
  exit 1
81
69
  end
82
70
 
@@ -134,8 +134,8 @@ secnolevel: 2
134
134
  # 表紙に配置し、書籍の影絵にも利用する画像ファイル。省略した場合はnull (画像を使わない)。画像ディレクトリ内に置いてもディレクトリ名は不要(例: cover.jpg)
135
135
  # coverimage: null
136
136
  #
137
- # 表紙の後に大扉ページを作成するか。省略した場合はnull (作成しない)
138
- # titlepage: null
137
+ # 表紙の後に大扉ページを作成するか。省略した場合はtrue (作成する)
138
+ # titlepage: true
139
139
  #
140
140
  # 自動生成される大扉ページを上書きするファイル。ファイル名を指定すると大扉として入る (PDFMaker向けにはLaTeXソース断片、EPUBMaker向けにはHTMLファイル)
141
141
  # titlefile: null
@@ -252,6 +252,9 @@ epubmaker:
252
252
  # verify_target_imagesがtrueの状態において、解析で発見されなくても強制的に取り込むファイルの相対パスの配列
253
253
  # force_include_images: []
254
254
  #
255
+ # 画像ファイルの縦x横の最大ピクセル数許容値
256
+ # image_maxpixels: 4000000
257
+ #
255
258
  # Re:VIEWファイル名を使わず、前付にpre01,pre02...、本文にchap01,chap02l...、後付にpost01,post02...という名前付けルールにするか
256
259
  # rename_for_legacy: null
257
260
  #
@@ -155,7 +155,7 @@ Re:VIEW フォーマットの文法について解説します。Re:VIEW フォ
155
155
  @<命令>{対象の内容}
156
156
  ```
157
157
 
158
- 内容に「}」という文字が必要であれば、`\}` でリテラルを表現できます。
158
+ 内容に「}」という文字が必要であれば、`\}` でリテラルを表現できます。なお、内容の末尾を「\」としたい場合は、`\\` と記述する必要があります(たとえば `@<tt>{\\}`)。
159
159
 
160
160
  記法および処理の都合で、次のような制約があります。
161
161
 
@@ -163,6 +163,25 @@ Re:VIEW フォーマットの文法について解説します。Re:VIEW フォ
163
163
  * ブロック命令内には見出しや箇条書きを格納できません。
164
164
  * インライン命令には別のインライン命令をネストできません。
165
165
 
166
+ ### インライン命令のフェンス記法
167
+
168
+ インライン命令において `}` や 末尾 `\` を多用したい場合、それぞれ `\}` や `\\` のようにエスケープするのはわずらわしいことがあります。そのようなときには、インライン命令の囲みの `{ }` の代わりに `$ $` あるいは `| |` を使って内容を囲むことで、エスケープ表記せずに記述できます。
169
+
170
+ ```
171
+ @<命令>$対象の内容$
172
+ @<命令>|対象の内容|
173
+ ```
174
+
175
+ 例:
176
+
177
+ ```review
178
+ @<m>$\Delta = \frac{\partial^2}{\partial x_1^2}+\frac{\partial^2}{\partial x_2^2} + \cdots + \frac{\partial^2}{\partial x_n^2}$
179
+ @<tt>|if (exp) then { ... } else { ... }|
180
+ @<b>|\|
181
+ ```
182
+
183
+ あくまでも代替であり、推奨する記法ではありません。濫用は避けてください。
184
+
166
185
  ## ソースコードなどのリスト
167
186
 
168
187
  ソースコードなどのリストには`//list`を使います。連番を付けたくない場合は先頭に `em`(embedded の略)、行番号を付ける場合は末尾に `num` を付加します。まとめると、以下の4種類になります。
@@ -115,7 +115,6 @@ They aren't nested.
115
115
 
116
116
  Usage:
117
117
 
118
-
119
118
  ```
120
119
  1. 1st condition
121
120
  2. 2nd condition
@@ -185,7 +184,7 @@ Inline commands are used in block, paragraphes, headings, block contents and bl
185
184
  @<command>{content}
186
185
  ```
187
186
 
188
- When you want to use a character `}` in inline content, you must use escaping `\}`.
187
+ When you want to use a character `}` in inline content, you must use escaping `\}`. If the content ends with `\`, it must be written `\\`. (ex. `@<tt>{\\}`)
189
188
 
190
189
  There are some limitations in blocks and inlines.
191
190
 
@@ -193,6 +192,24 @@ There are some limitations in blocks and inlines.
193
192
  * You cannot write headings and itemize in block contents.
194
193
  * Inline commands also do not support nestins. You cannot write inlines in another inline.
195
194
 
195
+ ### Fence notation for inline commands
196
+ You may be tired of escaping when you use a large number of inline commands including `{` and `\`. By surrounding the contents with `$ $` or `| |` instead of `{ }`, you can write without escaping.
197
+
198
+ ```
199
+ @<command>$content$
200
+ @<command>|content|
201
+ ```
202
+
203
+ Example:
204
+
205
+ ```review
206
+ @<m>$\Delta = \frac{\partial^2}{\partial x_1^2}+\frac{\partial^2}{\partial x_2^2} + \cdots + \frac{\partial^2}{\partial x_n^2}$
207
+ @<tt>|if (exp) then { ... } else { ... }|
208
+ @<b>|\|
209
+ ```
210
+
211
+ Since this notation is substitute, please avoid abuse.
212
+
196
213
  ## Code List
197
214
 
198
215
  Code list like source codes is `//list`. If you don't need numbers, you can use ``em`` prefix (as embedded). If you need line numbers, you can use ``num`` postfix. So you can use four types of lists.
@@ -518,10 +535,9 @@ is in footnotes.
518
535
 
519
536
  Note that In LATEXBuilder, you should use `footnotetext` option to use `@<fn>{...}` in columns and tables.
520
537
 
521
- ### `--footnotetext` option
538
+ ### `footnotetext` option
522
539
 
523
- When you want to use `footnotetext` option, you can add `--footnotetext` with `params` in config.yml.
524
- With this option, you can use footnote in tables and short notes.
540
+ By adding `footnotetext:true` in config.yml, you can use footnote in tables and short notes.
525
541
 
526
542
  Note that there are some constraints that (because of normal footnote )
527
543
 
@@ -1,5 +1,3 @@
1
- # encoding: utf-8
2
-
3
1
  # = epubmaker.rb -- EPUB production set.
4
2
  #
5
3
  # Copyright (c) 2010-2017 Kenshi Muto
@@ -12,7 +10,7 @@
12
10
  # == Quick usage
13
11
  # require 'epubmaker'
14
12
  # producer = EPUBMaker::Producer.new
15
- # params = producer.load("config.yml")
13
+ # config = producer.load("config.yml")
16
14
  # producer.contents.push(EPUBMaker::Content.new({"file" => "ch01.xhtml"}))
17
15
  # producer.contents.push(EPUBMaker::Content.new({"file" => "ch02.xhtml"}))
18
16
  # ...
@@ -1,5 +1,3 @@
1
- # encoding: utf-8
2
-
3
1
  # = content.rb -- Content object for EPUBMaker.
4
2
  #
5
3
  # Copyright (c) 2010-2017 Kenshi Muto
@@ -11,7 +9,6 @@
11
9
  #
12
10
 
13
11
  module EPUBMaker
14
-
15
12
  # EPUBMaker::Content represents a content data for EPUBMaker.
16
13
  # EPUBMaker#contents takes an array of Content.
17
14
  class Content
@@ -32,22 +29,26 @@ module EPUBMaker
32
29
  # Chapter type (pre/post/part/nil(body))
33
30
  attr_accessor :chaptype
34
31
 
32
+ def inspect
33
+ "<Content id=#{@id}, file=#{@file}, media=#{@media}, title=#{@title}, level=#{@level}, notoc=#{@notoc}, properties=#{@properties}, chaptype=#{@chaptype}>"
34
+ end
35
+
35
36
  # :call-seq:
36
37
  # initialize(file, id, media, title, level, notoc)
37
38
  # initialize(hash)
38
39
  # Construct Content object by passing a sequence of parameters or hash.
39
40
  # Keys of +hash+ relate with each parameters.
40
41
  # +file+ (or +hash+["file"]) is required. Others are optional.
41
- def initialize(fileorhash, id=nil, media=nil, title=nil, level=nil, notoc=nil, properties=nil, chaptype=nil)
42
+ def initialize(fileorhash, id = nil, media = nil, title = nil, level = nil, notoc = nil, properties = nil, chaptype = nil)
42
43
  if fileorhash.instance_of?(Hash)
43
- @id = fileorhash["id"]
44
- @file = fileorhash["file"]
45
- @media = fileorhash["media"]
46
- @title = fileorhash["title"]
47
- @level = fileorhash["level"]
48
- @notoc = fileorhash["notoc"]
49
- @properties = fileorhash["properties"] || []
50
- @chaptype = fileorhash["chaptype"]
44
+ @id = fileorhash['id']
45
+ @file = fileorhash['file']
46
+ @media = fileorhash['media']
47
+ @title = fileorhash['title']
48
+ @level = fileorhash['level']
49
+ @notoc = fileorhash['notoc']
50
+ @properties = fileorhash['properties'] || []
51
+ @chaptype = fileorhash['chaptype']
51
52
  else
52
53
  @file = fileorhash
53
54
  @id = id
@@ -62,9 +63,7 @@ module EPUBMaker
62
63
  end
63
64
 
64
65
  def ==(other)
65
- if self.class != other.class
66
- return false
67
- end
66
+ return false unless self.class == other.class
68
67
  [self.id, self.file, self.media, self.title, self.level, self.notoc, self.chaptype, self.properties] ==
69
68
  [other.id, other.file, other.media, other.title, other.level, other.notoc, other.chaptype, other.properties]
70
69
  end
@@ -73,22 +72,20 @@ module EPUBMaker
73
72
 
74
73
  # Complement other parameters by using file parameter.
75
74
  def complement
76
- @id = @file.gsub(/[\\\/\. ]/, '-') if @id.nil?
75
+ @id = @file.gsub(%r{[\\/\. ]}, '-') if @id.nil?
77
76
  @id = "rv-#{@id}" if @id =~ /\A[^a-z]/i
78
77
  @media = @file.sub(/.+\./, '').downcase if !@file.nil? && @media.nil?
79
78
 
80
- @media = "application/xhtml+xml" if @media == "xhtml" || @media == "xml" || @media == "html"
81
- @media = "text/css" if @media == "css"
82
- @media = "image/jpeg" if @media == "jpg" || @media == "jpeg" || @media == "image/jpg"
83
- @media = "image/png" if @media == "png"
84
- @media = "image/gif" if @media == "gif"
85
- @media = "image/svg+xml" if @media == "svg" || @media == "image/svg"
86
- @media = "application/vnd.ms-opentype" if @media == "ttf" || @media == "otf"
87
- @media = "application/font-woff" if @media == "woff"
79
+ @media = 'application/xhtml+xml' if @media == 'xhtml' || @media == 'xml' || @media == 'html'
80
+ @media = 'text/css' if @media == 'css'
81
+ @media = 'image/jpeg' if @media == 'jpg' || @media == 'jpeg' || @media == 'image/jpg'
82
+ @media = 'image/png' if @media == 'png'
83
+ @media = 'image/gif' if @media == 'gif'
84
+ @media = 'image/svg+xml' if @media == 'svg' || @media == 'image/svg'
85
+ @media = 'application/vnd.ms-opentype' if @media == 'ttf' || @media == 'otf'
86
+ @media = 'application/font-woff' if @media == 'woff'
88
87
 
89
- if @id.nil? || @file.nil? || @media.nil?
90
- raise "Type error: #{id}, #{file}, #{media}, #{title}, #{notoc}"
91
- end
88
+ raise "Type error: #{id}, #{file}, #{media}, #{title}, #{notoc}" if @id.nil? || @file.nil? || @media.nil?
92
89
  end
93
90
  end
94
91
  end