Comme d'autres l'ont souligné, ce message provient de l'invite de votre shell. Le problème est que dans un référentiel fraîchement créé HEAD
( .git/HEAD
) pointe vers une référence qui n'existe pas encore.
% git init test
Initialized empty shared Git repository in /Users/jhelwig/tmp/test/.git/
% cd test
% cat .git/HEAD
ref: refs/heads/master
% ls -l .git/refs/heads
total 0
% git rev-parse HEAD
HEAD
fatal: ambiguous argument 'HEAD': unknown revision or path not in the working tree.
Use '--' to separate paths from revisions
On dirait que rev-parse
est utilisé sans qu'un contrôle d'erreur suffisant n'ait été effectué au préalable. Après la création du premier commit .git/refs/heads
est un peu différent et git rev-parse HEAD
n'échouera plus.
% ls -l .git/refs/heads
total 4
-rw------- 1 jhelwig staff 41 Oct 14 16:07 master
% git rev-parse HEAD
af0f70f8962f8b88eef679a1854991cb0f337f89
Dans la fonction qui met à jour les informations Git pour le reste de mon invite de commande (version fortement modifiée du thème d'invite wunjo pour ZSH), j'ai ce qui suit pour contourner le problème :
zgit_info_update() {
zgit_info=()
local gitdir=$(git rev-parse --git-dir 2>/dev/null)
if [ $? -ne 0 ] || [ -z "$gitdir" ]; then
return
fi
# More code ...
}