view contrib/git-add-vendor-branch.sh @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
line wrap: on
line source

#! /bin/sh -e

# Create a new upstream vendor branch.

# Usage:
#  contrib/git-add-vendor-branch.sh <vendor>/<branch-name> <base>

usage ()
{
    echo "Usage:"
    echo "  $0 <vendor>/<branch-name> <start-point>"
    echo
    echo "<vendor> must have already been set up using contrib/git-fetch-vendor.sh"
    exit 1
}

if [ $# != 2 ]
then
    usage
fi

vendor=$(echo "$1" | sed -r "s:([^/]*)/.*$:\1:")
branch=$(echo "$1" | sed -r "s:[^/]*/(.*)$:\1:")
start=$2

# Sanity check the new branch argument.  If there is no '/', then the
# vendor will be the same as the entire first argument.
if [ -z "$vendor" -o -z "$branch" -o ${vendor} = $1 ]
then
    usage
fi

# Check that we know about the vendor
url=$(git config --get "remote.vendors/${vendor}.url"||true)
if [ -z "$url" ]
then
    echo "Cannot locate remote data for vendor ${vendor}.  Have you set it up?"
    exit 1
fi

git branch --no-track ${vendor}/${branch} ${start}
git push vendors/${vendor} ${vendor}/${branch}:refs/vendors/${vendor}/heads/${branch}
git fetch -q vendors/${vendor}
git branch --set-upstream-to=remotes/vendors/${vendor}/${branch} ${vendor}/$branch
echo "You are now ready to check out ${vendor}/${branch}"
echo "To push the branch upstream, use:"
echo
echo "git push vendors/${vendor} ${vendor}/${branch}"