login
Header Space

 
 

[PATCH] Add contrib/stg-gitk: helper script to run gitk

Score:
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Catalin Marinas <catalin.marinas@...>
Cc: GIT list <git@...>
Date: Monday, January 8, 2007 - 6:12 pm

Signed-off-by: Yann Dirson <ydirson@altern.org>
---

Here is a small helper script implementing the display of current/named/all
stgit stacks (or standard branches) in gitk.  As noted earlier, that does not
allow to see new refs by requesting an update from gitk, but it will still be
useful to me at least :)

 contrib/stg-gitk |   59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 59 insertions(+), 0 deletions(-)

diff --git a/contrib/stg-gitk b/contrib/stg-gitk
new file mode 100755
index 0000000..8d4ae43
--- /dev/null
+++ b/contrib/stg-gitk
@@ -0,0 +1,59 @@
+#!/bin/sh
+set -e
+
+# stg-gitk - helper script to graphically display an StGIT stack
+
+# Allows quick synchronization of a cvs mirror branch (does not try to
+# reconstruct patchsets, creates "jumbo" commits), and commits stgit
+# patches to CVS.
+
+# LIMITATIONS:
+# - asking gitk to "update" won't detect any new ref
+# - no support for spaces in branch names
+
+# Copyright (c) 2007 Yann Dirson <ydirson@altern.org>
+# Subject to the GNU GPL, version 2.
+
+usage()
+{
+    echo "Usage: $(basename $0) [<branches>|--all]"
+    exit 1
+}
+
+allbranches=0
+case "$1" in
+--all) allbranches=1; shift ;;
+--*) usage ;;
+*) break ;;
+esac
+
+if [ $allbranches = 1 ] && [ "$#" -gt 0 ]; then
+    usage
+fi
+
+GIT_DIR=$(git-rev-parse --git-dir)
+GIT_DIR_SPKIPLEN=$(printf "$GIT_DIR/X" | wc -c)
+
+refdirs=''
+if [ $allbranches = 1 ]; then
+    refdirs="$GIT_DIR/refs"
+else
+    if [ "$#" = 0 ]; then
+	set -- "$(stg branch)"
+    fi
+
+    for b in "$@"; do
+	if [ -e "$GIT_DIR/refs/patches/$b" ]; then
+	    # StGIT branch: show all patches
+	    refdirs="$refdirs $GIT_DIR/refs/patches/$b"
+	elif [ -e "$GIT_DIR/refs/heads/$b" ]; then
+	    # other GIT branch
+	    refdirs="$refdirs $GIT_DIR/refs/heads/$b"
+	else
+	    echo >&2 "ERROR: no such branch '$b'"
+	    usage
+	fi
+    done
+fi
+
+gitk $(find $refdirs -type f -not -name '*.log' | cut -c${GIT_DIR_SPKIPLEN}- )
-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH] Add contrib/stg-gitk: helper script to run gitk, Yann Dirson, (Mon Jan 8, 6:12 pm)
Re: [PATCH] Add contrib/stg-gitk: helper script to run gitk, Catalin Marinas, (Wed Jan 10, 7:47 pm)
Re: [PATCH] Add contrib/stg-gitk: helper script to run gitk, Catalin Marinas, (Fri Jan 12, 7:09 pm)
Re: suggestions about stgit commands renaming, Yann Dirson, (Wed Jan 10, 3:52 pm)
Re: suggestions about stgit commands renaming, Catalin Marinas, (Wed Jan 10, 7:35 pm)
speck-geostationary