forked from martinthomson/i-d-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup-branch.sh
executable file
·47 lines (38 loc) · 1.37 KB
/
setup-branch.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/env bash
set -e
hash realpath 2>/dev/null || function realpath() { cd "$1"; pwd -P; }
branch="$1"
shift
# Fetch here, but don't abort on failure.
git fetch -qf origin "$branch:$branch" >/dev/null 2>&1 || true
if git show-ref -s "$branch" >/dev/null 2>&1; then
echo "The $branch branch already exists, skipping setup."
exit
fi
tmp=$(mktemp -d /tmp/init-branch-"$branch"-XXXXX)
function cleanup() {
rm -rf "$tmp"
}
trap cleanup ERR EXIT
echo "Initializing $branch branch"
git clone -n . "$tmp"
git -C "$tmp" checkout -q --orphan "$branch"
git -C "$tmp" rm -rfq .
echo Creating .gitignore and initial files
echo "/${LIBDIR:-"$(basename "$(dirname "$0")")"}/" > "$tmp"/.gitignore
echo "/node_modules/" >> "$tmp"/.gitignore
echo "/package-lock.json" >> "$tmp"/.gitignore
echo "/.requirements.txt" >> "$tmp"/.gitignore
echo "/Gemfile.lock" >> "$tmp"/.gitignore
for f in "$@"; do
touch "$tmp"/"$f"
done
echo Commit and push to origin/"$branch"
user=()
git config --global --get user.name >/dev/null || user+=(-c user.name='ID Bot')
git config --global --get user.email >/dev/null || user+=(-c user.email='[email protected]')
git -C "$tmp" add .gitignore "$@"
git -C "$tmp" "${user[@]}" commit -m "Automatic setup of $branch."
git -C "$tmp" push origin "$branch"
git push --set-upstream origin "$branch" || \
echo "Not pushing $branch because it might already exist."