Comment puis-je vérifier avec la ligne de commande le dernier hachage de validation d'une branche particulière de Git?
Utilisation git ls-remote git://github.com/<user>/<project>.git
. Par exemple, mon projet trac-backlog donne:
:: git ls-remote git://github.com/jszakmeister/trac-backlog.git
5d6a3c973c254378738bdbc85d72f14aefa316a0 HEAD
4652257768acef90b9af560295b02d0ac6e7702c refs/heads/0.1.x
35af07bc99c7527b84e11a8632bfb396823326f3 refs/heads/0.2.x
5d6a3c973c254378738bdbc85d72f14aefa316a0 refs/heads/master
520dcebff52506682d6822ade0188d4622eb41d1 refs/pull/11/head
6b2c1ed650a7ff693ecd8ab1cb5c124ba32866a2 refs/pull/11/merge
51088b60d66b68a565080eb56dbbc5f8c97c1400 refs/pull/12/head
127c468826c0c77e26a5da4d40ae3a61e00c0726 refs/pull/12/merge
2401b5537224fe4176f2a134ee93005a6263cf24 refs/pull/15/head
8aa9aedc0e3a0d43ddfeaf0b971d0ae3a23d57b3 refs/pull/15/merge
d96aed93c94f97d328fc57588e61a7ec52a05c69 refs/pull/7/head
f7c1e8dabdbeca9f9060de24da4560abc76e77cd refs/pull/7/merge
aa8a935f084a6e1c66aa939b47b9a5567c4e25f5 refs/pull/8/head
cd258b82cc499d84165ea8d7a23faa46f0f2f125 refs/pull/8/merge
c10a73a8b0c1809fcb3a1f49bdc1a6487927483d refs/tags/0.1.0
a39dad9a1268f7df256ba78f1166308563544af1 refs/tags/0.2.0
2d559cf785816afd69c3cb768413c4f6ca574708 refs/tags/0.2.1
434170523d5f8aad05dc5cf86c2a326908cf3f57 refs/tags/0.2.2
d2dfe40cb78ddc66e6865dcd2e76d6bc2291d44c refs/tags/0.3.0
9db35263a15dcdfbc19ed0a1f7a9e29a40507070 refs/tags/0.3.0^{}
Juste grep pour celui dont vous avez besoin et découpez-le:
:: git ls-remote git://github.com/jszakmeister/trac-backlog.git | \
grep refs/heads/master | cut -f 1
5d6a3c973c254378738bdbc85d72f14aefa316a0
Ou, vous pouvez spécifier les références que vous voulez sur la ligne de commande et éviter le grep avec:
:: git ls-remote git://github.com/jszakmeister/trac-backlog.git refs/heads/master | \
cut -f 1
5d6a3c973c254378738bdbc85d72f14aefa316a0
Remarque: il n'est pas nécessaire que ce soit le git://
URL. Il pourrait être https://
ou [email protected]:
aussi.
À l'origine, cela visait à connaître le dernier commit d'une branche distante (pas seulement à partir de votre dernière extraction, mais le dernier commit dans la branche du référentiel distant). Si vous avez besoin du hash de commit pour quelque chose localement, la meilleure réponse est:
git rev-parse branch-name
C'est rapide, facile et une seule commande. Si vous voulez le hash de commit pour la branche courante, vous pouvez regarder HEAD:
git rev-parse HEAD
git log -n 1 [branch_name]
branch_name
(peut être une branche distante ou locale) est facultatif. Sans pour autant branch_name
, il affichera le dernier commit sur la branche en cours.
Par exemple:
git log -n 1
git log -n 1 Origin/master
git log -n 1 some_local_branch
git log -n 1 --pretty=format:"%H" #To get only hash value of commit
Essayez d'utiliser git log -n 1
après avoir fait un git checkout branchname
. Ceci affiche le hachage de validation, l'auteur, la date et le message de validation pour la dernière validation.
Effectuer un git pull Origin/branchname
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ Pour commencer, _ pour vous assurer que votre référentiel local correspond en amont.
Si vous ne voulez peut-être voir qu'une liste des commits, votre branche locale est en retard sur la branche distante, procédez comme suit:
git fetch Origin
git cherry localbranch remotebranch
Ceci listera tous les hachages des commits que vous n'avez pas encore fusionnés dans votre branche locale.
vous pouvez git fetch nameofremoterepo
, puis git log
et personnellement, je alias gitlog
à git log --graph --oneline --pretty --decorate --all
. essayez et voyez si ça vous va
Notez que lorsque vous utilisez l'option "git log -n 1 [nom de branche]". -n ne renvoie qu'une ligne de journal, mais l'ordre dans lequel elle est renvoyée n'est pas garanti. Voici extrait de la page de manuel git-log
.....
.....
Commit Limiting
Besides specifying a range of commits that should be listed using the special notations explained in the description, additional commit limiting may be applied.
Using more options generally further limits the output (e.g. --since=<date1> limits to commits newer than <date1>, and using it with --grep=<pattern> further limits to commits whose log message has a line that matches <pattern>), unless otherwise noted.
Note that these are applied before commit ordering and formatting options, such as --reverse.
-<number>
-n <number>
.....
.....
Dans un commentaire que vous avez écrit
je veux montrer qu'il y a une différence entre le repo local et github
Comme déjà mentionné dans une autre réponse, vous devriez faire un git fetch Origin
première. Ensuite, si la télécommande est en avance sur votre branche actuelle, vous pouvez répertorier tous les commits entre votre branche locale et la télécommande avec
git log master..Origin/master --stat
Si votre agence locale est en avance:
git log Origin/master..master --stat
--stat
affiche également une liste des fichiers modifiés.
Si vous voulez lister explicitement les ajouts et les suppressions, utilisez git diff
:
git diff master Origin/master