about summary refs log tree commit diff stats
path: root/instantiate_templates.sh
diff options
context:
space:
mode:
Diffstat (limited to '')
-rwxr-xr-xinstantiate_templates.sh43
1 files changed, 43 insertions, 0 deletions
diff --git a/instantiate_templates.sh b/instantiate_templates.sh
new file mode 100755
index 0000000..eaffcb2
--- /dev/null
+++ b/instantiate_templates.sh
@@ -0,0 +1,43 @@
+#!/usr/bin/env sh
+
+#! Copies the templates from `templates/*` to `build/*` and replaces every symlink with a
+#! copy.
+
+# Source: https://stackoverflow.com/a/20460402
+# Checks if the string (arg2) starts with the substring (arg1)
+#
+# arg1: substring
+# arg2: string
+stringContain() { case $2 in $1*) return 0 ;; *) return 1 ;; esac }
+
+ROOT="$(git rev-parse --show-toplevel)"
+
+DRY_RUN_CMD=""
+
+$DRY_RUN_CMD mkdir --parents "$ROOT/build"
+
+fd . "$ROOT/templates" --max-depth 1 --type directory | while read -r template; do
+    echo "Instantiating template: '.${template#"$ROOT"}'.."
+    template_new_path="$ROOT/build/$(basename "$template")"
+    $DRY_RUN_CMD cp --no-target-directory --recursive "${template%/}" "$template_new_path"
+
+    {
+        # Show directories
+        fd . "$template_new_path" --type symlink --follow --hidden
+
+        # Show simple files
+        fd . "$template_new_path" --type symlink --hidden
+    } | while read -r symlink; do
+        symlink_path="$(readlink --canonicalize "$symlink")"
+
+        if stringContain "$ROOT" "$symlink_path"; then
+            echo "Instantiating symlink: '.${symlink#"$ROOT"}'.."
+            $DRY_RUN_CMD rm "$symlink"
+            $DRY_RUN_CMD cp "$symlink_path" "$symlink"
+        else
+            echo "Not instantiating symlink '.${symlink#"$ROOT"}', as it points outside the repo!"
+        fi
+    done
+done
+
+# vim: ft=sh