diff options
author | Daniel Hahler <git@thequod.de> | 2015-05-13 15:26:04 +0200 |
---|---|---|
committer | Daniel Hahler <git@thequod.de> | 2015-05-18 02:48:03 +0200 |
commit | 94c6b32fe76f630f6682edb7cb8b9c0c884809a4 (patch) | |
tree | 3e57c84e4132306c3352eb3759ee071742765dcd /Completion/Unix | |
parent | 454f079852deb0c704870c7d5a462485f1e65bbf (diff) | |
download | zsh-94c6b32fe76f630f6682edb7cb8b9c0c884809a4.tar.gz zsh-94c6b32fe76f630f6682edb7cb8b9c0c884809a4.tar.xz zsh-94c6b32fe76f630f6682edb7cb8b9c0c884809a4.zip |
35104: completion: git: __git_commit_objects: query 1000 commits
Also, `--all` and `--reflog` is used to get all commits. It adds the _guard in front, so only non-empty values will come here. Also, __git_commit_objects_prefer_recent will only call it, if there are no matching recent commits.
Diffstat (limited to 'Completion/Unix')
-rw-r--r-- | Completion/Unix/Command/_git | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/Completion/Unix/Command/_git b/Completion/Unix/Command/_git index d64e777e8..f87861edb 100644 --- a/Completion/Unix/Command/_git +++ b/Completion/Unix/Command/_git @@ -5656,12 +5656,15 @@ __git_commit_objects () { local gitdir expl start declare -a commits + # Abort if the argument does not match a commit hash (including empty). + _guard '[[:xdigit:]](#c,40)' || return 1 + # Note: the after-the-colon part must be unique across the entire array; # see workers/34768 - : ${(A)commits::=${(f)"$(_call_program commits git --no-pager log -20 --format='%h:\\\[%h\\\]\ %s')"}} + : ${(A)commits::=${(f)"$(_call_program commits git --no-pager log -1000 --all --reflog --format='%h:\\\[%h\\\]\ %s')"}} __git_command_successful $pipestatus || return 1 - _describe -V -t commits 'commit object name' commits || _guard '[[:xdigit:]](#c,40)' 'commit object name' + _describe -V -t commits 'commit object name' commits } (( $+functions[__git_recent_commits] )) || |