case "$0" in
all|*/all)
case "`uname`" in
- MINGW*)
+ MINGW*|Win*)
# Windows hates users. So this script has to copy itself elsewhere first...
tname=
cp "$SELF" ../all.xonotic.sh
fi
;;
esac
- if ! verbose git pull; then
- check_mergeconflict "$d"
- # do not exit, as this may also mean we are tracking something else
+ verbose git config remote.origin.fetch "refs/heads/*:refs/remotes/origin/*"
+
+ r=`git symbolic-ref HEAD`
+ r=${r#refs/heads/}
+ if git config branch.$r.remote >/dev/null 2>&1; then
+ if ! verbose git pull; then
+ check_mergeconflict "$d"
+ exit 1 # FATAL
+ fi
fi
+
cd "$d00"
checkself "$cmd" "$@"
cd "$d0/$d"
branch)
remote=$1
branch=$2
+ srcbranch=$3
if [ -z "$branch" ]; then
branch=$remote
remote=origin
fi
+ if [ -z "$srcbranch" ]; then
+ srcbranch=master
+ fi
if [ -z "$branch" ]; then
for d in $repos; do
enter "$d0/$d"
read -r a
done
if [ x"$a" = x"y" ]; then
- verbose git push "$remote" HEAD:"$branch"
+ verbose git push "$remote" "$srcbranch":"$branch"
verbose git checkout --track -b "$branch" "$remote/$branch"
fi
cd "$d0"
cd "$d0"
done
;;
- push)
+ push|commit)
for d in $repos; do
dv=`visible_repo_name "$d"`
enter "$d0/$d"
echo " $SELF push"
echo " $SELF branches"
echo " $SELF branch [<remote>] <branchname>"
+ echo " $SELF branch <remote> <branchname> <srcbranchname>"
echo " $SELF checkout [<remote>] <branchname>"
echo " $SELF compile"
echo " $SELF run <client> <options>"