X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=pinopress;h=b457b131e7a33ac5be26daeca1a2fbbfdb969227;hb=ae8408af2f6cac8cb64ff24aa1f2fe2c2255bf63;hp=5157f99c91fea441927b88e021d5e14f3398913c;hpb=d9e98960c517be5806c756518f46827cf59d0471;p=pinopress.git diff --git a/pinopress b/pinopress index 5157f99..b457b13 100755 --- a/pinopress +++ b/pinopress @@ -1,8 +1,12 @@ #!/usr/bin/make -sf +## pinopress - the simple static blog generator +## dependencies: sponge + +# user variables SITEURL := https://blog.danieliu.xyz -USERVAR1 := -USERVAR2 := +USERGLOBAL1 := +USERGLOBAL2 := .PHONY: help build clean @@ -12,26 +16,46 @@ BUILD_DIR := build SRC_DIR := articles MODULE_DIR := modules -ARTICLE_PATH := $(BUILD_DIR)/article +ARTICLE_PATH := article ARTICLE_LIST := $(basename $(shell ls $(SRC_DIR))) # some helper functions define export_common export SITEURL="$(SITEURL)" - export USERVAR1="$(USERVAR1)" - export USERVAR2="$(USERVAR2)" + export USERGLOBAL1="$(USERGLOBAL1)" + export USERGLOBAL2="$(USERGLOBAL2)" +endef + +# usage: export_article [input md] +define export_article + export ARTICLE_TITLE=`./$(MODULE_DIR)/md-header "$(1)" name` + export PUBLISHED_DATE=`./$(MODULE_DIR)/md-header "$(1)" published` + export DESCRIPTION=`./$(MODULE_DIR)/md-header "$(1)" description` + export USERLOCAL1=`./$(MODULE_DIR)/md-header "$(1)" userlocal1` + export USERLOCAL2=`./$(MODULE_DIR)/md-header "$(1)" userlocal2` + # vvv this is sorta ugly vvv + export ARTICLE_URL="$(SITEURL)/$(ARTICLE_PATH)/$(subst .md,.html,$(notdir "$(1)"))" +endef + +# usage: loop_article [dest] [template_filename] +define loop_article + for article_file in `ls $(SRC_DIR)`; do + $(call export_article,"$(SRC_DIR)/$$article_file") + envsubst < $(TEMPLATE_DIR)/$(2) | sed -i "//r /dev/stdin" "$(1)" + done endef help: echo 'pinopress help|build|clean' -build: $(BUILD_DIR)/rolling.html $(BUILD_DIR)/archive.html $(ARTICLE_PATH)/$(addsuffix .html,$(ARTICLE_LIST)) +build: $(BUILD_DIR)/rolling.html $(BUILD_DIR)/archive.html $(BUILD_DIR)/feed.xml $(addprefix $(BUILD_DIR)/$(ARTICLE_PATH)/,$(addsuffix .html,$(ARTICLE_LIST))) .ONESHELL: $(BUILD_DIR)/rolling.html: echo 'building rolling file' $(export_common) cat $(TEMPLATE_DIR)/head.template.html $(TEMPLATE_DIR)/rollingbody.template.html $(TEMPLATE_DIR)/foot.template.html > "$@" + $(call loop_article,"$@",rollingitem.template.html) envsubst < "$@" | sponge "$@" .ONESHELL: @@ -39,14 +63,22 @@ $(BUILD_DIR)/archive.html: echo 'building archive file' $(export_common) cat $(TEMPLATE_DIR)/head.template.html $(TEMPLATE_DIR)/archivebody.template.html $(TEMPLATE_DIR)/foot.template.html > "$@" + $(call loop_article,"$@",archiveitem.template.html) + envsubst < "$@" | sponge "$@" + +.ONESHELL: +$(BUILD_DIR)/feed.xml: + echo 'building feed file' + $(export_common) + cat $(TEMPLATE_DIR)/feed.template.xml > "$@" + $(call loop_article,"$@",feeditem.template.xml) envsubst < "$@" | sponge "$@" .ONESHELL: -$(ARTICLE_PATH)/%.html: articles/%.md - echo 'parsing $^' +$(BUILD_DIR)/$(ARTICLE_PATH)/%.html: $(SRC_DIR)/%.md + echo "parsing $<" $(export_common) - export ARTICLE_TITLE="$(shell ./$(MODULE_DIR)/md-header "$<" name)" - export PUBLISHED_DATE="$(shell ./$(MODULE_DIR)/md-header "$<" published)" + $(call export_article,"$<") cat $(TEMPLATE_DIR)/head.template.html > "$@" # module pipeline starts here ./$(MODULE_DIR)/md "$^" >> "$@" @@ -56,5 +88,5 @@ $(ARTICLE_PATH)/%.html: articles/%.md clean: echo 'cleaning...' - rm $(BUILD_DIR)/rolling.html $(BUILD_DIR)/archive.html $(ARTICLE_PATH)/* + rm $(BUILD_DIR)/rolling.html $(BUILD_DIR)/archive.html $(BUILD_DIR)/feed.xml $(BUILD_DIR)/$(ARTICLE_PATH)/*