summaryrefslogtreecommitdiffstats
path: root/scripts/bupa
blob: 971cfb626b668cf5b898e79f3a53f5897bfe9c54 (plain)
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#!/usr/bin/env python
"""Usage: bupa <page>

Options:
  -h, --help     Show this screen.
  -v, --version  Show the version information.
"""
from jinja2 import Environment, FileSystemLoader
import glob, yaml, docopt, datetime
from docutils import core
from pyatom import AtomFeed
from os import path

class Page(object):
	def __init__(self, page_dict):
		self.id = None
		self.title = page_dict['title']
		self.header = page_dict['header']
		self.date = page_dict['date']
		self.author = page_dict['author']
		if 'author_link' in page_dict:
			self.author_link = page_dict['author_link']
		self.body = page_dict['body'][0]

def reST_to_html(s):
	return core.publish_parts(s, writer_name='html4css1')['fragment']

def filename_to_id(file_name):
	filename = path.split(file_name)[1]
	file_id  = filename.split('-')[0].split('.')[0]
	return int(file_id)

def filename_to_extless(filename):
	filename = path.split(filename)[1]
	extless = path.splitext(filename)[0]
	return extless

def parse(filename):
	with open(filename, 'rb') as file:
		data = file.read().decode('utf-8')

	frontmatter, *body = data.split('\n\n', 1)

	frontmatter = frontmatter.partition('\n')[2]
	frontmatter = yaml.load(frontmatter)

	page_dict = frontmatter.copy()
	page_dict['body'] = body
	if not 'header' in page_dict:
		page_dict['header'] = page_dict['title']

	page = Page(page_dict)
	return page

def build_entry(filename, atom_feed):
	entry = parse(filename)
	entry.id = filename_to_id(filename)
	entry.page = filename_to_extless(filename) + '.html'
	entry.srcpage = filename_to_extless(filename) + '.rst'
	entry.body = reST_to_html(entry.body)
	atom_feed.add(
		title=entry.title,
		content=entry.body,
		content_type="html",
		author={'name': entry.author, 'uri': entry.author_link},
		url="https://theos.kyriasis.com/~kyrias/"+entry.page,
		updated=entry.date
	)
	return entry

def build_journal(jinja_env):
	template   = jinja_env.get_template('journal.html')
	files      = glob.glob('src/journal/*.rst')
	files.sort(key=filename_to_id, reverse=True)

	atom_feed = AtomFeed(
		title     = "kyrias’ journal",
		subtitle  = "The lost journal of Kyrias",
		feed_url  = "https://theos.kyriasis.com/~kyrias/journal.xml",
		url       = "https://theos.kyriasis.com/~kyrias/journal.html",
		author    = { 'name': 'Johannes Löthberg',
		               'uri': 'https://theos.kyriasis.com/~kyrias/about.html' },
		updated   = datetime.datetime.utcnow(),
		generator = ('bupa', '', '0.0.1')
	)

	entries = []
	for file in files:
		entry = build_entry(file, atom_feed)
		write_page(entry, 'The lost journal', 'journal/'+entry.page, 'entry.html', jinja_env)
		entries += [entry]

	with open('build/journal.html', 'wb') as file:
		journal = template.render(entries=entries, title='~/journal', header='The lost journal')
		file.write(journal.encode('utf-8'))

	with open('build/journal.xml', 'wb') as file:
		file.write(atom_feed.to_string().encode('utf-8'))

def build_page(jinja_env, template, pagename):
	page = parse('src/'+pagename+'.rst')
	page.body = reST_to_html(page.body)
	page.article_id = pagename
	write_page(page, page.header, pagename+'.html', template, jinja_env)

def write_page(page, header, filename, template, jinja_env):
	template = jinja_env.get_template(template)
	with open('build/'+filename, 'wb') as file:
		rendered_page = template.render(page=page, title=page.title, header=header)
		file.write(rendered_page.encode('utf-8'))

def main():
	arguments = docopt.docopt(__doc__, version='bupa 0.0.1')
	jinja_env = Environment(loader=FileSystemLoader('src/templates')) # something something jinja2 templates

	if arguments['<page>'] == 'journal.html':
		build_journal(jinja_env)
	elif arguments['<page>'] == 'index.html':
		build_page(jinja_env, 'page.html', 'index')
	elif arguments['<page>'] == 'about.html':
		build_page(jinja_env, 'page.html', 'about')

if __name__ == '__main__':
	main()