Merge pull request #1109 from containous/fix-git-rpr-upstream
Fix git rpr
This commit is contained in:
commit
106e5c1f92
3 changed files with 66 additions and 13 deletions
26
.github/cpr.sh
vendored
Executable file
26
.github/cpr.sh
vendored
Executable 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
27
.github/rmpr.sh
vendored
Executable 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
26
.github/rpr.sh
vendored
|
@ -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
|
|
Loading…
Reference in a new issue