From cb205d1c4bf42f5c2e25cef6e7884853c86de056 Mon Sep 17 00:00:00 2001 From: Lucas Fryzek Date: Fri, 20 Jan 2023 22:58:09 -0500 Subject: Add RSS feed --- html/assets/rss.svg | 56 +++++++++++++++++++++++++++++++++++++++++++++++ html/assets/style.css | 22 ++++++++++++++++++- html/feed.xml | 2 ++ html/index.html | 16 +++++++++----- makefile | 5 ++++- templates/front_page.html | 6 ++++- tools/front_page.lua | 6 ++++- tools/link_gen.lua | 19 ++++++++++++---- tools/rss_gen.py | 54 +++++++++++++++++++++++++++++++++++++++++++++ 9 files changed, 172 insertions(+), 14 deletions(-) create mode 100644 html/assets/rss.svg create mode 100644 html/feed.xml create mode 100755 tools/rss_gen.py diff --git a/html/assets/rss.svg b/html/assets/rss.svg new file mode 100644 index 0000000..15cdd0c --- /dev/null +++ b/html/assets/rss.svg @@ -0,0 +1,56 @@ + + + + + + + + + + + + + diff --git a/html/assets/style.css b/html/assets/style.css index 06345df..4c7cf48 100644 --- a/html/assets/style.css +++ b/html/assets/style.css @@ -89,6 +89,19 @@ blockquote overflow-wrap: anywhere; } +img.rss:hover +{ + transform: scale(120%); +} + +img.rss +{ + height: 1em; + width: 1em; + display: inline; + margin-left: 10px; +} + .main-container { margin: 0; @@ -259,7 +272,7 @@ main { display: flex; flex-wrap: wrap; - justify-content: center; + justify-content: start; } .note-box @@ -293,6 +306,7 @@ main margin-top: 10px; margin-left: 10px; margin-bottom: 10px; + margin-right: 10px } .note-box img @@ -329,6 +343,12 @@ main { display: initial; } + + .note-link + { + margin-left: auto; + margin-right: auto; + } } .animated-box::before diff --git a/html/feed.xml b/html/feed.xml new file mode 100644 index 0000000..5716b68 --- /dev/null +++ b/html/feed.xml @@ -0,0 +1,2 @@ + +Fryzek Conceptshttps://fryzekconcepts.comLucas is a developer working on cool thingsSat, 21 Jan 2023 03:57:34 -0000Generating Videohttps://fryzekconcepts.com/notes/generating-videoOne thing I’m very interested in is computer graphics. This could be complex 3D graphics or 2DSun, 30 Oct 2022 04:00:00 -0000https://fryzekconcepts.com/notes/generating-videoN64Brew GameJam 2021https://fryzekconcepts.com/notes/n64brew-gamejam-2021So this year myself and two others decided to participate together in the N64Brew homebrew whereSun, 30 Oct 2022 04:00:00 -0000https://fryzekconcepts.com/notes/n64brew-gamejam-2021Baremetal RISC-Vhttps://fryzekconcepts.com/notes/baremetal-risc-vAfter re-watching suckerpinch’s Reverse Emulation video I got inspired to try and replicate whatSun, 30 Oct 2022 04:00:00 -0000https://fryzekconcepts.com/notes/baremetal-risc-vDigital Gardenhttps://fryzekconcepts.com/notes/digital_gardenAfter reading Maggie Appleton page on digital gardens I was inspired to convert my own website intoSun, 30 Oct 2022 04:00:00 -0000https://fryzekconcepts.com/notes/digital_gardenRasterizing Triangleshttps://fryzekconcepts.com/notes/rasterizing-trianglesLately I’ve been trying to implement a software renderer following the algorithm described bySun, 30 Oct 2022 04:00:00 -0000https://fryzekconcepts.com/notes/rasterizing-triangles \ No newline at end of file diff --git a/html/index.html b/html/index.html index 3a84a5f..6ff7569 100644 --- a/html/index.html +++ b/html/index.html @@ -37,39 +37,43 @@

is a developer working on cool things.

-

Notes

+

Notes + + + +

N64Brew GameJam 2021

-

So this year, myself and two others decided to participate together in the N64Brew homebrew where ...

+

So this year, myself and two others decided to participate together in the N64Brew homebrew where ...

Digital Garden

-

After reading Maggie Appleton page on digital gardens I was inspired to convert my own website into...

+

After reading Maggie Appleton page on digital gardens I was inspired to convert my own website into a digital garden.I have many half baked ideas that I seem to be able to finish. Some of them get to a published state like and , but many of them never make it to the published state. The idea of digital garden seems very appealing to me, as it encourages you to post on a topic even if you haven’t made it publishable yet.How this site works - I wanted a bit of challenge when putting together ...

Rasterizing Triangles

-

Lately I’ve been trying to implement a software renderer following the algorithm described by ...

+

Lately I’ve been trying to implement a software renderer following the algorithm described by ...

Baremetal RISC-V

-

After re-watching suckerpinch’s Reverse Emulation video I got inspired to try and replicate what ...

+

After re-watching suckerpinch’s Reverse Emulation video I got inspired to try and replicate what ...

Generating Video

-

One thing I’m very interested in is computer graphics. This could be complex 3D graphics or 2D ...

+

One thing I’m very interested in is computer graphics. This could be complex 3D graphics or simple 2D graphics. The idea of getting a computer to display visual data fascinates me. One fundamental part of showing visual data is interfacing with a computer monitor. This can be accomplished by generating a video signal that the monitor understands. Below I have written instructions on how an FPGA can be used to generate a video signal. I have specifically worked with the iCEBreaker FPGA but the...

