我已经尝试了 .gitignore 的多种组合,但没有一个能满足我的需要。我有这棵树:
jobs/
jobs/projecta/config.xml
jobs/projecta/garbage
jobs/projecta/more/garbage
jobs/projectb/config.xml
jobs/projectb/garbage
jobs/projectb/more/garbage
垃圾是指任何其他文件。我只想提交 config.xml 文件,并忽略 jobs/ 中除它们之外的所有内容。所以我尝试:
/jobs/*
!/jobs/*/config.xml
这样,作业内的所有内容都会被忽略,包括 config.xml 文件。如果顺序相反,也会发生同样的情况。因此,我可以强制添加所有配置文件,并且将跟踪对它们的更改,但如果我在作业中添加新文件夹,它的 config.xml 将不会显示为未跟踪的文件,这样人们就可能忘记添加它们。
我已经尝试过 **,但我得到了同样的结果。
有任何想法吗?
谢谢!
The 我在评论中提到的问题 https://stackoverflow.com/questions/5533050/gitignore-exclude-folder-but-include-specific-subfolder实际上回答了这个场景;关键部分如下:
如果排除某个目录,Git 将永远不会查看该目录的内容。
这只是对这段代码的改写吉蒂诺尔 http://git-scm.com/docs/gitignore文档,重点是我的。
如果排除某个文件的父目录,则无法重新包含该文件。出于性能原因,Git 不会列出排除的目录,因此所包含文件上的任何模式都无效,无论它们是在哪里定义的。
你的模式/jobs/*
将忽略中的每个文件和文件夹jobs
。这意味着 git 甚至不会在这个被忽略的文件夹中查找以查看您的!/jobs/*/config.xml
模式匹配其中的文件。
反过来你必须明确地unignore子文件夹,然后reignore内容;之后你可以再次unignore your config.xml
文件。这可能看起来很愚蠢,但这就是 git 处理忽略的方式。
# Ignore everything in /jobs
/jobs/*
# Reinclude all folders in /jobs
!/jobs/*/
# Ignore everything in the subfolders of /jobs
/jobs/*/*
# Reinclude config.xml files in the first-level subfolders of /jobs
!/jobs/*/config.xml
这种模式会忽略一切,但config.xml
的第一级子文件夹中的文件jobs
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)