forked from cschneid/sinatra-book
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sinatra-book.thor
executable file
·85 lines (64 loc) · 2.26 KB
/
sinatra-book.thor
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# module: sinatra-book
require 'rubygems'
require 'maruku'
require 'fileutils'
class Book < Thor
SUPPORTED_FORMATS = %w{html latex pdf}
OUTPUT_DIR = File.join(File.dirname(__FILE__), "output")
BOOK_DIR = File.join(File.dirname(__FILE__), "book")
BOOK_FILE_NAME = "sinatra-book"
OUTPUT_FILE_BASE_NAME = File.join(OUTPUT_DIR, BOOK_FILE_NAME)
desc "build [FORMAT]", "Build the book. FORMAT specifies what format the output should have. Defaults to html. Valid options are: #{SUPPORTED_FORMATS.join(", ")}"
def build(format = 'html')
doc = Maruku.new(complete_markdown)
FileUtils.mkdir_p(OUTPUT_DIR)
FileUtils.cp( File.join(File.dirname(__FILE__), 'assets', 'book.css'), File.join(File.dirname(__FILE__), 'output'))
if SUPPORTED_FORMATS.include?( format )
self.send("build_#{format}", doc)
else
STDERR << "Error: Don't know how to build for format '#{format}'"
exit 1
end
end
desc "clean", "Delete the output directory, along with all contents"
def clean
FileUtils.rm_rf(OUTPUT_DIR, {:verbose => true})
end
private
def build_html(doc)
File.open(OUTPUT_FILE_BASE_NAME + '.html', 'w+') do |file|
file << doc.to_html_document
end
end
def build_latex(doc)
File.open(OUTPUT_FILE_BASE_NAME + '.tex', 'w+') do |file|
file << doc.to_latex_document
end
end
def build_pdf(doc)
build_latex(doc)
Dir.chdir(OUTPUT_DIR) do |dir|
# Run twice to get cross-references right
2.times { system("pdflatex #{OUTPUT_FILE_BASE_NAME + '.tex'} -output-directory=#{OUTPUT_DIR}") }
# Clean up
file_patterns = %w{*.aux *.out *.toc *.log}
file_patterns.each do |pattern|
FileUtils.rm(Dir.glob(pattern))
end
end
end
def complete_markdown
# Collect all the markdown files in the correct order and squash them together into one big string
s = []
File.new("book-order.txt").each_line do |line|
line.strip!
next if line =~ /^#/ # Skip comments
next if line =~ /^$/ # Skip blank lines
File.open(File.join(BOOK_DIR, line)) do |f|
# I have no idea if the double \n is needed, but seems safe
s << f.read
end
end
return s.join("\n\n* * *\n\n")
end
end