3

当前状态:我git diff-tree -r HASH用来在特定提交中列出所有添加、修改和删除的文件。这一直有效到今天。

问题:我想在我的第一次提交中列出所有添加的文件,但是将第一个 HASH 作为参数传递是行不通的。为什么?

主要问题:如何获取第一次提交中添加的所有文件的列表?

4

3 回答 3

4

这对我有用

git show <commit|branch-name> --name-only
于 2017-06-06T15:11:46.817 回答
1

git show --pretty=format: --name-only <revision>

于 2017-06-06T15:10:15.423 回答
1

对于第一次提交,如果你坚持git diff-tree -r HASH,还需要一个参数,4b825dc642cb6eb9a060e54bf8d69288fbee4904

4b825dc642cb6eb9a060e54bf8d69288fbee4904是一棵空树。为了制作这个特殊的树对象:

#inside your repo
git rm -r *
git write-tree
git reset HEAD --hard

或者更可靠的方法:

#inside your repo
git init temp
cd temp
git commit --allow-empty -m 'empty tree'
cd ..
git fetch temp/ master
rm -rf temp

现在git diff-tree -r HASH 4b825dc642cb6eb9a060e54bf8d69288fbee4904工作。

您可以标记此树对象以方便将来使用,并将其推送到其他存储库。

git tag void 4b825dc642cb6eb9a060e54bf8d69288fbee4904
git diff-tree -r HASH void
git push <remote> void
于 2017-06-06T15:33:52.210 回答