我想在git log
中查看每次提交中更改的文件列表。 Another question询问如何查看单个提交的已更改文件,并获得following response:
$ git diff-tree --no-commit-id --name-only -r bd61ad98
index.html
javascript/application.js
javascript/ie6.js
我想知道的是如何将其应用于git log
。也就是说,我应该运行什么命令来获得类似以下输出的内容?
commit 78b3ba12002f9cab5cbb57fac87d8c703702a196
Author: WD40 <example@example.com>
Date: Fri Apr 14 09:59:57 2017 -0500
Change more things
about.html
javascript/application.js
javascript/ie6.js
commit 0f98b1f7eda33a4e9cfaab09506aa8094044085f
Author: WD40 <example@example.com>
Date: Fri Apr 14 09:49:03 2017 -0500
Change some things
index.html
javascript/application.js
javascript/ie6.js
此外,如果可能的话,我想知道如何做同样的事情,还要显示添加和删除的文件。
我查看了git log --format
选项,但找不到任何类似我想要的内容。我觉得使用git log是不可能的,并且可能需要将来自多个git diff-tree
的输出串起来,但是我不知道如何在没有脚本的情况下(这可能是唯一的方法)我想要什么,但我想我会继续问,因为这将是我的最后一招。)
答案 0 :(得分:2)
git-log
有许多用于显示更改的选项。 They're found in the docs as Common Diff Options,很常见,因为它们可以显示许多可以显示提交的命令,例如git-diff-tree
。
--name-only
就是你想要的。还有...
-p
显示完整的补丁--stat
显示文件更改和更改次数--name-status
显示名称及其更改方式(修改,删除,...)还有更多!
因此,例如,git log --name-status
可能会显示如下内容:
commit 78b3ba12002f9cab5cbb57fac87d8c703702a196
Author: WD40 <example@example.com>
Date: Fri Apr 14 09:59:57 2017 -0500
Change more things
A about.html
M javascript/application.js
D javascript/ie6.js
commit 0f98b1f7eda33a4e9cfaab09506aa8094044085f
Author: WD40 <example@example.com>
Date: Fri Apr 14 09:49:03 2017 -0500
Change some things
A index.html
A javascript/application.js
A javascript/ie6.js
添加A
的地方,M
被修改,D
被删除。