diff options
author | SZEDER Gábor <szeder.dev@gmail.com> | 2017-03-23 16:29:21 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-03-23 11:18:22 -0700 |
commit | 400a7553c4e0f0cafa1bef5a1dd792b6cc10c450 (patch) | |
tree | bbd88c21538b34ecf8e6c339d747e996577f72b6 /t/t1006-cat-file.sh | |
parent | 824388d54b238b0d0cdc3f584dd27cb334df4ebc (diff) | |
download | git-400a7553c4e0f0cafa1bef5a1dd792b6cc10c450.tar.gz git-400a7553c4e0f0cafa1bef5a1dd792b6cc10c450.tar.xz |
completion: let 'for-each-ref' sort remote branches for 'checkout' DWIMery
When listing unique remote branches for 'git checkout's tracking
DWIMery, __git_refs() runs the classic '... |sort |uniq -u' pattern to
filter out duplicate remote branches.
Let 'git for-each-ref' do the sorting, sparing the overhead of
fork()+exec()ing 'sort' and a stage in the pipeline where potentially
relatively large amount of data can be passed between two subsequent
pipeline stages.
This speeds up refs completion for 'git checkout' a bit when a lot of
remote branches match the current word to be completed. Listing a
single local and 100k remote branches, all packed, best of five:
On Linux, before:
$ time __git_complete_refs --track
real 0m1.856s
user 0m1.816s
sys 0m0.060s
After:
real 0m1.550s
user 0m1.512s
sys 0m0.060s
On Windows, before:
real 0m3.128s
user 0m2.155s
sys 0m0.183s
After:
real 0m2.781s
user 0m1.826s
sys 0m0.136s
Signed-off-by: SZEDER Gábor <szeder.dev@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t1006-cat-file.sh')
0 files changed, 0 insertions, 0 deletions