On Tue, Jun 18, 2013 at 02:05:35AM -0400, Jeff King wrote: > On Tue, Jun 18, 2013 at 04:17:03AM +0200, SZEDER Gábor wrote: > > > The whole series speeds up the bash prompt on Windows/MSysGit > > considerably. Here are some timing results in two scenarios, repeated > > 10 times: > > > > At the top of the work tree, before: > > > > $ time for i in {0..9} ; do prompt="$(__git_ps1)" ; done > > > > real 0m1.716s > > user 0m0.301s > > sys 0m0.772s > > > > After: > > > > real 0m0.686s > > user 0m0.075s > > sys 0m0.287s > > > > In a subdirectory, during rebase, stash status indicator enabled, > > before: > > > > real 0m3.557s > > user 0m0.495s > > sys 0m1.767s > > > > After: > > > > real 0m0.702s > > user 0m0.045s > > sys 0m0.409s > > Very nice speedup (or perhaps it is a testament to how bad fork() is on > msys). Well, it seems it's not just fork() & friends. The latter case on Linux, before: $ time for i in {0..99}; do prompt="$(__git_ps1)" ; done real 0m2.819s user 0m0.180s sys 0m0.272s After: real 0m0.787s user 0m0.000s sys 0m0.044s If you look solely at speedup (Win/MSys: 80%, Linux: 72%), Linux isn't that much better either, but overall it's about an order of magnitude faster to begin with (100 repetitions vs. 10). Btw, it could still be a bit faster in you would care to change your prompt to run from $PROMPT_COMMAND, because it would avoid that final $(__git_ps1) command sunstitution, too. But I didn't measured that because I find the interface awful ;) (Hmm, speaking of which, the patch reading HEAD might break setups using $PROMPT_COMMAND, because it might do a simple return without updating $PS1...) > Reading patches 8 and 9, I can't help but feel that "git status" > is letting us down a little by making us parse all of this data > ourselves. In theory, __git_ps1() could just be something like: > > eval "$(git status --shell)" > printf ... > > and the heavy lifting could be done in a single C process which does not > have to worry about fork overhead. But that is quite far from where we > are now, so while it might be an interesting place to go in the future, > I do not think such dreams would want to hold up current work. Yeah, that would be one way to go. It would have the added benefit that it could support 'core.abbrev' in the non-describable detached HEAD case without noticable overhead. OTOH it still requires a command substitution and a git command, so it's less than ideal. The previous version of this series more than a year ago did some tricky things to create a prompt without a single fork(), let alone exec(), e.g. looking for .git directory with bash builtins, comparing pwd's prefix with path to .git dir to find out whether inside .git dir, etc. As a result even that subdir+rebase+stash case could be done in 10ms on Windows. Too bad that that "inside .git dir" check could misfire on case insensitive file systems, so we have to do that check with '$(git rev-parse)'. http://thread.gmane.org/gmane.comp.version-control.git/197432/focus=197450 Gábor -- 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