From: Daniel Vetter <daniel.vetter@ffwll.ch>
To: DRI Development <dri-devel@lists.freedesktop.org>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>,
Intel Graphics Development <intel-gfx@lists.freedesktop.org>,
Daniel Vetter <daniel.vetter@intel.com>
Subject: [PATCH 15/18] dim: support multiple remotes for branches
Date: Fri, 21 Oct 2016 21:36:57 +0200 [thread overview]
Message-ID: <20161021193700.22100-16-daniel.vetter@ffwll.ch> (raw)
In-Reply-To: <20161021193700.22100-1-daniel.vetter@ffwll.ch>
Still left to do is fixing up create-branch and remove-branch.
Everything else should work here now.
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
---
dim | 36 ++++++++++++++++++++++++++----------
1 file changed, 26 insertions(+), 10 deletions(-)
diff --git a/dim b/dim
index 4d5008ecce11..fc99108b6e55 100755
--- a/dim
+++ b/dim
@@ -163,7 +163,8 @@ if [ "$subcommand" != "setup" -a "$subcommand" != "help" -a "$subcommand" != "us
#
dim_branches=`(source $DIM_PREFIX/drm-rerere/nightly.conf ; echo $nightly_branches) | \
- xargs -n 1 echo | grep '^origin' | sed -e 's/^origin\///'`
+ xargs -n 1 echo | grep '^\(drm-intel\|drm-misc\)' | \
+ sed -e 's/^\(drm-intel\|drm-misc\)\///'`
fi
function dim_uptodate
@@ -209,6 +210,14 @@ function get_remote_name
echo $remote
}
+function get_remote_for_branch
+{
+ local remote=`git rev-parse --abbrev-ref --symbolic-full-name $1@{upstream}`
+ remote=${remote%%/*}
+
+ echo $remote
+}
+
# get message id from file
# $1 = file
message_get_id ()
@@ -434,12 +443,14 @@ function dim_push_branch
exit 1
fi
- branch=$1
+ local branch=$1
shift
assert_branch $branch
- git push $DRY_RUN $DIM_DRM_INTEL_REMOTE $branch "$@"
+ local remote=`get_remote_for_branch $branch`
+
+ git push $DRY_RUN $remote $branch "$@"
dim_rebuild_nightly
}
@@ -715,7 +726,11 @@ function dim_checkout
dim_cd $1
if [[ `git branch --list $1` == "" ]] ; then
- git checkout -t $DIM_DRM_INTEL_REMOTE/$1
+ if [[ `git branch --list --remote $1` == "" ]] ; then
+ git checkout -t $DIM_DRM_INTEL_REMOTE/$1
+ else
+ git checkout -t $1
+ fi
else
git checkout $1
fi
@@ -999,8 +1014,9 @@ function dim_pull_request
exit 1
fi
- branch=$1
- upstream=$2
+ local branch=$1
+ local upstream=$2
+ local remote=`get_remote_for_branch $1`
if [ "$branch" != "drm-intel-next" ]; then
assert_branch $branch
@@ -1013,13 +1029,13 @@ function dim_pull_request
if [ "$branch" = "drm-intel-next" ]; then
# drm-intel-next pulls have been tagged using dim update-next
- drm_intel_next_tags=`git log $DIM_DRM_INTEL_REMOTE/drm-intel-next ^$upstream --decorate | grep "(.*tag: drm-intel-next-" | sed -e "s/^.*(.*tag: \(drm-intel-next-[^ ,]*\).*)$/\1/"`
+ drm_intel_next_tags=`git log $branch@{upstream} ^$upstream --decorate | grep "(.*tag: drm-intel-next-" | sed -e "s/^.*(.*tag: \(drm-intel-next-[^ ,]*\).*)$/\1/"`
prep_pull_mail $drm_intel_next_tags
- tag=`git describe --all --exact $DIM_DRM_INTEL_REMOTE/drm-intel-next`
+ tag=`git describe --all --exact $branch@{upstream}`
else
tag=$branch-$today
- $DRY git tag -f $tag $DIM_DRM_INTEL_REMOTE/$branch
- $DRY git push -f $DIM_DRM_INTEL_REMOTE $tag
+ $DRY git tag -f $tag $branch@{upstream}
+ $DRY git push -f $remote $tag
prep_pull_mail
fi
--
2.9.3
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
next prev parent reply other threads:[~2016-10-21 19:37 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-10-21 19:36 [PATCH 00/18] dim: split out drm-misc/tip.git Daniel Vetter
2016-10-21 19:36 ` [PATCH 01/18] dim: Extract TODO Daniel Vetter
2016-10-21 19:36 ` [PATCH 02/18] dim: Autocheck for up-to-dateness Daniel Vetter
2016-10-21 19:36 ` [PATCH 03/18] dim: echoerr helper for printing to stderr Daniel Vetter
2016-10-21 19:36 ` [PATCH 04/18] dim: autodetect remotes, first part for dim_setup Daniel Vetter
2016-10-21 19:36 ` [PATCH 05/18] dim: support git worktree for aux checkouts Daniel Vetter
2016-10-21 19:36 ` [PATCH 06/18] dim: Nuke nightly-forget Daniel Vetter
2016-10-21 19:36 ` [PATCH 07/18] dim: autodetect branches in rebuild-nightly Daniel Vetter
2016-10-21 19:36 ` [PATCH 08/18] dim: remove integration-tree remotes Daniel Vetter
2016-10-21 19:36 ` [PATCH 09/18] dim: Split out drm-nightly.git Daniel Vetter
2016-10-21 19:36 ` [PATCH 10/18] dim: s/drm-nightly/drm-tip Daniel Vetter
2016-10-21 19:36 ` [PATCH 11/18] dim: use git branch --list Daniel Vetter
2016-10-21 19:36 ` [PATCH 12/18] dim: add revert-rerere Daniel Vetter
2016-10-21 19:36 ` [PATCH 13/18] dim: use get_maintainers.pl in dim fixes Daniel Vetter
2016-10-21 19:36 ` [PATCH 14/18] dim-update-next: Update DRIVER_TIMESTAMP Daniel Vetter
2016-10-21 19:36 ` Daniel Vetter [this message]
2016-10-21 19:36 ` [PATCH 16/18] dim: remove DIM_DRM_UPSTREAM_REMOTE config var Daniel Vetter
2016-10-21 19:36 ` [PATCH 17/18] dim: Adapat create/remove-branch Daniel Vetter
2016-10-21 19:37 ` [PATCH 18/18] dim: Make update_linux_next multi-repo compliant Daniel Vetter
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20161021193700.22100-16-daniel.vetter@ffwll.ch \
--to=daniel.vetter@ffwll.ch \
--cc=daniel.vetter@intel.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.