review 1.4.0 → 1.5.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (87) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -1
  3. data/.travis.yml +1 -0
  4. data/ChangeLog +87 -0
  5. data/bin/review-check +2 -2
  6. data/bin/review-compile +15 -30
  7. data/bin/review-index +1 -1
  8. data/bin/review-init +12 -7
  9. data/bin/review-vol +9 -1
  10. data/doc/catalog.ja.md +53 -0
  11. data/doc/catalog.md +52 -0
  12. data/doc/format.ja.md +734 -0
  13. data/doc/format.md +746 -0
  14. data/doc/format_idg.ja.md +203 -0
  15. data/doc/{quickstart.rdoc → quickstart.ja.md} +138 -104
  16. data/doc/quickstart.md +252 -0
  17. data/doc/sample.yml +216 -48
  18. data/lib/epubmaker.rb +0 -1
  19. data/lib/epubmaker/content.rb +2 -2
  20. data/lib/epubmaker/epubcommon.rb +440 -0
  21. data/lib/epubmaker/epubv2.rb +8 -418
  22. data/lib/epubmaker/epubv3.rb +67 -61
  23. data/lib/epubmaker/producer.rb +60 -19
  24. data/lib/review/book.rb +1 -3
  25. data/lib/review/book/base.rb +18 -11
  26. data/lib/review/book/chapter.rb +5 -24
  27. data/lib/review/book/compilable.rb +5 -1
  28. data/lib/review/book/index.rb +48 -17
  29. data/lib/review/book/page_metric.rb +17 -8
  30. data/lib/review/book/part.rb +12 -2
  31. data/lib/review/book/volume.rb +3 -2
  32. data/lib/review/builder.rb +30 -10
  33. data/lib/review/compiler.rb +6 -4
  34. data/lib/review/configure.rb +3 -3
  35. data/lib/review/epubmaker.rb +56 -26
  36. data/lib/review/htmlbuilder.rb +33 -42
  37. data/lib/review/htmlutils.rb +12 -7
  38. data/lib/review/i18n.rb +77 -17
  39. data/lib/review/i18n.yml +80 -4
  40. data/lib/review/idgxmlbuilder.rb +27 -57
  41. data/lib/review/inaobuilder.rb +3 -3
  42. data/lib/review/latexbuilder.rb +90 -67
  43. data/lib/review/layout.tex.erb +54 -7
  44. data/lib/review/markdownbuilder.rb +21 -3
  45. data/lib/review/pdfmaker.rb +67 -38
  46. data/lib/review/sec_counter.rb +1 -1
  47. data/lib/review/tocparser.rb +9 -5
  48. data/lib/review/topbuilder.rb +6 -6
  49. data/lib/review/version.rb +1 -1
  50. data/review.gemspec +3 -1
  51. data/test/book_test_helper.rb +1 -1
  52. data/test/sample-book/README.md +2 -0
  53. data/test/sample-book/src/Rakefile +31 -0
  54. data/test/sample-book/src/_cover.html +0 -0
  55. data/test/sample-book/src/catalog.yml +10 -0
  56. data/test/sample-book/src/ch01.re +0 -0
  57. data/test/sample-book/src/ch02.re +0 -0
  58. data/test/sample-book/src/config.yml +160 -32
  59. data/test/sample-book/src/images/ch01-imgsample.jpg +0 -0
  60. data/test/sample-book/src/images/cover.jpg +0 -0
  61. data/test/sample-book/src/preface.re +0 -0
  62. data/test/sample-book/src/sty/jumoline.sty +0 -0
  63. data/test/sample-book/src/sty/reviewmacro.sty +18 -0
  64. data/test/sample-book/src/style.css +0 -0
  65. data/test/test_book.rb +25 -27
  66. data/test/test_book_chapter.rb +4 -73
  67. data/test/test_book_part.rb +5 -4
  68. data/test/test_builder.rb +3 -3
  69. data/test/test_epub3maker.rb +527 -0
  70. data/test/test_epubmaker.rb +6 -6
  71. data/test/test_htmlbuilder.rb +143 -6
  72. data/test/test_i18n.rb +95 -10
  73. data/test/test_idgxmlbuilder.rb +28 -2
  74. data/test/test_index.rb +109 -1
  75. data/test/test_latexbuilder.rb +51 -0
  76. data/test/test_markdownbuilder.rb +54 -1
  77. data/test/test_pdfmaker.rb +7 -6
  78. data/test/test_review_ext.rb +31 -0
  79. data/test/test_topbuilder.rb +3 -1
  80. metadata +46 -13
  81. data/doc/catalog.rdoc +0 -49
  82. data/doc/format.rdoc +0 -618
  83. data/doc/format_idg.rdoc +0 -180
  84. data/doc/libepubmaker/config.yml +0 -207
  85. data/lib/epubmaker/resource.rb +0 -82
  86. data/test/sample-book/src/CHAPS +0 -2
  87. data/test/sample-book/src/PREDEF +0 -1
