summaryrefslogtreecommitdiffstats
path: root/git/bin/git-checkout-branches
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2021-08-28 09:22:15 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2021-08-28 09:22:27 +0000
commitbe6735f4d9fd2138bb78110779bbff13ab9f6fa3 (patch)
treed115aab736d93525d444e73645f6ab049b8f8e5f /git/bin/git-checkout-branches
parentReleasing debian version 20190301-lts1-2. (diff)
downloadopen-infrastructure-service-tools-be6735f4d9fd2138bb78110779bbff13ab9f6fa3.tar.xz
open-infrastructure-service-tools-be6735f4d9fd2138bb78110779bbff13ab9f6fa3.zip
Merging upstream version 20210828.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'git/bin/git-checkout-branches')
-rwxr-xr-xgit/bin/git-checkout-branches29
1 files changed, 29 insertions, 0 deletions
diff --git a/git/bin/git-checkout-branches b/git/bin/git-checkout-branches
new file mode 100755
index 0000000..5b1ef15
--- /dev/null
+++ b/git/bin/git-checkout-branches
@@ -0,0 +1,29 @@
+#!/bin/sh
+
+set -e
+
+CURRENT_BRANCH="$(git branch --show-current)"
+REMOTE_BRANCHES="$(git branch -r | awk '{ print $1 }')"
+
+for REMOTE_BRANCH in ${REMOTE_BRANCHES}
+do
+ BRANCH="$(echo "${REMOTE_BRANCH}" | cut -d/ -f 2-)"
+
+ case "${BRANCH}" in
+ HEAD)
+ continue
+ ;;
+ esac
+
+ if git branch | grep -Eq "^ *${BRANCH}$"
+ then
+ continue
+ fi
+
+ git checkout -b "${BRANCH}" "${REMOTE_BRANCH}"
+done
+
+if [ "$(git branch --show-current)" != "${CURRENT_BRANCH}" ]
+then
+ git checkout "${CURRENT_BRANCH}"
+fi