Compare commits
No commits in common. "1aea2465005fb6409ee5749b9342bf504b2c3b34" and "2db1a7d8eba86f65d80e29412398646af3658fd3" have entirely different histories.
1aea246500
...
2db1a7d8eb
2
blog
2
blog
|
@ -1 +1 @@
|
||||||
Subproject commit 9d7c004775b60dc1af3c942d637d4376752a8f83
|
Subproject commit 358314e4cd30487c136d37fd01b18b4fefcd4fe8
|
1
makefile
1
makefile
|
@ -63,7 +63,6 @@ blog: $(HTML_INCLUDES) $(CSS_TARGETS)
|
||||||
done
|
done
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
make --directory $(BLOG_BASE_DIR) clean
|
|
||||||
rm -rf $(OUT_DIR)
|
rm -rf $(OUT_DIR)
|
||||||
|
|
||||||
.PHONY: blog
|
.PHONY: blog
|
||||||
|
|
|
@ -0,0 +1,86 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import markdown
|
||||||
|
import re
|
||||||
|
|
||||||
|
# SRC
|
||||||
|
# +-2022/
|
||||||
|
# | +-10/
|
||||||
|
# | +-12/
|
||||||
|
# | +-25/
|
||||||
|
# +-2023/
|
||||||
|
# | +-1/
|
||||||
|
# | +-26/
|
||||||
|
# | +-3/
|
||||||
|
# ...
|
||||||
|
|
||||||
|
def print_usage():
|
||||||
|
print("\nusage: python mkblog.py SRC DEST\n")
|
||||||
|
print("\n")
|
||||||
|
print("\t\tSRC\tinput markdown file")
|
||||||
|
print("\t\tDEST\tdestination html file")
|
||||||
|
|
||||||
|
# check args
|
||||||
|
if len(sys.argv) != 3:
|
||||||
|
print_usage()
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
src_file = sys.argv[1]
|
||||||
|
dest_file = sys.argv[2]
|
||||||
|
|
||||||
|
# check blog root exists
|
||||||
|
if not os.path.isfile(src_file):
|
||||||
|
print("{blog_root} doesn't exist")
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
# make dest dir if it doesnt exist
|
||||||
|
|
||||||
|
dest_dir = os.path.dirname(dest_file)
|
||||||
|
print(dest_dir)
|
||||||
|
if not os.path.isdir(dest_dir):
|
||||||
|
os.makedirs(dest_dir)
|
||||||
|
|
||||||
|
# write markdown into a dummy file first so that we can add lines before it in the final output
|
||||||
|
dummy_file = f"{dest_file}.bak"
|
||||||
|
open(dummy_file, 'w').close()
|
||||||
|
|
||||||
|
print(f"{src_file} -> {dummy_file}")
|
||||||
|
markdown.markdownFromFile(input=src_file, output=dummy_file, extensions=["fenced_code"])
|
||||||
|
|
||||||
|
print(f"{dummy_file} -> {dest_file}")
|
||||||
|
with open(dummy_file, 'r') as read_file, open(dest_file, 'w') as write_file:
|
||||||
|
write_file.write("#include blogstart.html\n")
|
||||||
|
|
||||||
|
# modify the basic html to make it nicer for styling later
|
||||||
|
html = read_file.read()
|
||||||
|
|
||||||
|
# extract images from their enclosing <p> tags and put them in img panels
|
||||||
|
html = re.sub('(<p>(<img(?:.+)/>)</p>)', r'<div class="img-panel">\2</div>', html)
|
||||||
|
|
||||||
|
# insert text-panel start between non-<p> and <p> elements
|
||||||
|
html = re.sub('((?<!</p>)\n)(<p>)', r'\1<div class="text-panel">\n\2', html)
|
||||||
|
# insert para-block end between <p> and non-<p> elements
|
||||||
|
html = re.sub('(</p>\n)((?!<p>))', r'\1</div>\n\2', html)
|
||||||
|
|
||||||
|
# insert code-panel start before <pre> elements
|
||||||
|
html = re.sub('(<pre>)', r'<div class="code-panel">\n\1', html)
|
||||||
|
# insert code-panel end after </pre> elements
|
||||||
|
html = re.sub('(</pre>)', r'\1\n</div>', html)
|
||||||
|
|
||||||
|
# replace horizontal rules with nice separator dot
|
||||||
|
html = re.sub('<hr />', r'<div class="separator"></div>', html)
|
||||||
|
|
||||||
|
lines = html.split("\n")
|
||||||
|
|
||||||
|
# tack on a closing div because we will have opened one without closing it on the final <p>
|
||||||
|
lines.append("</div>")
|
||||||
|
|
||||||
|
for line in lines:
|
||||||
|
write_file.write(line + "\n")
|
||||||
|
|
||||||
|
write_file.write("\n#include blogend.html\n")
|
||||||
|
|
||||||
|
os.remove(dummy_file)
|
||||||
|
|
|
@ -21,13 +21,6 @@
|
||||||
padding: 1.0em 1.5em;
|
padding: 1.0em 1.5em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.page .blog .text-panel ul li {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
.page .blog .text-panel ul li::before {
|
|
||||||
content: "• "
|
|
||||||
}
|
|
||||||
|
|
||||||
.page .blog .code-panel {
|
.page .blog .code-panel {
|
||||||
color: var(--background);
|
color: var(--background);
|
||||||
background-color: var(--foreground);
|
background-color: var(--foreground);
|
||||||
|
|
Loading…
Reference in New Issue