47 lines
1.2 KiB
Python
Executable File
47 lines
1.2 KiB
Python
Executable File
#!/usr/bin/python3
|
|
|
|
from sys import argv, exit
|
|
from os import walk, path
|
|
from random import choice, seed
|
|
import time, urllib.parse
|
|
|
|
from article_utils import parse_metadata
|
|
from page_shares import wrap_page, ADJECTIVES, MONTHS
|
|
|
|
if len(argv) <= 1:
|
|
print("No directory was supplied")
|
|
exit(-1)
|
|
|
|
seed()
|
|
|
|
page_metadata = """Title: mjestečko
|
|
CSS: /style.css
|
|
|
|
"""
|
|
|
|
page = f"""Personal blog of one {choice(ADJECTIVES)} Veclav Talica.
|
|
|
|
---
|
|
|
|
### Articles ###
|
|
|
|
"""
|
|
|
|
# todo: Sort by date first.
|
|
for root, dirs, _ in walk(argv[1]):
|
|
for d in dirs:
|
|
metadata = parse_metadata(path.abspath(root + '/' + d + "/page.mmd"))
|
|
article = urllib.parse.quote(d)
|
|
page += (
|
|
f"""[{metadata.get("Title", "No title given! What a clusterfuck!")}](/articles/{article}.html)\n\n"""
|
|
f""">{metadata.get("Brief", "")}\n\n"""
|
|
)
|
|
if "Tags" in metadata:
|
|
page += f""">*{','.join(metadata["Tags"])}*\n---\n"""
|
|
break
|
|
|
|
curtime = time.gmtime(int(time.time()))
|
|
page += f"Last compiled: *{MONTHS[curtime.tm_mon]} {curtime.tm_mday}, {curtime.tm_year} {curtime.tm_hour}:{curtime.tm_min:02d} UTC*\n\n"
|
|
|
|
print(page_metadata + wrap_page(page))
|