当前状态:我git diff-tree -r HASH
用来在特定提交中列出所有添加、修改和删除的文件。这一直有效到今天。
问题:我想在我的第一次提交中列出所有添加的文件,但是将第一个 HASH 作为参数传递是行不通的。为什么?
主要问题:如何获取第一次提交中添加的所有文件的列表?
当前状态:我git diff-tree -r HASH
用来在特定提交中列出所有添加、修改和删除的文件。这一直有效到今天。
问题:我想在我的第一次提交中列出所有添加的文件,但是将第一个 HASH 作为参数传递是行不通的。为什么?
主要问题:如何获取第一次提交中添加的所有文件的列表?
这对我有用
git show <commit|branch-name> --name-only
git show --pretty=format: --name-only <revision>
对于第一次提交,如果你坚持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