@@ -1,7 +1,7 @@
1
1
  # encoding: utf-8
2
2
  # = epubv2.rb -- EPUB version 2 producer.
3
3
  #
4
- # Copyright (c) 2010-2014 Kenshi Muto and Masayoshi Takahashi
4
+ # Copyright (c) 2010-2015 Kenshi Muto and Masayoshi Takahashi
5
5
  #
6
6
  # This program is free software.
7
7
  # You can distribute or modify this program under the terms of
@@ -9,21 +9,16 @@
9
9
  # For details of the GNU LGPL, see the file "COPYING".
10
10
  #
11
11
 
12
- require 'epubmaker/producer'
12
+ require 'epubmaker/epubcommon'
13
13
  require 'cgi'
14
14
 
15
15
  module EPUBMaker
16
16
 
17
17
  # EPUBv2 is EPUB version 2 producer.
18
- class EPUBv2
18
+ class EPUBv2 < EPUBCommon
19
19
  # Construct object with parameter hash +params+ and message resource hash +res+.
20
20
  def initialize(producer)
21
- @producer = producer
22
- end
23
-
24
- # Return mimetype content.
25
- def mimetype
26
- "application/epub+zip"
21
+ super
27
22
  end
28
23
 
29
24
  # Return opf file content.
@@ -88,22 +83,6 @@ EOT
88
83
  s
89
84
  end
90
85
 
91
- def opf_coverimage
92
- s = ""
93
- if @producer.params["coverimage"]
94
- file = nil
95
- @producer.contents.each do |item|
96
- if item.media =~ /\Aimage/ && item.file =~ /#{@producer.params["coverimage"]}\Z/
97
- s << %Q[ <meta name="cover" content="#{item.id}"/>\n]
98
- file = item.file
99
- break
100
- end
101
- end
102
- raise "coverimage #{@producer.params["coverimage"]} not found. Abort." if file.nil?
103
- end
104
- s
105
- end
106
-
107
86
  def opf_manifest
108
87
  s = ""
109
88
  s << <<EOT
@@ -112,7 +91,7 @@ EOT
112
91
  <item id="#{@producer.params["bookname"]}" href="#{@producer.params["cover"]}" media-type="application/xhtml+xml"/>
113
92
  EOT
114
93
 
115
- s << %Q[ <item id="toc" href="#{@producer.params["bookname"]}-toc.#{@producer.params["htmlext"]}" media-type="application/xhtml+xml"/>\n] unless @producer.params["mytoc"].nil?
94
+ s << %Q[ <item id="toc" href="#{@producer.params["bookname"]}-toc.#{@producer.params["htmlext"]}" media-type="application/xhtml+xml"/>\n] if @producer.params["toc"] && @producer.params["mytoc"]
116
95
 
117
96
  @producer.contents.each do |item|
118
97
  next if item.file =~ /#/ # skip subgroup
@@ -123,7 +102,7 @@ EOT
123
102
  end
124
103
 
125
104
  def opf_tocx
126
- if @producer.params["cover_linear"] && @producer.params["cover_linear"] != "no"
105
+ if @producer.params["epubmaker"]["cover_linear"] && @producer.params["epubmaker"]["cover_linear"] != "no"
127
106
  cover_linear = "yes"
128
107
  else
129
108
  cover_linear = "no"
@@ -177,408 +156,19 @@ EOT
177
156
  s
178
157
  end
179
158
 
