From: Lady Date: Sun, 21 Jan 2024 01:51:36 +0000 (-0500) Subject: Use 👥📤 Yseme for syncing X-Git-Url: https://git.ladys.computer/WWW/commitdiff_plain/715911964479ffb20cfa205765db47453266cf44?hp=03da40f109bb0955e043167ef4658aad93e8b268 Use 👥📤 Yseme for syncing --- diff --git a/.gitmodules b/.gitmodules index 0355c5d..d7f81d4 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,3 +1,6 @@ [submodule "书社"] path = .shushe url = https://git.ladys.computer/Shushe.git +[submodule "Yseme"] + path = .yseme + url = https://git.ladys.computer/Yseme.git diff --git a/.yseme b/.yseme new file mode 160000 index 0000000..11d9fdb --- /dev/null +++ b/.yseme @@ -0,0 +1 @@ +Subproject commit 11d9fdbb76bac028c834c84521fcc45c6a95ea6e diff --git a/GNUmakefile b/GNUmakefile index b40c209..275f6ca 100644 --- a/GNUmakefile +++ b/GNUmakefile @@ -6,48 +6,31 @@ SHELL = /bin/sh # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at https://mozilla.org/MPL/2.0/. -# This Makefile requires rsync 3 or newer. -RSYNC = rsync -RSYNC_FLAGS = -Oclmrtvz -RSYNC_OPTIONS = -RSYNC_FILTER = .rsync-filter +SHUSHE := .shushe +SHUSHE_OPTIONS := INCLUDEDIR='sources/INCLUDE' TRANSFORMS='$(wildcard transforms/*.xslt) $(wildcard $(SHUSHE)/transforms/*.xslt)' -SOURCE_CHARSET = utf-8-mac +YSEME := .yseme +YSEME_OPTIONS := DESTDIR=public SERVERPATH=lady/www -DESTINATION_HOST = computer -DESTINATION_PATH = lady/www -DESTINATION = $(DESTINATION_HOST):$(DESTINATION_PATH) -DESTINATION_CHARSET = utf-8 - -GIT_FORCE = - -SHUSHE = .shushe -SHUSHE_OPTIONS = 'INCLUDEDIR=sources/INCLUDE' 'TRANSFORMS=$(wildcard transforms/*.xslt) $(wildcard $(SHUSHE)/transforms/*.xslt)' - -build: +build: $(SHUSHE)/GNUmakefile rm -rf ./public - @$(MAKE) -f $(SHUSHE)/GNUmakefile install $(SHUSHE_OPTIONS) + @$(MAKE) -f $< install $(SHUSHE_OPTIONS) touch .grass -list: - @$(MAKE) -f $(SHUSHE)/GNUmakefile list $(SHUSHE_OPTIONS) - -ensure-build: - @if [ ! -f .grass ]; then echo 'Error: The website has not been built yet!' >&2; echo 'Run `make` before syncing.' >&2; exit 1; fi - @if buildtime=$$(stat -f '%m' .grass) && committime=$$(git log -1 --format='%ct' | awk '{print $$NF}') && [ "$$committime" -gt "$$buildtime" ]; then echo 'Error: A commit was made after the last build!' >&2; echo 'Run `make` before syncing.' >&2; exit 1; fi +list: $(SHUSHE)/GNUmakefile + @$(MAKE) -f $< $@ $(SHUSHE_OPTIONS) -ensure-branch-up-to-date: - git fetch - @if ! git merge-base --is-ancestor @{u} HEAD; then echo 'Error: This branch is currently out‐of‐date!' >&2; echo 'Pull in changes with `git pull` before syncing.' >&2; exit 1; fi +$(SHUSHE)/GNUmakefile $(YSEME)/GNUmakefile: %/GNUmakefile: + git submodule update --init $* -ensure-clean: - @if output=$$(git status --porcelain) && [ ! -z "$$output" ]; then echo 'Error: There are uncommitted changes!' >&2; echo 'Commit changes and run `make` before syncing.' >&2; exit 1; fi +GNUmakefile: $(SHUSHE)/GNUmakefile $(YSEME)/GNUmakefile + touch GNUmakefile -dry-sync: ensure-clean$(if $(GIT_FORCE),, ensure-branch-up-to-date) ensure-build - cd public && $(RSYNC) $(RSYNC_FLAGS) --del --dry-run --filter=". ../$(RSYNC_FILTER)" --iconv=$(SOURCE_CHARSET),$(DESTINATION_CHARSET) $(RSYNC_OPTIONS) . $(DESTINATION) +ifneq ($(wildcard $(YSEME)/GNUmakefile),) +YSEME_TARGETS := $(shell sed '/^\.PHONY[ :]/!d;/^\.PHONY[ :]/s/ *;.*//;/^\.PHONY[ :]/s/\.PHONY.*: *//' < $(YSEME)/GNUmakefile) -sync: ensure-clean$(if $(GIT_FORCE),, ensure-branch-up-to-date) ensure-build - cd public && $(RSYNC) $(RSYNC_FLAGS) --del --filter=". ../$(RSYNC_FILTER)" --iconv=$(SOURCE_CHARSET),$(DESTINATION_CHARSET) $(RSYNC_OPTIONS) . $(DESTINATION) - git push$(if $(GIT_FORCE), --force,) +$(YSEME_TARGETS): $(YSEME)/GNUmakefile + @$(MAKE) -f $< $@ $(YSEME_OPTIONS) +endif -.PHONY: build dry-sync ensure-branch-up-to-date ensure-build ensure-clean sync; +.PHONY: build list $(YSEME_TARGETS);