git-stash: don't complain when listing in a repo with no stash

Previously, the git-log invocation would complain if a repo
had not had any stashes created in it yet:

$ git-init
$ git-stash
fatal: ambiguous argument 'refs/stash': unknown revision or
  path not in the working tree.
Use '--' to separate paths from revisions

Instead, we only call git-log if we actually have a
refs/stash. We could alternatively create the ref when any
stash command is called, but it's better for the 'list'
command to not require write access to the repo.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2007-07-02 00:21:24 -04:00 коммит произвёл Junio C Hamano
Родитель 006a866464
Коммит 401de4057a
1 изменённых файлов: 5 добавлений и 0 удалений

Просмотреть файл

@ -76,7 +76,12 @@ save_stash () {
printf >&2 'Saved WIP on %s\n' "$msg" printf >&2 'Saved WIP on %s\n' "$msg"
} }
have_stash () {
git-rev-parse --verify $ref_stash >/dev/null 2>&1
}
list_stash () { list_stash () {
have_stash || return 0
git-log --pretty=oneline -g "$@" $ref_stash | git-log --pretty=oneline -g "$@" $ref_stash |
sed -n -e 's/^[.0-9a-f]* refs\///p' sed -n -e 's/^[.0-9a-f]* refs\///p'
} }