diff options
author | Gustav Eek <gustav.eek@fripost.org> | 2024-05-30 07:57:03 +0200 |
---|---|---|
committer | Gustav Eek <gustav.eek@fripost.org> | 2024-07-13 09:28:26 +0200 |
commit | 7c7ea5ae027c0f0b353aef54749b34957cf05c59 (patch) | |
tree | 6d29f34ee32f9d64b65f0c2bada572e428b2a0c1 | |
parent | b520bb4d9182b5b25e8b5cb0835c9e563814b87d (diff) |
System. Provide general synchronization from shared folders
TODO. Document usage in README (copy from conversation with SRE) Jul
2, 2024
-rw-r--r-- | lib/Makefile | 18 | ||||
-rwxr-xr-x | lib/sync | 40 |
2 files changed, 52 insertions, 6 deletions
diff --git a/lib/Makefile b/lib/Makefile index 535809f..2c53bed 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -8,6 +8,10 @@ MINUTES ?= # will be compiled with *minutes* template POLICY ?= # will be compiled with *by-laws* template REPORTS ?= # will be compiled with *report* template +# Repository root + +ROOT ?= $(shell git rev-parse --show-toplevel) + # Targets .PHONY: all @@ -48,20 +52,22 @@ $(addsuffix .pdf, $(REPORTS)): %.pdf: %.md .PHONY: archive ARCHIVE ?= archive -ROOT ?= $(shell git rev-parse --show-toplevel) SUFFIX ?= -$(subst /,,$(dir $(subst $(ROOT),,$(PWD)))) PDF ?= $(basename $(wildcard *.pdf)) -print: - @echo ARCHIVE = $(ARCHIVE) - @echo ROOT = $(ROOT) - @echo SUFFIX = $(SUFFIX) - archive: for p in $(PDF); do \ rsync $$p.pdf $(ROOT)/$(ARCHIVE)/$$p$(SUFFIX).pdf; \ done +# Sync from shared meeting working directory + +SRC ?= $(FRIPOST_SYNC_SRC) + +sync: + FRIPOST_SYNC_SRC="$(SRC)" $(ROOT)/lib/sync + + # Upload to server .PHONY: send diff --git a/lib/sync b/lib/sync new file mode 100755 index 0000000..1db2b30 --- /dev/null +++ b/lib/sync @@ -0,0 +1,40 @@ +#!/usr/bin/env bash + +HELP="Usage: sync [-h] + +Sync a source with a Git repository target. + +Parameters + Environmntal variables + FRIPOST_SYNC_SRC set source directory + -h help + +Set target directory where the repository is found and script +executed. Set source directory to for example a shared folder. Make +sure that all pahts are absolute." + +EXCL=" +*~* +*#* +Readme.md +lib +" + +trg="$PWD" +src="$FRIPOST_SYNC_SRC" +excl=$XDG_RUNTIME_DIR/${0##*/}-excl + +if [ "$1" == "-h" ]; then echo "$HELP"; exit; fi +if [ ! -d "$src" -o ! -d "$trg" ]; then + echo -n "Suorce '$src' and target '$trg' must be valid directories." + echo " See help: '${0} -h'." + exit 1 +fi + +echo "${0##*/}: I: Sync '${src}' to '${trg}'" 1>&2 + +echo "$EXCL" > $excl + +rsync -a --delete -P --exclude-from=$excl "${src}"/ "${trg}"/ \ + | grep -iv "^sending" +git -C "${trg}" status --short --branch |