forked from captn3m0/google-sre-ebook
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgenerate.rb
98 lines (81 loc) · 2.62 KB
/
generate.rb
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
86
87
88
89
90
91
92
93
94
95
96
97
98
require 'nokogiri'
require 'pathname'
require 'fileutils'
# First we get the list of all the book sections:
Dir.chdir("html/sre.google/%s/table-of-contents" % ENV['BOOK_NAME'])
chapter_links = Nokogiri::HTML(open("index.html"))
.css('#drop-down a')
.map {|l| l.attribute('href').value}
html = <<EOT
<!DOCTYPE html>
<html>
<head>
<title>#{ENV['BOOK_NAME_FULL']}</title>
<meta charset="utf-8">
</head>
<body>
EOT
chapter_links.each do |chapter_link|
chapter_file = File.basename File.dirname chapter_link
html += "<span class=\"hidden\" id=\"#{chapter_file}\"></span>"
doc = Nokogiri::HTML(open(chapter_link))
content = doc.css('.content')
# this title is with additional 'chapter X' in front
title = doc.at_css('h2.chapter-title').content
content.css('.cont').each do |e|
e.remove
end
# Ensure that all links are to the same file
content.css('a').each do |a|
link = a.attribute('href')
if link
matches = link.value.scan /^(\S*index.html)+(#[\w-]+)?/
# pp [link.value, matches] if link.value and link.value.include? 'lessons-learned'
if matches.length == 1 and matches[0].length == 2
# Self Links
if matches[0][0] =="index.html" and matches[0][1]
a['href'] = matches[0][1]
# If it points to start of a different chapter
else
chapter_slug = File.basename File.dirname matches[0][0]
a['href'] = "##{chapter_slug}"
end
end
end
end
chapter_header = content.at('.heading')
headers = (1..6).map {|x| "h#{x}"}
content.css(headers.join(',')).each do |e|
# If chapter heading
if e == chapter_header
e.name = 'h1'
else
# Reduce everything by 1
i = headers.index e.name
new_name = headers[i+1] ? headers[i+1] : 'h6'
e.name = new_name
end
end
content.css('img').each do |img|
img_file = img.attribute('src')
if img_file
chapter_directory = File.dirname chapter_link
absolute_image_path = Pathname.new File.absolute_path img_file, chapter_directory
cwd = Pathname.new Dir.pwd
img['src'] = absolute_image_path.relative_path_from cwd
end
end
if content.children.css('section > h1').length > 0
# remove additional parent section tag
content = content.children.at_css('section')
elsif content.children.css('div > h1').length > 0
# remove additional parent div tag
content = content.children.at_css('div')
end
# replace h1 title
content.at_css('h1').inner_html = title
html += content.inner_html
end
html+="</body></html>"
File.open("complete.html", 'w') { |file| file.write(html) }
puts "[html] Generated HTML file"