SVN的日志有一个“-v”模式,输出每次提交时更改的文件的文件名,如下所示:

jes5199$ svn log -v
------------------------------------------------------------------------
r1 |   jes5199 | 2007-01-03 14:39:41 -0800 (Wed, 03 Jan 2007) | 1 line
Changed paths:
   A /AUTHORS
   A /COPYING
   A /ChangeLog
   A /EVOLUTION
   A /INSTALL
   A /MacOSX

是否有一种快速的方法可以在Git中获得每次提交时更改的文件列表?


当前回答

我正在使用:

git diff-tree -v --name-status -r <commit-id>

它显示了非常相似的输出,如svn log -v

其他回答

我每天都用它来显示文件更改的历史:

git log --stat --pretty=short --graph

为了保持简短,在你的.gitconfig中添加一个别名:

git config --global alias.ls 'log --stat --pretty=short --graph'

我用这个:

git log --name-status <branch>..<branch> | grep -E '^[A-Z]\b' | sort | uniq

它只输出文件列表及其状态(添加,修改,删除):

A   sites/api/branding/__init__.py
M   sites/api/branding/wtv/mod.py
...

我通常使用这些来获取日志:

$ git log --name-status --author='<Name of author>' --grep="<text from Commit message>"

$ git log --name-status --grep="<text from Commit message>"

另一个有用的命令是git diff-tree <hash>,其中哈希也可以是一个哈希范围(由<old>..新< >符号)。输出示例:

$ git diff-tree  HEAD
:040000 040000 8e09a be406 M myfile

字段为:

源模式,目标模式,源哈希,目标哈希,状态和文件名

状态是您所期望的状态:D(删除),A(添加),M(修改),等等。请参阅手册页以获得完整的描述

我发现下面是理想的显示,以简洁的格式列出每次提交更改的文件:

git log --pretty=oneline --graph --name-status