Existe-t-il un moyen de répertorier toutes les validations qui ont modifié un fichier spécifique?
Existe-t-il un moyen de répertorier toutes les validations qui ont modifié un fichier spécifique?
Réponses:
Les --follow
travaux pour un fichier particulier
git log --follow -- filename
Différence avec les autres solutions proposées
Notez que d'autres solutions incluent git log path
(sans le --follow
). Cette approche est pratique si vous souhaitez suivre par exemple les changements dans un répertoire , mais trébuche lorsque les fichiers ont été renommés (donc utiliser --follow filename
).
--follow
compte pour les renommages, c'est donc plus robuste quegit log -- path
--follow
accepte un chemin d'accès , qui peut être un fichier mais aussi un répertoire. Dans ce dernier cas, il s'exécutera de manière récursive et signalera les modifications apportées à tous les fichiers en dessous de ce point. (Ce comportement n'est pas documenté dans la page de manuel et peut ne pas être permanent.)
git log filename?
git log filename
ne suit pas le changement de nom du fichier, c'est-à-dire qu'il affichera toutes les validations concernant ce nom de fichier (pas le fichier réel). Si vous créez des fichiers X
et Y
, modifiés à la fois, puis supprimé Y
et renommé X
pour Y
et puis aussi changé, et que vous exécutez git log Y
, vous obtiendrez des messages à la fois ancienne Y
et nouvelle une. Et le contraire, avec --follow
vous obtiendrez des commits concernant ce fichier quand il a été nommé X
et quand il a été nommé Y
.
git log path
devrait faire ce que vous voulez. De l' git log
homme :
[--] <path>…
Show only commits that affect any of the specified paths. To prevent confusion with
options and branch names, paths may need to be prefixed with "-- " to separate them
from options or refnames.
J'ai regardé cela de près et toutes ces réponses ne semblent pas vraiment me montrer tous les engagements dans toutes les branches.
Voici ce que j'ai trouvé en jouant avec les options de vue d'édition de gitk. Cela me montre tous les commits pour un fichier indépendamment de la branche, du local, du reflog et de la distance.
gitk --all --first-parent --remotes --reflog --author-date-order -- filename
Il fonctionne également avec git log
:
git log --all --first-parent --remotes --reflog --author-date-order -- filename
--reflog
inclut les commits qui ont été rebasés / modifiés ou autrement rejetés. Cela devrait peut-être être évident, mais j'ai essayé de l'utiliser avec git log
et essayais de comprendre pourquoi je voyais des commits apparemment dupliqués!
Utilisez la commande ci-dessous pour obtenir des validations pour un fichier spécifique:
git log -p filename
git log -p mybranch -- filename
ou simplement utiliser git log --all -- filename
pour regarder dans toutes les branches.
Cela devrait être aussi simple que git log <somepath>
; consultez la page de manuel ( git-log(1)
).
Personnellement, j'aime l'utiliser git log --stat <path>
pour voir l'impact de chaque commit sur le fichier.
-p
si vous voulez voir le diff complet, pas seulement qu'il avait un certain nombre de lignes modifiées.
git show
sur les commits spécifiques qui semblent importants.
Alternativement (depuis Git 1.8.4), il est également possible d'obtenir simplement tous les commits qui ont changé une partie spécifique d'un fichier. Vous pouvez l'obtenir en passant la ligne de départ et le numéro de ligne de fin.
Le résultat renvoyé serait la liste des validations qui ont modifié cette partie particulière. La commande va comme:
git log --pretty=short -u -L <upperLimit>,<lowerLimit>:<path_to_filename>
où upperLimit
est le start_line_number
et lowerLimit
est leending_line_number
Plus d'informations - https://www.techpurohit.com/list-some-useful-git-commands
Comme l'a souligné jackrabb1t, --follow
est plus robuste car il continue de répertorier l'historique au-delà des renommages / mouvements. Donc, si vous recherchez un fichier qui ne se trouve pas actuellement dans le même chemin ou un fichier qui a été renommé lors de diverses validations, --follow le suivra.
Cela peut être une meilleure option si vous souhaitez visualiser les changements de nom / chemin:
git log --follow --name-status -- <path>
Mais si vous voulez une liste plus compacte avec seulement ce qui compte:
git log --follow --name-status --format='%H' -- <path>
ou même
git log --follow --name-only --format='%H' -- <path>
L'inconvénient est que cela --follow
ne fonctionne que pour un seul fichier.
--follow
fonctionne pour un seul chemin , qui pourrait être un répertoire. Si passé un répertoire, il s'exécutera récursivement et signalera les modifications apportées à tous les fichiers en dessous de ce point.
Si vous essayez de --suivre un fichier supprimé lors d'une précédente utilisation de commit
git log --follow -- filename
git
débutants: Utilisez également git log -p --follow -- filename
pour afficher les modifications. Notez également: "nom de fichier" peut être un fichier, un répertoire ou un sous-module.
Si vous souhaitez afficher toutes les validations qui ont modifié un fichier, dans toutes les branches, utilisez ceci:
git log --follow --all <filepath>
Si vous souhaitez rechercher toutes les validations par filename
et non par filepath
, utilisez:
git log --all -- '*.wmv'
Si vous souhaitez voir toutes les modifications apportées aux validations qui ont modifié un fichier particulier (plutôt que simplement les modifications apportées au fichier lui-même), vous pouvez transmettre --full-diff
:
git log -p --full-diff [branch] -- <path>
[branch]
gitk <path_to_filename>
En supposant que le package "gitk" est déjà installé.
S'il n'est pas installé, procédez comme suit:
sudo apt-get install gitk
Et puis essayez la commande ci-dessus. C'est pour Linux ... Cela pourrait aider les utilisateurs de Linux s'ils veulent une interface graphique.
gitk
est fourni avec Git pour Windows.
Pour obtenir simplement une liste des hachages de validation, utilisez git rev-list
git rev-list HEAD <filename>
Production:
b7c4f0d7ebc3e4c61155c76b5ebc940e697600b1
e3920ac6c08a4502d1c27cea157750bd978b6443
ea62422870ea51ef21d1629420c6441927b0d3ea
4b1eb462b74c309053909ab83451e42a7239c0db
4df2b0b581e55f3d41381f035c0c2c9bd31ee98d
ce qui signifie que 5 commits ont touché ce fichier. C'est l'ordre chronologique inverse, donc le premier commit de la liste b7c4f0d7
est le plus récent.
Sous Linux, vous pouvez utiliser gitk pour cela.
Il peut être installé à l'aide de "sudo apt-get install git-gui gitk". Il peut être utilisé pour voir les validations d'un fichier spécifique par "gitk <Filename>".
# Shows commit history with patch
git log -p -<no_of_commits> --follow <file_name>
# Shows brief details like "1 file changed, 6 insertions(+), 1 deletion(-)"
git log --stat --follow <file_name>