2022-06-03 17:12:32 +02:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import markdown
|
|
|
|
import pathlib
|
|
|
|
import sys
|
|
|
|
import re
|
|
|
|
|
|
|
|
def print_usage():
|
|
|
|
print("\nusage: python mkblogrss.py POSTS\n")
|
|
|
|
print("\n")
|
|
|
|
print("\t\tPOSTS\tfilepaths of blog posts")
|
|
|
|
|
|
|
|
# check args for at least one file path
|
|
|
|
if len(sys.argv) < 2:
|
|
|
|
print_usage()
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
# posts are arguments from index 1 onwards
|
|
|
|
posts = sys.argv[1:]
|
|
|
|
|
|
|
|
# header and footer to enclose feed items
|
|
|
|
header = """<?xml version="1.0" encoding="utf-8" ?>
|
|
|
|
<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0">
|
|
|
|
<channel>
|
2022-06-03 22:56:43 +02:00
|
|
|
<title>ktyl.dev</title>
|
2022-06-03 17:12:32 +02:00
|
|
|
<link>https://ktyl.dev/blog/index.html</link>
|
2022-06-03 22:56:43 +02:00
|
|
|
<description>mostly computer stuff!</description>
|
2022-06-03 17:12:32 +02:00
|
|
|
<atom:link href="https://ktyl.dev/blog/index.xml" rel="self" type="application/rss+xml"/>
|
|
|
|
"""
|
|
|
|
footer = "</channel></rss>"
|
|
|
|
|
|
|
|
# regex patterns
|
|
|
|
title_pattern = re.compile("<h1>(.+)</h1>")
|
|
|
|
path_pattern = re.compile("(.+)\/(\d{4})\/(\d{1,2})\/(\d{1,2})\/(.+).md")
|
|
|
|
|
|
|
|
def make_item(path):
|
|
|
|
str = "<item>\n"
|
|
|
|
|
|
|
|
# get the HTML version of the file
|
|
|
|
text = ""
|
|
|
|
with open(path) as f:
|
|
|
|
text = f.read()
|
|
|
|
html = markdown.markdown(text, extensions=["fenced_code"])
|
|
|
|
|
|
|
|
# title
|
|
|
|
title = ""
|
|
|
|
m = title_pattern.match(html)
|
|
|
|
title = m.group(1)
|
|
|
|
str += f"<title>{title}</title>\n"
|
|
|
|
|
|
|
|
# link
|
|
|
|
url = "/".join(pathlib.Path(path).parts[2:])
|
|
|
|
url = url.replace(".md", ".html")
|
|
|
|
link = f"https://ktyl.dev/blog/{url}"
|
|
|
|
str += f"<link>{link}</link>\n"
|
|
|
|
|
|
|
|
# content
|
|
|
|
description = html
|
|
|
|
description = re.sub('<', '<', description)
|
|
|
|
description = re.sub('>', '>', description)
|
|
|
|
str += f"<description>{description}</description>\n"
|
|
|
|
|
|
|
|
# pub date
|
|
|
|
date = re.sub(path_pattern, r'\2-\3-\4', path)
|
|
|
|
str += f"<pubDate>{date}</pubDate>\n"
|
|
|
|
|
|
|
|
str += "</item>"
|
|
|
|
|
|
|
|
return str
|
|
|
|
|
|
|
|
# print everything!
|
|
|
|
print(header)
|
|
|
|
for p in posts:
|
|
|
|
print(make_item(p))
|
|
|
|
print(footer)
|
|
|
|
|