我如何将一个空的目录(不包含文件)添加到一个Git存储库中?
当前回答
这个解决方案为我工作了。
1. 将.gitignore 文件添加到您的空白目录中:
*
*/
!.gitignore
* 忽略文件夹中的所有文件 */ 忽略子指南!.gitignore 包含.gitignore 文件
然后删除您的缓存,步行您的文件,承诺并按下:
git rm -r --cached .
git add . // or git stage .
git commit -m ".gitignore fix"
git push
其他回答
您可以随时将 README 文件放入目录中,并解释为什么您想要此,否则空白,目录在存储库中。
我总是建立一个功能来检查我想要的文件夹结构,并在项目中为我构建它。
function check_page_custom_folder_structure () {
if (!is_dir(TEMPLATEPATH."/page-customs"))
mkdir(TEMPLATEPATH."/page-customs");
if (!is_dir(TEMPLATEPATH."/page-customs/css"))
mkdir(TEMPLATEPATH."/page-customs/css");
if (!is_dir(TEMPLATEPATH."/page-customs/js"))
mkdir(TEMPLATEPATH."/page-customs/js");
}
这是在PHP,但我确信大多数语言支持相同的功能,因为文件夹的创建是由应用程序照顾的,文件夹将永远在那里。
你不能,不幸的是,你永远不会能做到这一点,这是Linus Torvald自己做的决定,他知道什么对我们有好处。
这里有一个地方,我读过一次。
我找到了 Re: 空的目录,但也许还有另一个。
你必须和工人一起生活......不幸的是。
这个解决方案为我工作了。
1. 将.gitignore 文件添加到您的空白目录中:
*
*/
!.gitignore
* 忽略文件夹中的所有文件 */ 忽略子指南!.gitignore 包含.gitignore 文件
然后删除您的缓存,步行您的文件,承诺并按下:
git rm -r --cached .
git add . // or git stage .
git commit -m ".gitignore fix"
git push
Jamie Flournoy的解决方案工作得很好. 这里有一个稍微改进的版本,以保持.htaccess :
# Ignore everything in this directory
*
# Except this file
!.gitignore
!.htaccess
使用此解决方案,您可以插入一个空的文件夹,例如 /log、 /tmp 或 /cache 并且文件夹将保持空白。
推荐文章
- 如何在Visual Studio中删除未推送的外向提交?
- Git在两个不同的文件之间的差异
- 我如何使用vimdiff来解决git合并冲突?
- 如何将更改提交到另一个预先存在的分支
- 为什么使用'git rm'来删除文件而不是'rm'?
- 我如何安装imagemagick与自制?
- 致命:git-write-tree:错误构建树
- Git克隆远程存储库的特定版本
- 如何在Python中获取当前执行文件的路径?
- git隐藏的意图用例是什么?
- 从远程Git存储库检索特定的提交
- 如何配置git bash命令行补全?
- 我如何迫使git拉覆盖每一个拉上的一切?
- 撤销“git add <dir>”?
- 是否可以在不先签出整个存储库的情况下进行稀疏签出?