180
- def ncx_isbn
181
- if @producer.params["isbn"].nil?
182
- %Q[ <meta name="dtb:uid" content="#{@producer.params["urnid"]}"/>\n]
183
- else
184
- %Q[ <meta name="dtb:uid" content="#{@producer.params["isbn"]}"/>\n]
185
- end
186
- end
187
-
188
- def ncx_doctitle
189
- <<EOT
190
- <docTitle>
191
- <text>#{CGI.escapeHTML(@producer.params["title"])}</text>
192
- </docTitle>
193
- <docAuthor>
194
- <text>#{@producer.params["aut"].nil? ? "" : CGI.escapeHTML(@producer.params["aut"].join(", "))}</text>
195
- </docAuthor>
196
- EOT
197
- end
198
-
199
- def ncx_navmap(indentarray)
200
- s = <<EOT
201
- <navMap>
202
- <navPoint id="top" playOrder="1">
203
- <navLabel>
204
- <text>#{CGI.escapeHTML(@producer.params["title"])}</text>
205
- </navLabel>
206
- <content src="#{@producer.params["cover"]}"/>
207
- </navPoint>
208
- EOT
209
-
210
- nav_count = 2
211
-
212
- unless @producer.params["mytoc"].nil?
213
- s << <<EOT
214
- <navPoint id="toc" playOrder="#{nav_count}">
215
- <navLabel>
216
- <text>#{@producer.res.v("toctitle")}</text>
217
- </navLabel>
218
- <content src="#{@producer.params["bookname"]}-toc.#{@producer.params["htmlext"]}"/>
219
- </navPoint>
220
- EOT
221
- nav_count += 1
222
- end
223
-
224
- @producer.contents.each do |item|
225
- next if item.title.nil?
226
- indent = indentarray.nil? ? [""] : indentarray
227
- level = item.level.nil? ? 0 : (item.level - 1)
228
- level = indent.size - 1 if level >= indent.size
229
- s << <<EOT
230
- <navPoint id="nav-#{nav_count}" playOrder="#{nav_count}">
231
- <navLabel>
232
- <text>#{indent[level]}#{CGI.escapeHTML(item.title)}</text>
233
- </navLabel>
234
- <content src="#{item.file}"/>
235
- </navPoint>
236
- EOT
237
- nav_count += 1
238
- end
239
-
240
- s << <<EOT
241
- </navMap>
242
- EOT
243
- s
244
- end
245
-
246
- # Return container content.
247
- def container
248
- s = <<EOT
249
- <?xml version="1.0" encoding="UTF-8"?>
250
- <container xmlns="urn:oasis:names:tc:opendocument:xmlns:container" version="1.0">
251
- <rootfiles>
252
- <rootfile full-path="OEBPS/#{@producer.params["bookname"]}.opf" media-type="application/oebps-package+xml" />
253
- </rootfiles>
254
- </container>
255
- EOT
256
- s
257
- end
258
-
259
- # Return cover content.
260
- def cover(type=nil)
261
- bodyext = type.nil? ? "" : " epub:type=\"#{type}\""
262
-
263
- s = common_header
264
- s << <<EOT
265
- <title>#{CGI.escapeHTML(@producer.params["title"])}</title>
266
- </head>
267
- <body#{bodyext}>
268
- EOT
269
- if @producer.params["coverimage"].nil?
270
- s << <<EOT
271
- <h1 class="cover-title">#{CGI.escapeHTML(@producer.params["title"])}</h1>
272
- EOT
273
- else
274
- file = nil
275
- @producer.contents.each do |item|
276
- if item.media =~ /\Aimage/ && item.file =~ /#{@producer.params["coverimage"]}\Z/ # /
277
- file = item.file
278
- break
279
- end
280
- end
281
- raise "coverimage #{@producer.params["coverimage"]} not found. Abort." if file.nil?
282
- s << <<EOT
283
- <div id="cover-image" class="cover-image">
284
- <img src="#{file}" alt="#{CGI.escapeHTML(@producer.params["title"])}" class="max"/>
285
- </div>
286
- EOT
287
- end
288
-
289
- s << <<EOT
290
- </body>
291
- </html>
292
- EOT
293
- s
294
- end
295
-
296
- # Return title (copying) content.
297
- def titlepage
298
- s = common_header
299
- s << <<EOT
300
- <title>#{CGI.escapeHTML(@producer.params["title"])}</title>
301
- </head>
302
- <body>
303
- <h1 class="tp-title">#{CGI.escapeHTML(@producer.params["title"])}</h1>
304
- EOT
305
-
306
- if @producer.params["aut"]
307
- s << <<EOT
308
- <p>
309
- <br />
310
- <br />
311
- </p>
312
- <h2 class="tp-author">#{CGI.escapeHTML(@producer.params["aut"].join(", "))}</h2>
313
- EOT
314
- end
315
-
316
- if @producer.params["prt"]
317
- s << <<EOT
318
- <p>
319
- <br />
320
- <br />
321
- <br />
322
- <br />
323
- </p>
324
- <h3 class="tp-publisher">#{CGI.escapeHTML(@producer.params["prt"].join(", "))}</h3>
325
- EOT
326
- end
327
-
328
- s << <<EOT
329
- </body>
330
- </html>
331
- EOT
332
-
333
- s
334
- end
335
-
336
- # Return colophon content.
337
- def colophon
338
- s = common_header
339
- s << <<EOT
340
- <title>#{@producer.res.v("colophontitle")}</title>
341
- </head>
342
- <body>
343
- <div class="colophon">
344
- EOT
345
-
346
- if @producer.params["subtitle"].nil?
347
- s << <<EOT
348
- <p class="title">#{CGI.escapeHTML(@producer.params["title"])}</p>
349
- EOT
350
- else
351
- s << <<EOT
352
- <p class="title">#{CGI.escapeHTML(@producer.params["title"])}<br /><span class="subtitle">#{CGI.escapeHTML(@producer.params["subtitle"])}</span></p>
353
- EOT
354
- end
355
-
356
- if @producer.params["date"] || @producer.params["history"]
357
- s << %Q[ <div class="pubhistory">\n]
358
- if @producer.params["history"]
359
- @producer.params["history"].each_with_index do |items, edit|
360
- items.each_with_index do |item, rev|
361
- editstr = (edit == 0) ? "初版" : "第#{edit + 1}版" # FIXME:i18n
362
- revstr = "第#{rev + 1}刷"
363
- if item =~ /\A\d+\-\d+\-\d+\Z/
364
- s << %Q[ <p>#{date_to_s(item)} #{editstr}#{revstr} 発行</p>\n] # FIXME:i18n
365
- else
366
- # custom date with string
367
- item.match(/\A(\d+\-\d+\-\d+)[\s ](.+)/) do |m|
368
- s << %Q[ <p>#{date_to_s(m[1])} #{m[2]}</p>\n]
369
- end
370
- end
371
- end
372
- end
373
- else
374
- s << %Q[ <p>#{date_to_s(@producer.params["date"])} 発行</p>\n] #FIXME:i18n
375
- end
376
- s << %Q[ </div>\n]
377
- end
378
-
379
- s << %Q[ <table class="colophon">\n]
380
- s << %Q[ <tr><th>#{@producer.res.v("c-aut")}</th><td>#{CGI.escapeHTML(@producer.params["aut"].join(", "))}</td></tr>\n] unless @producer.params["aut"].nil?
381
- s << %Q[ <tr><th>#{@producer.res.v("c-csl")}</th><td>#{CGI.escapeHTML(@producer.params["csl"].join(", "))}</td></tr>\n] unless @producer.params["csl"].nil?
382
- s << %Q[ <tr><th>#{@producer.res.v("c-trl")}</th><td>#{CGI.escapeHTML(@producer.params["trl"].join(", "))}</td></tr>\n] unless @producer.params["trl"].nil?
383
- s << %Q[ <tr><th>#{@producer.res.v("c-dsr")}</th><td>#{CGI.escapeHTML(@producer.params["dsr"].join(", "))}</td></tr>\n] unless @producer.params["dsr"].nil?
384
- s << %Q[ <tr><th>#{@producer.res.v("c-ill")}</th><td>#{CGI.escapeHTML(@producer.params["ill"].join(", "))}</td></tr>\n] unless @producer.params["ill"].nil?
385
- s << %Q[ <tr><th>#{@producer.res.v("c-edt")}</th><td>#{CGI.escapeHTML(@producer.params["edt"].join(", "))}</td></tr>\n] unless @producer.params["edt"].nil?
386
- s << %Q[ <tr><th>#{@producer.res.v("c-prt")}</th><td>#{CGI.escapeHTML(@producer.params["prt"].join(", "))}</td></tr>\n] unless @producer.params["prt"].nil?
387
- s << %Q[ <tr><th>#{@producer.res.v("c-pht")}</th><td>#{CGI.escapeHTML(@producer.params["pht"].join(", "))}</td></tr>\n] unless @producer.params["pht"].nil?
388
- if @producer.params["isbn"].to_s =~ /\A\d{10}\Z/ || @producer.params["isbn"].to_s =~ /\A\d{13}\Z/
389
- isbn = nil
390
- str = @producer.params["isbn"].to_s
391
- if str.size == 10
392
- isbn = "#{str[0..0]}-#{str[1..5]}-#{str[6..8]}-#{str[9..9]}"
393
- else
394
- isbn = "#{str[0..2]}-#{str[3..3]}-#{str[4..8]}-#{str[9..11]}-#{str[12..12]}"
395
- end
396
- s << %Q[ <tr><th>ISBN</th><td>#{isbn}</td></tr>\n]
397
- end
398
- s << <<EOT
399
- </table>
400
- EOT
401
- if !@producer.params["rights"].nil? && @producer.params["rights"].size > 0
402
- s << %Q[ <p class="copyright">#{@producer.params["rights"].join("<br />")}</p>]
403
- end
404
-
405
- s << <<EOT
406
- </div>
407
- </body>
408
- </html>
409
- EOT
410
- s
411
- end
412
-
413
- def date_to_s(date)
414
- ymd = date.to_s.split('-')
415
- "#{ymd[0]}年#{ymd[1].sub(/\A0/, '')}月#{ymd[2].sub(/\A0/, '')}日" # FIXME:i18n
416
- end
417
-
418
- # Return own toc content.
419
- def mytoc
420
- s = common_header
421
- s << <<EOT
422
- <title>#{@producer.res.v("toctitle")}</title>
423
- </head>
424
- <body>
425
- <h1 class="toc-title">#{@producer.res.v("toctitle")}</h1>
426
- EOT
427
-
428
- if @producer.params["flattoc"].nil?
429
- s << hierarchy_ncx("ul")
430
- else
431
- s << flat_ncx("ul", @producer.params["flattocindent"])
432
- end
433
-
434
- s << <<EOT
435
- </body>
436
- </html>
437
- EOT
438
- s
439
- end
440
-
441
- def hierarchy_ncx(type)
442
- require 'rexml/document'
443
- level = 1
444
- find_jump = nil
445
- has_part = nil
446
- toclevel = @producer.params["toclevel"].to_i
447
-
448
- # check part existance
449
- @producer.contents.each do |item|
450
- if item.notoc.nil? && item.chaptype == "part"
451
- has_part = true
452
- break
453
- end
454
- end
455
-
456
- if !has_part.nil?
457
- @producer.contents.each do |item|
458
- item.level += 1 if item.chaptype == "part" || item.chaptype == "body"
459
- item.notoc = true if (item.chaptype == "pre" || item.chaptype == "post") && !item.level.nil? && (item.level + 1 == toclevel) # FIXME: 部があるときに前後の処理が困難
460
- end
461
- toclevel += 1
462
- end
463
-
464
- doc = REXML::Document.new(%Q[<#{type} class="toc-h#{level}"><li /></#{type}>])
465
-
466
- e = doc.root.elements[1] # first <li/>
467
- @producer.contents.each do |item|
468
- next if !item.notoc.nil? || item.level.nil? || item.file.nil? || item.title.nil? || item.level > toclevel
469
-
470
- if item.level == level
471
- e2 = e.parent.add_element("li")
472
- e = e2
473
- elsif item.level > level
474
- find_jump = true if (item.level - level) > 1
475
- # deeper
476
- (level + 1).upto(item.level) do |n|
477
- if e.size == 0
478
- # empty span for epubcheck
479
- es = e.add_element("span")
480
- es.add_text(REXML::Text.new(" ", false, nil, true))
481
- end
482
-
483
- e2 = e.add_element(type, {"class" => "toc-h#{n}"})
484
- e3 = e2.add_element("li")
485
- e = e3
486
- end
487
- level = item.level
488
- elsif item.level < level
489
- # shallower
490
- (level - 1).downto(item.level) do |n|
491
- e = e.parent.parent
492
- end
493
- e2 = e.parent.add_element("li")
494
- e = e2
495
- level = item.level
496
- end
497
- e2 = e.add_element("a", {"href" => item.file})
498
- e2.add_text(REXML::Text.new(item.title, true))
499
- end
500
-
501
- warn "found level jumping in table of contents. consider to use 'flattoc: true' for strict ePUB validator." unless find_jump.nil?
502
-
503
- doc.to_s.gsub("<li/>", "").gsub("</li>", "</li>\n").gsub("href='", "href=\"").gsub(" class='", " class=\"").gsub("'>", "\">").gsub("<#{type} ", "\n" + '\&') # ugly
504
- end
505
-
506
- def flat_ncx(type, indent=nil)
507
- s = %Q[<#{type} class="toc-h1">\n]
508
- @producer.contents.each do |item|
509
- next if !item.notoc.nil? || item.level.nil? || item.file.nil? || item.title.nil? || item.level > @producer.params["toclevel"].to_i
510
- is = indent == true ? " " * item.level : ""
511
- s << %Q[<li><a href="#{item.file}">#{is}#{CGI.escapeHTML(item.title)}</a></li>\n]
512
- end
513
- s << %Q[</#{type}>\n]
514
-
515
- s
516
- end
517
-
518
159
  # Produce EPUB file +epubfile+.
519
160
  # +basedir+ points the directory has contents.
520
161
  # +tmpdir+ defines temporary directory.
521
162
  def produce(epubfile, basedir, tmpdir)
522
163
  produce_write_common(basedir, tmpdir)
523
164
 
524
- File.open("#{tmpdir}/OEBPS/#{@producer.params["bookname"]}.ncx", "w") {|f| @producer.ncx(f, @producer.params["ncxindent"]) }
165
+ File.open("#{tmpdir}/OEBPS/#{@producer.params["bookname"]}.ncx", "w") {|f| @producer.ncx(f, @producer.params["epubmaker"]["ncxindent"]) }
525
166
  File.open("#{tmpdir}/OEBPS/#{@producer.params["bookname"]}-toc.#{@producer.params["htmlext"]}", "w") {|f| @producer.mytoc(f) } unless @producer.params["mytoc"].nil?
526
167
 
527
- @producer.call_hook(@producer.params["hook_prepack"], tmpdir)
168
+ @producer.call_hook(@producer.params["epubmaker"]["hook_prepack"], tmpdir)
528
169
  export_zip(tmpdir, epubfile)
529
170
  end
530
171
 
531
- def produce_write_common(basedir, tmpdir)
532
- File.open("#{tmpdir}/mimetype", "w") {|f| @producer.mimetype(f) }
533
-
534
- Dir.mkdir("#{tmpdir}/META-INF") unless File.exist?("#{tmpdir}/META-INF")
535
- File.open("#{tmpdir}/META-INF/container.xml", "w") {|f| @producer.container(f) }
536
-
537
- Dir.mkdir("#{tmpdir}/OEBPS") unless File.exist?("#{tmpdir}/OEBPS")
538
- File.open("#{tmpdir}/OEBPS/#{@producer.params["bookname"]}.opf", "w") {|f| @producer.opf(f) }
539
-
540
- if File.exist?("#{basedir}/#{@producer.params["cover"]}")
541
- FileUtils.cp("#{basedir}/#{@producer.params["cover"]}", "#{tmpdir}/OEBPS")
542
- else
543
- File.open("#{tmpdir}/OEBPS/#{@producer.params["cover"]}", "w") {|f| @producer.cover(f) }
544
- end
545
-
546
- @producer.contents.each do |item|
547
- next if item.file =~ /#/ # skip subgroup
548
- fname = "#{basedir}/#{item.file}"
549
- raise "#{fname} doesn't exist. Abort." unless File.exist?(fname)
550
- FileUtils.mkdir_p(File.dirname("#{tmpdir}/OEBPS/#{item.file}")) unless File.exist?(File.dirname("#{tmpdir}/OEBPS/#{item.file}"))
551
- FileUtils.cp(fname, "#{tmpdir}/OEBPS/#{item.file}")
552
- end
553
- end
554
-
555
- def export_zip(tmpdir, epubfile)
556
- Dir.chdir(tmpdir) {|d| `#{@producer.params["zip_stage1"]} #{epubfile} mimetype` }
557
- Dir.chdir(tmpdir) {|d| `#{@producer.params["zip_stage2"]} #{epubfile} META-INF OEBPS #{@producer.params["zip_addpath"]}` }
558
- end
559
-
560
- def legacy_cover_and_title_file(loadfile, writefile)
561
- s = common_header
562
- s << <<EOT
563
- <title>#{@producer.params["booktitle"]}</title>
564
- </head>
565
- <body>
566
- EOT
567
- File.open(loadfile) do |f|
568
- f.each_line do |l|
569
- s << l
570
- end
571
- end
572
- s << <<EOT
573
- </body>
574
- </html>
575
- EOT
576
-
577
- File.open(writefile, "w") do |f|
578
- f.puts s
579
- end
580
- end
581
-
582
172
  private
583
173
 
584
174
  # Return common XHTML headder