diff options
author | Malfurious <m@lfurio.us> | 2023-08-08 22:06:21 -0400 |
---|---|---|
committer | Malfurious <m@lfurio.us> | 2023-08-08 22:06:21 -0400 |
commit | 2c3e2e404c87d01166471ec9f27912d654dec9bb (patch) | |
tree | 5b89256482654679727eafb35f665e1d517f0a3b /acid/check_source | |
parent | 2a5c618158dc9a3c583e5ae054bb59b5870955af (diff) | |
download | cychedelic-2c3e2e404c87d01166471ec9f27912d654dec9bb.tar.gz cychedelic-2c3e2e404c87d01166471ec9f27912d654dec9bb.zip |
acid: Update check_source
Script is renamed to 'cyche-source' and updated to account for a couple
of potential edge-cases during a git update.
Signed-off-by: Malfurious <m@lfurio.us>
Diffstat (limited to 'acid/check_source')
-rwxr-xr-x | acid/check_source | 47 |
1 files changed, 0 insertions, 47 deletions
diff --git a/acid/check_source b/acid/check_source deleted file mode 100755 index b86e32d..0000000 --- a/acid/check_source +++ /dev/null @@ -1,47 +0,0 @@ -#!/bin/bash - -# check_source <name> <url> <refspec> -# -# Check a git source for new updates. A local cache repository is cloned if -# <name> doesn't exist. If updates are found, we attempt to checkout the -# newest version according to <refspec> (see git-for-each-ref(1)). -# -# The new (or current) git commit hash is printed to stdout. If the file tree -# is updated, this file exits non-zero. - -gethash() { - git for-each-ref \ - --count=1 \ - --format='%(objectname)' \ - --sort='-creatordate' \ - "$1" #ref -} - -cd '/git' - -if ! [ -d "$1" ]; then - git clone "$2" "$1" >&2 - touch "$1/.git/previous_hash" - touch "$1/.git/previous_slug" -fi - -cd "$1" - -git fetch --all --prune >&2 -prev=$(cat '.git/previous_hash') -next=$(gethash "$3") -echo "$next" - -if [ "$prev" != "$next" ]; then - git submodule deinit --all -f >/dev/null 2>&1 - git reset . >/dev/null 2>&1 - git checkout . >/dev/null 2>&1 - git clean -xffd >/dev/null 2>&1 - - git checkout "$next" >/dev/null 2>&1 - git submodule update --init --recursive >/dev/null 2>&1 - - exit 1 -fi - -exit 0 |