Skip to content

Commit

Permalink
Merge pull request #1109 from containous/fix-git-rpr-upstream
Browse files Browse the repository at this point in the history
Fix git rpr
  • Loading branch information
emilevauge committed Feb 6, 2017
2 parents 8d0bacf + c00a9fa commit 106e5c1
Show file tree
Hide file tree
Showing 3 changed files with 66 additions and 13 deletions.
26 changes: 26 additions & 0 deletions .github/cpr.sh
Original file line number Diff line number Diff line change
@@ -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 changes: 27 additions & 0 deletions .github/rmpr.sh
Original file line number Diff line number Diff line change
@@ -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 changes: 13 additions & 13 deletions .github/rpr.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@

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 "$usage" >&2
exit 1
Expand All @@ -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

base=$(git rev-parse --abbrev-ref HEAD)
initial=$(git rev-parse --abbrev-ref HEAD)
pr=$1
base=$2
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 checkout $base
clean ()
{
.github/rmpr.sh $pr
}

git remote add $remote git@github.com:$remote/traefik.git
git fetch $remote $branch
git checkout -t $remote/$branch
git rebase origin/$base
git push -f $remote $branch
trap clean EXIT

.github/cpr.sh $pr

# clean
git checkout $base
git branch -D $branch
git remote remove $remote
git rebase $base
git push -f $remote $branch

0 comments on commit 106e5c1

Please sign in to comment.