Merge pull request #1109 from containous/fix-git-rpr-upstream

Fix git rpr
This commit is contained in:
Emile Vauge 2017-02-06 14:40:45 +01:00 committed by GitHub
commit 106e5c1f92
3 changed files with 66 additions and 13 deletions

26
.github/cpr.sh vendored Executable file
View file

@ -0,0 +1,26 @@
#!/bin/sh
#
# git config --global alias.cpr '!sh .github/cpr.sh'
set -e # stop on error
usage="$(basename "$0") pr -- Checkout a Pull Request locally"
if [ "$#" -ne 1 ]; then
echo "Illegal number of parameters"
echo "$usage" >&2
exit 1
fi
command -v jq >/dev/null 2>&1 || { echo "I require jq but it's not installed. Aborting." >&2; exit 1; }
set -x # echo on
initial=$(git rev-parse --abbrev-ref HEAD)
pr=$1
remote=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.repo.owner.login)
branch=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.ref)
git remote add $remote git@github.com:$remote/traefik.git
git fetch $remote $branch
git checkout -t $remote/$branch

27
.github/rmpr.sh vendored Executable file
View file

@ -0,0 +1,27 @@
#!/bin/sh
#
# git config --global alias.rmpr '!sh .github/rmpr.sh'
set -e # stop on error
usage="$(basename "$0") pr -- remove a Pull Request local branch & remote"
if [ "$#" -ne 1 ]; then
echo "Illegal number of parameters"
echo "$usage" >&2
exit 1
fi
command -v jq >/dev/null 2>&1 || { echo "I require jq but it's not installed. Aborting." >&2; exit 1; }
set -x # echo on
initial=$(git rev-parse --abbrev-ref HEAD)
pr=$1
remote=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.repo.owner.login)
branch=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.ref)
# clean
git checkout $initial
git branch -D $branch
git remote remove $remote

26
.github/rpr.sh vendored
View file

@ -4,9 +4,9 @@
set -e # stop on error set -e # stop on error
usage="$(basename "$0") pr -- rebase a Pull Request against current branch" usage="$(basename "$0") pr remote/branch -- rebase a Pull Request against a remote branch"
if [ "$#" -ne 1 ]; then if [ "$#" -ne 2 ]; then
echo "Illegal number of parameters" echo "Illegal number of parameters"
echo "$usage" >&2 echo "$usage" >&2
exit 1 exit 1
@ -16,20 +16,20 @@ command -v jq >/dev/null 2>&1 || { echo "I require jq but it's not installed. A
set -x # echo on set -x # echo on
base=$(git rev-parse --abbrev-ref HEAD) initial=$(git rev-parse --abbrev-ref HEAD)
pr=$1 pr=$1
base=$2
remote=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.repo.owner.login) remote=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.repo.owner.login)
branch=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.ref) branch=$(curl -s https://api.github.com/repos/containous/traefik/pulls/$pr | jq -r .head.ref)
git checkout $base clean ()
{
.github/rmpr.sh $pr
}
git remote add $remote git@github.com:$remote/traefik.git trap clean EXIT
git fetch $remote $branch
git checkout -t $remote/$branch .github/cpr.sh $pr
git rebase origin/$base
git rebase $base
git push -f $remote $branch git push -f $remote $branch
# clean
git checkout $base
git branch -D $branch
git remote remove $remote