On Sun, 3 Jun 2007, Johannes Schindelin wrote: > On Sun, 3 Jun 2007, Jakub Narebski wrote: >> Johannes Schindelin wrote: >> >>> This script is derived from Pasky's cg-admin-rewritehist. >>> >>> In fact, it _is_ the same script, minimally adapted to work without cogito. >>> It _should_ be able to perform the same tasks, even if only relying on >>> core-git programs. >>> >>> All the work is Pasky's, just the adaption is mine. >> >> I was thinking about rewriting cg-adin-rewritehist as git-rewritehist >> using Perl (IIRC it needs bash, not only POSIX shell), and make it >> use git-fast-import. By the way, why did you change name to git-filter-branch, instead of leaving it [almost] as is, i.e. git-rewritehist. Or if you wanted to emphasize that it rewrites only one branch at a time, git-rewrite-branch? Note that history (branch) gets rewritten also in absence of filters, if there are any grafts in place. But I might be mistaken. > First, it does not need Perl. > > Second, it does not even need bash. If I remember correctly (but I can be wrong here) Pasky said that he had to use arrays in cg-admin-rewritehist. Because introducing dependency on bash would be bad, that was the cause of thought to rewrite it in Perl (which we depend on anyway). See below. > At least that is what I tried to make sure. I replaced the only instance > of a bashim I was aware, namely the arrayism of $unchanged. It can be a > string just as well, as we are only storing object names in it. I'm sorry, I haven't reviewed your patch carefully enough, it seems like. If you can translate cg-admin-rewritehist to POSIX shell, more power to you. -- " -- Few notes of lesser importance (meaning they can go into subsequent commits). 1. Documentation: Cogito had documentation together with the command described, similarly to Perl POD, or LaTeX doc package + DocStrip, etc. It has IIRC rules in Makefile to extract documentation. In git we have documentation in separate files. The commands themselves have only usage, and sometimes long usage embedded. It would be nice of git-filter-branch / git-rewrite-branch also followed this convention. 2. Using fast-import. >> +# Note that since this operation is extensively I/O expensive, it might >> +# be a good idea to do it off-disk, e.g. on tmpfs. Reportedly the speedup >> +# is very noticeable. Would it be possible to use git-fast-import to reduce I/O in this command? Cogito didn't use it because it is quite new, but there is no reason to not to use it now, I think. -- Jakub Narebski Poland - 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