背景
最近在提交文件时,因为是空的 Maven 项目结构,发现 Git 空目录死活不能提交,还以为是我自己在 .gitignore 文件中忽略了,在网上查了下,原来还真有这回事。
如,用 git status 查看状态:
$ git status
On branch master
No commits yet
nothing to commit (create/copy files and use "git add" to track)
空目录无法被 git 感应。
解决方案
最主流的做法是,在空目录下创建 .gitkeep 或者 .keep 空文件,或者 .gitignore 文件,这只是一个约定俗成的空目录识别文件名,其实除了占位识别空目录,其他并没什么卵用。
我们再在空目录中创建一个空文件:
touch .gitkeep
然后再用 git status 查看状态:
$ git status
On branch master
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
src/
nothing added to commit but untracked files present (use "git add" to track)
现在可以感应到 src 目录了。
另外需要注意,在项目的 .gitignore 中不要忽略此文件。如果有需要,关注公众号Java技术栈可以获取一份推荐的 .gitignore 通用文件。
WHY
这种解决方案感觉有点扯淡,为什么提交不了空目录,一定要放个文件才行,放个不相干的文件感觉又有点扯淡。
于是抱着怀疑的态度再次查下资料,在下面这个链接我找到解释:
https://git.wiki.kernel.org/index.php/GitFaq#Can_I_add_empty_directories.3F
大概就是,Git 最初的设计是用来索引文件的,所以 Git 只关注文件,不关心文件,不关心目录。
这是不是 Git 的设计问题呢?
最后,你是否有遇到这种蛋疼的问题?你还有其他解决方案吗?欢迎留言分享~
后面我还会分享一些我平时用到的修改历史记录的实战干货,比如怎么修改历史提交信息、合并多次提交等,关注公众号Java技术栈第一时间推送。
老铁们,觉得有用,点个在看、转发支持下哦!