diff --git a/makefile b/makefile index 6c10813..80ba4fc 100644 --- a/makefile +++ b/makefile @@ -33,7 +33,10 @@ $(HTML_DIR)/%.html: $(PAGE_DIR)/%.md -M main_container="main-container-page" \ -o $@ -$(HTML_DIR)/index.html: $(HTML_DOCS) $(PAGE_FILES) +html/feed.xml: $(META_DOCS) + ./tools/rss_gen.py + +$(HTML_DIR)/index.html: $(HTML_DOCS) $(PAGE_FILES) html/feed.xml touch $(HTML_DIR)/.nojekyll pandoc -s --lua-filter=./tools/front_page.lua --template=./templates/main.html main.md \ --metadata=note_list:"$(SOURCE_FILES)" \ diff --git a/templates/front_page.html b/templates/front_page.html index 14a22f7..faa286f 100644 --- a/templates/front_page.html +++ b/templates/front_page.html @@ -13,7 +13,11 @@

is a developer working on cool things.

-

Notes

+

Notes + + + +

$for(notes)$ diff --git a/tools/front_page.lua b/tools/front_page.lua index 9557a53..6a7cf4d 100644 --- a/tools/front_page.lua +++ b/tools/front_page.lua @@ -36,7 +36,11 @@ function Pandoc(doc) local header = pandoc.Header(2, note.title) table.insert(out_list, header) - table.insert(out_list, pandoc.Para(string.format("%s...", note.preview))) + if note["cover_image"] == nil then + table.insert(out_list, pandoc.Para(string.format("%s...", note.long_preview))) + else + table.insert(out_list, pandoc.Para(string.format("%s...", note.preview))) + end local out = pandoc.MetaBlocks(out_list) output:insert(pandoc.MetaMap({link=string.format("/notes/%s.html", note.note_name), note=out})) diff --git a/tools/link_gen.lua b/tools/link_gen.lua index fb53b53..04729d3 100644 --- a/tools/link_gen.lua +++ b/tools/link_gen.lua @@ -4,11 +4,13 @@ local meta_tools = require("tools/meta_tools") local meta = PANDOC_DOCUMENT.meta local preview = "" +local long_preview = "" local internal_links = {} local max_string_length = 100 +local max_long_string_length = 500 -local function append_str(buf, s) - if (#buf + #s) < max_string_length then +local function append_str(buf, s, max_length) + if (#buf + #s) < max_length then buf = buf .. s end @@ -66,6 +68,7 @@ function Doc(body, metadata, variables) end values["preview"] = preview + values["long_preview"] = long_preview for k,v in pairs(values) do output = output .. string.format("%s,%s\n", k, v) end @@ -73,13 +76,21 @@ function Doc(body, metadata, variables) return output end +function Header(s) + preview = append_str(preview, " - ", max_string_length) + long_preview = append_str(long_preview, " - ", max_long_string_length) + return "" +end + function Str(s) - preview = append_str(preview, s) + preview = append_str(preview, s, max_string_length) + long_preview = append_str(long_preview, s, max_long_string_length) return "" end function Space() - preview = append_str(preview, " ") + preview = append_str(preview, " ", max_long_string_length) + long_preview = append_str(long_preview, " ", max_long_string_length) return "" end diff --git a/tools/rss_gen.py b/tools/rss_gen.py new file mode 100755 index 0000000..c4cc1b0 --- /dev/null +++ b/tools/rss_gen.py @@ -0,0 +1,54 @@ +#!/usr/bin/env python3 + +from lxml import etree as ET +import datetime +import time +import email.utils +import os + +today = email.utils.formatdate() +url = "https://fryzekconcepts.com" +personal_author_string = "lucas.fryzek@fryzekconcepts.com (Lucas Fryzek)" + +xmlns_uris = {"atom" : "http://www.w3.org/2005/Atom"} + +rss = ET.Element("rss", version="2.0", nsmap=xmlns_uris) +channel = ET.SubElement(rss, "channel") +ET.SubElement(channel, "title").text = "Fryzek Concepts" +ET.SubElement(channel, "{{{}}}link".format(xmlns_uris["atom"]), href="{}/feed.xml".format(url), rel="self", type="application/rss+xml") +ET.SubElement(channel, "link").text = url +ET.SubElement(channel, "description").text = "Lucas is a developer working on cool things" +#ET.SubElement(channel, "pubData").text = today +ET.SubElement(channel, "lastBuildDate").text = today + +notes = [] + +build_dir = "./build" +for file in os.listdir(build_dir): + if file.endswith(".meta"): + path = os.path.join(build_dir, file) + f = open(path, "r") + note = {"name" : "".join(file.split(".")[:-1])} + for line in f: + line_split = line.strip().split(",") + note[line_split[0]] = "".join(line_split[1:]) + f.close() + + notes.append(note) + +for note in notes: + post_time = datetime.datetime.strptime("2022-10-30", "%Y-%m-%d") + post_rfc_time = email.utils.formatdate(timeval=time.mktime(post_time.timetuple())) + post_url = "{}/notes/{}".format(url, note["name"]) + item = ET.SubElement(channel, "item") + ET.SubElement(item, "title").text = note["title"] + ET.SubElement(item, "link").text = post_url + ET.SubElement(item, "description").text = note["preview"] + if "categories" in note: + ET.SubElement(item, "category").text = note["categories"] + + ET.SubElement(item, "pubDate").text = post_rfc_time + ET.SubElement(item, "guid").text = post_url + +tree = ET.ElementTree(rss) +tree.write("html/feed.xml", encoding='utf-8', xml_declaration=True) -- cgit v1.2.3