summaryrefslogtreecommitdiff
path: root/sync/griff
diff options
context:
space:
mode:
authorTimmy Keller <tjk@tjkeller.xyz>2021-10-20 20:13:28 -0500
committerTimmy Keller <tjk@tjkeller.xyz>2021-10-20 20:13:28 -0500
commit83944c6497381a77bd118a0d89107992c8f047a9 (patch)
treede141db80e256fe5aac00523b8d956583cdb7a7f /sync/griff
parentc2c48e2fb05aaffdfccd621b41aaa0e9559f8740 (diff)
downloadscripts-83944c6497381a77bd118a0d89107992c8f047a9.tar.xz
scripts-83944c6497381a77bd118a0d89107992c8f047a9.zip
optimized dmenunametag script
Diffstat (limited to 'sync/griff')
-rwxr-xr-xsync/griff53
1 files changed, 53 insertions, 0 deletions
diff --git a/sync/griff b/sync/griff
new file mode 100755
index 0000000..02b4183
--- /dev/null
+++ b/sync/griff
@@ -0,0 +1,53 @@
+#!/bin/sh
+home=$(echo $HOME | sed 's/\//\\\//g')
+repos="$(grep -v '#' | sed "s/\~/$home/")" << REPOS
+blr|~/.local/src/programs/blr
+dmenu|~/.local/src/programs/dmenu
+dotconfig|~/.config
+scripts|~/.local/bin
+st|~/.local/src/programs/st
+timmywm|~/.local/src/programs/timmywm
+REPOS
+#echo "$repos" | cut -f1
+
+# Colors
+BOLD="\033[1m"
+NORM="\033[0m"
+CYN="\033[0;36m"
+RED="\033[0;31m"
+GRN="\033[0;32m"
+MAG="\033[0;35m"
+
+for repo in $repos; do
+ name=$(echo $repo | cut -d'|' -f1)
+ dir=$(echo $repo | cut -d'|' -f2)
+ if cd $dir 2>/dev/null; then
+ if git diff --quiet HEAD $REF -- $DIR; then
+ echo "$GRN[Repo $name is unchanged!]$NORM"
+ else
+ echo "$CYN[Repo $name has changed:]$NORM"
+ echo "\tFiles Changed:"
+ git diff HEAD $REF -- $DIR | sed -n '/^+++/ s/+++ b\//\t- /p'
+ echo
+ read -p "Would you like to view the changes? [y/n]: " viewchange
+ case $viewchange in
+ y|yes|Y|Yes) git diff HEAD $REF -- $DIR ;;
+ esac
+ read -p "Would you like to push these changes? [y/n]: " pushchange
+ case $pushchange in
+ y|yes|Y|Yes)
+ while [ -z "$commitmsg" ]; do
+ read -p "Enter a commit message: " commitmsg
+ done
+ git add .
+ git commit -m "$commitmsg" \
+ && echo "$GRN[Changes to repo $name successfully pushed!]$NORM" \
+ || echo "$RED[An error occured while pushing changes to repo $name!]$NORM"
+ git push
+ ;;
+ esac
+ fi
+ else
+ echo "$BOLD$RED[Repo $name does not exist at $dir!]$NORM"
+ fi
+done