# • For files with a location of `sources/index.xml` or `sources/index-*.xml`, the transformed file will be written to `public/%.html` (where `%` is the filename).
#
# • For all other files with a location of `sources/*.xml` or `sources/*/*.xml`, the transformed file will be written to `public/%/index.html` (where `%` is the filename and subdirectory if applicable).
+# Other files in the corresponding directory (i·e without the `.xml`) are copied over verbatim.
# Only one level of subdirectory is supported.
#
# By default, running `make` will do this for all applicable source files.
override pagesources := $(filter-out $(indexsources),$(wildcard sources/*.xml sources/*/*.xml))
override pages := $(patsubst sources/%.xml,public/%/index.html,$(pagesources))
+override resourcesources := $(wildcard $(addsuffix /*,$(basename $(pagesources))))
+override resources := $(patsubst sources/%,public/%,$(resourcesources))
+
override content := $(indices) $(pages)
override makexslt = $(XSLT) --nonet --novalid $(XSLTOPTS) -o $(2) transform.xslt $(1)
-all: $(content) ;
+all: $(content) $(resources);
$(indices): public/%.html: sources/%.xml $(prerequisites)
@echo "Generating $@…"
@echo "Generating $@…"
@$(call makexslt,$<,$@)
+$(resources): public/%: sources/%
+ @echo "Copying over $@…"
+ @mkdir -p $(dir $<)
+ @cp $< $@
+
.PHONY: all ;
## Features
- Really simple shrine generation
-
- One command: `make`
## Prerequisites
output at `public/%/index.html` (where `%` is the filename and
optional subdirectory). Only one level of subdirectory is supported.
+- For any files at `sources/*.xml` and `sources/*/*.xml`, files in the
+ folder with the same name (minus the `.xml`) will be copied over
+ verbatim.
+
- The transformation doesn’t do any rewriting of links. Make sure you
write them to point to the *final* location of the files, not their
location within the `sources/` directory.