On Mon, Jul 09, 2007 at 01:57:10PM +0100, Johannes Schindelin wrote: > On Mon, 9 Jul 2007, Sven Verdoolaege wrote: > > On Mon, Jul 09, 2007 at 12:56:04AM +0100, Johannes Schindelin wrote: > > I thought you had to specify the name of the new branch on the command > > line. Anyway, I don't really care about the name of this hierarchy. > > I just picked a name that is somewhat related to "rewrite-commits". > > Suggestions are welcome. > > How much more explicit should I formulate my suggestion? [..] > actually changed. So even if you _have_ to keep your current behaviour, > namely that the results are stored under the original names, you should > store the original refs in something like refs/original (overridable by a I suppose I can live with "original". > command line option), but _only if_ they actually changed. That's what I do right now. > You will see that both definitions apply _perfectly_ to what you do here. > You pipe the commit into the "map" and write it out as a new commit! > The _perfect_ example for a UNIX filter. OK. Makes sense. I've always found that naming confusing, but it has a long tradition. Sorry for the strong word. > > > - The example you give with "git update-index --remove" can fail, right? > > > > Yes. Spectacularly, even. > > Does that mean you acknowledge that the man page should tell about this? > And probably also reveal the "|| :" remedy? Yes. (Am I on trial, here?) > > > - The commit filter again deviates from the usage in cg-admin-rewritehist. > > > I can see that you wanted to make it more versatile. However, it makes > > > the tool potentially also a bit more cumbersome to use. Besides, you use > > > a temporary file where there is no need to. > > > > Are you saying I should use two pipes? > > Umm. Why not? > > > What if the commit message is larger than the pipe buffer? > > You start_command(). Then you write() until it is all written, or the > pipe is broken. Then you get the output via index_pipe(). Which is a > single sha1. I do not understand your question. Ah, but that is not how my commit "filter" works right now. It should produce the whole commit on stdout (as mentioned in the documentation). So the default filter is "cat" (and not "git-hash-object -t commit --stdin", as you seem to assume). How about I change that to a filter that accepts a single SHA1 and produces zero or more SHA1's as output? A filter for the current rewrite-commits would then be replaced by "xargs | git-cat-file commit | original-filter | git-hash-object -t commit --stdin" > To enhance on the above example: you're rewriting the commit messages so > that commit names are rewritten to match the rewritten commits. That is > possible by a message filter in cg-admin-rewritehist. > > But now somebody comes along, and says "I have a history I need to > rewrite. All bug fixes. The commit names were all abbreviated in the > commit messages, but they always had 'commit ' in front of them. I want > to rewrite them, too." The current git-rewrite-commits will rewrite all SHA1's it can find, irrespective of any 'commit ' that may precede it. I guess I'm trying to misunderstand you again. > Are you trying to misunderstand me? No. > > > But hey, maybe it _is_ time to rethink the whole filter business, and > > > introduce some kind of regular expression based action language. > > > Something like > > > > > > git rewrite-commits -e '/^author Darl McBribe/skip-commit' \ > > > > What's wrong with --author='!Darl McBribe' ? > > It is a very special use case. Not always will you be able to get all the > information from the commit object you need for conditional operations. > My example only showed that you can do the same with that syntax. But > imagine what you could do if we just added a small syntactical sugar: > > -e '?has-path:README?substitute/v2/v3/' So you want to introduce a whole language? Isn't that a bit over-engineering? skimo - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html