Why might git log not show history for a moved file, and what can I do about it?

前端 未结 4 1994
花落未央
花落未央 2020-12-07 19:56

I\'ve renamed a couple of files using git mv, used git stash, had a quick look at HEAD (without changing it) then did git stash pop to

相关标签:
4条回答
  • 2020-12-07 20:12

    Please have a try with git log --follow on your file. I learn from here Is it possible to move/rename files in git and maintain their history?

    0 讨论(0)
  • 2020-12-07 20:22

    Answering my own question, since I have managed to assuage my concerns, even if I haven't solved my problem exactly. (git log --follow still doesn't work for me, though.)

    Firstly, the --summary log for the renaming commit includes the delete line with the file's old name. So if it's easy to spot, you can find its old name and git log from there.

    If it's part of some large commit, and therefore a bit harder to spot -- and this situation was one of my worries -- git blame -C can be used with the file's new name on the first post-rename revision. Presumably lines remain from the original file! -- so git should find their source, and show old file name (and a commit hash for good measure). You can then pick up the trail with git log.

    So, if you have some interest in the history of the file as a unit (for whatever reason) then it seems like it can be done relatively straightforwardly. Though I get the impression git would prefer that you used it properly.

    0 讨论(0)
  • 2020-12-07 20:28

    Well, I do see my renames with git log -M --summary..

    0 讨论(0)
  • 2020-12-07 20:32
    git log --follow ./path/to/file
    

    I believe this is what you're looking for.

    0 讨论(0)
提交回复
热议问题