From: Thomas Rast <trast@student.ethz.ch>
To: git@vger.kernel.org
Cc: Petr Baudis <pasky@suse.cz>
Subject: [TopGit TOY PATCH] tg-graft: forge tip--base--<deps...> history for a subcommand
Date: Tue, 12 Aug 2008 23:10:16 +0200 [thread overview]
Message-ID: <1218575416-16711-1-git-send-email-trast@student.ethz.ch> (raw)
Adds a command 'tg graft <command>' that evaluates <command> with a
special GIT_GRAFT_FILE: the parent of each patch head is its patch
base, and the parents of the patch base are the dependencies of the
patch.
Try, for example, 'tg graft "gitk --all"'.
Signed-off-by: Thomas Rast <trast@student.ethz.ch>
---
Mainly sending this so someone can turn it into a useful feature, and
maybe build a few subcommands on top of it (that might call gitk or
'git log --graph', for example).
The one big issue with the resulting history is that the commit
messages at the tip aren't very interesting and may even be completely
irrelevant (for a base merge). I don't see a good solution for that.
Makefile | 2 +-
tg-graft.sh | 47 +++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 48 insertions(+), 1 deletions(-)
create mode 100755 tg-graft.sh
diff --git a/Makefile b/Makefile
index 6eade1e..57745c0 100644
--- a/Makefile
+++ b/Makefile
@@ -6,7 +6,7 @@ sharedir = $(PREFIX)/share/topgit
hooksdir = $(cmddir)/hooks
-commands_in = tg-create.sh tg-delete.sh tg-export.sh tg-info.sh tg-patch.sh tg-summary.sh tg-update.sh
+commands_in = tg-create.sh tg-delete.sh tg-export.sh tg-info.sh tg-patch.sh tg-summary.sh tg-update.sh tg-graft.sh
hooks_in = hooks/pre-commit.sh
commands_out = $(patsubst %.sh,%,$(commands_in))
diff --git a/tg-graft.sh b/tg-graft.sh
new file mode 100755
index 0000000..b6d0458
--- /dev/null
+++ b/tg-graft.sh
@@ -0,0 +1,47 @@
+#!/bin/sh
+# TopGit - A different patch queue manager
+# (c) Petr Baudis <pasky@suse.cz> 2008
+# GPLv2
+
+if [ -z "$1" -o -n "$2" ]; then
+ echo "Usage: tg graft <command>" >&2
+ exit 1
+fi
+
+mkdir -p "$git_dir"/info
+
+grafts_file="$(mktemp)"
+
+if [ -f "$git_dir"/info/grafts ]; then
+ cp "$git_dir"/info/grafts "$grafts_file"
+fi
+
+mapdir="$(mktemp -d)"
+
+git for-each-ref refs/top-bases |
+ while read rev name ref; do
+ name="${ref#refs/top-bases/}"
+ tip=$(git rev-parse "$name")
+ base=$(git rev-parse "$ref")
+ if [ "$tip" != "$base" ]; then
+ echo $base >> "$mapdir"/$tip
+ fi
+ git cat-file blob "$name:.topdeps" |
+ while read dep; do
+ if git rev-parse --verify "$dep" >/dev/null 2>&1; then
+ rev=$(git rev-parse "$dep")
+ [ $rev != $base ] && echo $rev >> "$mapdir"/$base
+ fi
+ done
+ done
+
+for sha in $(cd "$mapdir" && ls); do
+ echo $sha $(cat "$mapdir"/$sha | sort -u) >> "$grafts_file"
+done
+
+rm -rf "$mapdir"
+
+export GIT_GRAFT_FILE="$grafts_file"
+eval "$1"
+
+rm "$grafts_file"
--
1.6.0.rc2.53.gfa6b9
next reply other threads:[~2008-08-12 21:11 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-08-12 21:10 Thomas Rast [this message]
2008-08-13 7:10 ` [TopGit TOY PATCH] tg-graft: forge tip--base--<deps...> history for a subcommand Bert Wesarg
2008-08-13 7:11 ` [TopGit PATCH] Makefile: Use $(wildcard) for commands_in Bert Wesarg
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=1218575416-16711-1-git-send-email-trast@student.ethz.ch \
--to=trast@student.ethz.ch \
--cc=git@vger.kernel.org \
--cc=pasky@suse.cz \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).