Add support for serving compressed versions of the site.
This commit is contained in:
parent
5b5b5bdb57
commit
1ae047ccfa
@ -10,6 +10,7 @@ from flask import Blueprint, render_template, send_from_directory, abort
|
|||||||
|
|
||||||
folder = "articles"
|
folder = "articles"
|
||||||
article_base_template = os.path.join(folder, "article.template.html")
|
article_base_template = os.path.join(folder, "article.template.html")
|
||||||
|
article_small_template = os.path.join(folder, "article.zip.template.html")
|
||||||
bloop = Blueprint("articles", __name__, template_folder="")
|
bloop = Blueprint("articles", __name__, template_folder="")
|
||||||
|
|
||||||
@bloop.route("/")
|
@bloop.route("/")
|
||||||
@ -17,11 +18,10 @@ def main_page():
|
|||||||
"""Renders the list of articles/projects."""
|
"""Renders the list of articles/projects."""
|
||||||
return render_template("project_list.html")
|
return render_template("project_list.html")
|
||||||
|
|
||||||
@bloop.route("/raw/<path:page_name>/")
|
@bloop.route("/.zip/")
|
||||||
def render_file(page_name):
|
def main_page_small():
|
||||||
"""Does nothing. Not really sure why I have this."""
|
return render_template("project_list.zip.html")
|
||||||
file_name = os.path.join(folder, page_name.replace("-", "_"))
|
|
||||||
|
|
||||||
@bloop.route("/<article_name>/")
|
@bloop.route("/<article_name>/")
|
||||||
def render_article(article_name):
|
def render_article(article_name):
|
||||||
"""Renders a requested article! This should always be @routed last, because it catches a
|
"""Renders a requested article! This should always be @routed last, because it catches a
|
||||||
@ -47,6 +47,8 @@ def render_article(article_name):
|
|||||||
# {article fragment}, but using the {article base template}. In the future, this should possibly also
|
# {article fragment}, but using the {article base template}. In the future, this should possibly also
|
||||||
# extract the title from the {article fragment} and feed it into the {article base template} as well.
|
# extract the title from the {article fragment} and feed it into the {article base template} as well.
|
||||||
return render_template(article_base_template, target=file_name + ".article.html")
|
return render_template(article_base_template, target=file_name + ".article.html")
|
||||||
|
if file_name.endswith(".zip") and os.path.isfile(file_name[:-4] + ".article.html"):
|
||||||
|
return render_template(article_small_template, target=file_name[:-4] + ".article.html")
|
||||||
if os.path.isfile(file_name + ".html"):
|
if os.path.isfile(file_name + ".html"):
|
||||||
# If we haven't found any results yet, check to see if "articles/some_article.html" exists. If it does,
|
# If we haven't found any results yet, check to see if "articles/some_article.html" exists. If it does,
|
||||||
# just display it plain. This also provides a clean way to access the raw form of files like
|
# just display it plain. This also provides a clean way to access the raw form of files like
|
||||||
@ -99,4 +101,6 @@ def supplementary(article_name, file_path):
|
|||||||
# If that file wasn't found, then, well, whoops.
|
# If that file wasn't found, then, well, whoops.
|
||||||
abort(404)
|
abort(404)
|
||||||
|
|
||||||
|
bloop.route("/<article_name>.zip/<path:file_path>")(supplementary)
|
||||||
|
|
||||||
"""Th-th-th-that's all, folks!"""
|
"""Th-th-th-that's all, folks!"""
|
||||||
|
Loading…
Reference in New Issue
Block a user