Je suis au milieu d'une git bisect
session.
Quelle est la commande pour savoir sur quel commit (hachage SHA1) je suis actuellement? git status
ne fournit pas cela.
Edit: Je suppose qu'appeler git log
et regarder la première entrée fonctionne?
Vous avez au moins 5 façons différentes d'afficher le commit que vous avez actuellement extrait dans votre copie de travail pendant une git bisect
session ( notez que les options 1 à 4 fonctionneront également lorsque vous ne faites pas de bissectrice ):
git show
.git log -1
.git status
.git bisect visualize
.J'expliquerai chaque option en détail ci-dessous.
Comme expliqué dans cette réponse à la question générale de savoir comment déterminer quel commit vous avez actuellement extrait (pas seulement pendant git bisect
), vous pouvez utiliser git show
avec l' -s
option pour supprimer la sortie du patch:
$ git show --oneline -s
a9874fd Merge branch 'epic-feature'
Vous pouvez également simplement le faire git log -1
pour savoir sur quel commit vous êtes actuellement.
$ git log -1 --oneline
c1abcde Add feature-003
Dans Git version 1.8.3+ (ou était-ce une version antérieure?), Si votre invite Bash est configurée pour afficher la branche actuelle que vous avez extraite dans votre copie de travail, elle vous montrera également le commit actuel que vous avez vérifié pendant une session bissectrice ou lorsque vous êtes dans un état "HEAD détaché". Dans l'exemple ci-dessous, j'ai actuellement c1abcde
vérifié:
# Prompt during a bisect
user ~ (c1abcde...)|BISECTING $
# Prompt at detached HEAD state
user ~ (c1abcde...) $
Toujours à partir de la version 1.8.3+ de Git (et peut-être plus tôt, encore une fois pas sûr), l'exécution git status
vous montrera également quel commit vous avez extrait pendant une bissectrice et lorsque vous êtes dans l'état HEAD détaché:
$ git status
# HEAD detached at c1abcde <== RIGHT HERE
Enfin, pendant que vous effectuez un git bisect
, vous pouvez également simplement utiliser git bisect visualize
ou son alias intégré git bisect view
pour lancer gitk
, afin de pouvoir visualiser graphiquement le commit sur lequel vous vous trouvez, ainsi que les commits que vous avez marqués comme mauvais et bons jusqu'à présent. Je suis à peu près sûr que cela existait bien avant la version 1.8.3, je ne sais pas dans quelle version il a été introduit:
git bisect visualize
git bisect view # shorter, means same thing
git log -p -S <search>
le travail.git status
ne vous montre pas l'ID de validation sauf si vous êtes à l'état détaché. sinon, il dit "Sur la branche quel que soit ".git show
fonctionne bienVous pouvez simplement faire:
Pour expliquer un peu plus loin:
git rev-parse
est la commande de base de git pour interpréter l' une des façons exotiques que vous pouvez spécifier le nom d'un commit etHEAD
est une référence à votre commit ou branche actuel. (Dans unegit bisect
session, il pointe directement vers un commit ("détaché HEAD") plutôt qu'une branche.)Une autre solution (et plus facile à retenir) serait de simplement faire:
... qui affiche par défaut le commit vers lequel
HEAD
pointe. Pour une version plus concise, vous pouvez faire:la source
git rev-parse HEAD
ne nécessite aucun traitement par rapport à toutes les alternatives de récupération.Mettre à jour:
Alternativement (si vous avez des balises):
(Bon pour nommer une version, pas très bon pour renvoyer à git.)
Ou (comme Mark l'a suggéré, énumérant ici pour l'exhaustivité):
la source
Si vous voulez extraire juste une simple information, vous pouvez l'obtenir en utilisant
git show
l'--format=<string>
option ... et lui demander de ne pas vous donner la différence avec--no-patch
. Cela signifie que vous pouvez obtenir une sortie de style printf de tout ce que vous voulez, qui peut souvent être un seul champ.Par exemple, pour obtenir uniquement le hachage raccourci (
%h
), vous pouvez dire:Si vous cherchez à enregistrer cela dans une variable d'environnement dans bash (ce que les gens voudront probablement faire), vous pouvez utiliser la
$()
syntaxe :La liste
git show --help
complète de ce que vous pouvez faire se trouve dans . Mais voici une liste abrégée de propriétés qui pourraient être utiles:%H
commettre le hachage%h
hachage de validation abrégé%T
hachage d'arbre%t
hachage d'arbre abrégé%P
hachages parent%p
hachages de parent abrégé%an
nom de l'auteur%ae
email de l'auteur%at
date de l'auteur, horodatage UNIX%aI
date de l'auteur, format ISO 8601 strict%cn
nom du commetteur%ce
email du committer%ct
date du committer, horodatage UNIX%cI
date du committer, format ISO 8601 strict%s
matière%f
ligne d'objet nettoyée, adaptée à un nom de fichier%gD
sélecteur reflog, par exemple, refs / stash @ {1}%gd
sélecteur de reflog raccourci, par exemple, stash @ {1}la source
show
n'a rien pour la branche .Utilisez
git show
, qui affiche également le message de validation, et prend par défaut la validation actuelle si aucun argument n'est donné.la source