- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试解决大型目录结构上的 gitignore 问题,但为了简化我的问题,我将其简化为以下内容。
我在一个全新的 git 存储库中有以下两个文件(foo、bar)的目录结构(到目前为止没有提交):
a/b/c/foo
a/b/c/bar
显然,'git status -u' 显示:
# Untracked files:
...
# a/b/c/bar
# a/b/c/foo
我想做的是创建一个 .gitignore 文件,忽略 a/b/c 中的所有内容,但不忽略文件“foo”。
如果我这样创建一个 .gitignore :
c/
然后 'git status -u' 显示 foo 和 bar 都被忽略:
# Untracked files:
...
# .gitignore
这是我所期望的。
现在,如果我为 foo 添加排除规则,则:
c/
!foo
根据 gitignore 联机帮助页,我希望它能工作。但它没有——它仍然忽略了 foo:
# Untracked files:
...
# .gitignore
这也行不通:
c/
!a/b/c/foo
这也不是:
c/*
!foo
给予:
# Untracked files:
...
# .gitignore
# a/b/c/bar
# a/b/c/foo
在那种情况下,虽然 foo 不再被忽略,但 bar 也不会被忽略。
.gitignore 中规则的顺序似乎也不重要。
这也不符合我的预期:
a/b/c/
!a/b/c/foo
那个忽略了 foo 和 bar。
一种可行的情况是,如果我创建文件 a/b/c/.gitignore 并将其放入其中:
*
!foo
但这样做的问题是,最终 a/b/c 下会有其他子目录,我不想将一个单独的 .gitignore 放入每个子目录中 - 我希望创建“基于项目的” ' .gitignore 文件可以位于每个项目的顶级目录中,并覆盖所有“标准”子目录结构。
这似乎也是等价的:
a/b/c/*
!a/b/c/foo
这可能是我能实现的最接近“工作”的东西,但是需要说明完整的相对路径和明确的异常(exception)情况,如果我有很多名为“foo”的文件,这会很痛苦在子目录树的不同级别。
无论如何,要么我不太明白排除规则是如何工作的,要么当目录(而不是通配符)被忽略时它们根本不起作用 - 通过以/结尾的规则
任何人都可以阐明这一点吗?
有没有办法让 gitignore 使用像正则表达式这样的合理的东西,而不是这种笨拙的基于 shell 的语法?
我在 Cygwin/bash3 上使用 git-1.6.6.1 并在 Ubuntu/bash3 上使用 git-1.7.1 并观察它。
最佳答案
/a/b/c/*!foo
似乎对我有用(Linux 上的 git 1.7.0.4)。 *
很重要,否则您将忽略目录本身(因此 git 不会查看内部)而不是目录中的文件(允许排除)。
将排除视为“但不是这个”而不是“但包括这个” - “忽略这个目录(/a/b/c/
)但不是这个(foo
)"没有多大意义; “忽略此目录 (/a/b/c/*
) 中的所有文件,但不忽略此目录 (foo
)”。引用手册页:
An optional prefix ! which negates the pattern; any matching file excluded by a previous pattern will become included again.
即,文件 必须已经被排除,才能再次被包含。希望能有所启发。
关于git - .gitignore 排除规则实际上是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3001888/
我有一个名为“members”的数据库表。分配给成员的是一个职位。 职位 来自部门。我有 Departments,然后是那些中的 Sub-Departments 和 Sub-Departments 中
我正在尝试为 Solr 搜索应用过滤器标记 Tagging_and_excluding_Filters . 挑战在于同时应用多个标记(对于单个页面上的多个选择选项)。例如 q=mainquery&fq
我知道这个问题已经被问过很多次了,我已经尝试了所有建议,并阅读了有关不同选择器等的所有内容,但没有任何对我有用 给出以下 HTML 片段: link
是否有直接的 LINQ 语法来查找集合 B 中不存在的集合 A 的成员?在 SQL 我会写这个 SELECT A.* FROM A LEFT JOIN B ON A.ID = B.ID WHERE B
我试图排除并在现有xpath中包括以下xpath,但不太确定如何做到这一点 //exclude -> //*[@id="ires"]/ol/li[6]/div/a[1]/img //include
我有 30 个站点,我需要在其中 24 个站点上回显某些内容。我怎样才能排除其他人?该代码不起作用,因为我认为它的逻辑是假的:) $currentsite = get_bloginfo('wpurl'
我需要对目标文件夹进行检查,并检查文件是否来自今天,并且超过5kb 下面的命令根据使用今天的日期存在的文件来提供bool值,但是我还要添加-gt5kb之类的排除项 我尝试使用-Exlcude,但不确定
我编入索引的Elasticsearch文档包含许多字段。我一直在使用match_all查询来获取结果。我想从match_all中排除一些字段,这可能吗? 最佳答案 在Elasticsearch中,您可
我正在为我的 DAO 编写一些测试,因为很多测试使用保存到我的数据库中的测试对象,所以我使用注释 @Before 和 @Before 创建了 setup() 和teardown() 方法@After
我编写了一个程序来解决以下问题: Implement a diffusion limited aggregation simulation on a toroid plane where seeds
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
很多时候我必须运行这个查询: select * from users where name is not null and name != '' 有没有更好的方法来做到这一点。我需要更多的性能,任何建
如果检测到某个操作系统,是否有一种简单的方法可以排除某些代码? 我设计了一个运行良好的网站(它是一个 sidescroller),当使用滚轮(向上/向下)时,它会左右滚动。但是,如果您使用的是 Mac
我应该如何排除“IN”子句中的值? $Graduates = "45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,6
很明显,如果一个 Mysql 表的全文索引包含一个出现在 50% 的数据行中的关键字,该关键字将被匹配查询忽略 因此,如果我有一个包含 50 个条目的全文索引“content”的表其中 27 个条目在
我有下面的循环。 我需要提取所有不包含字母 p 的名称 (lskey),但我的尝试不起作用。 for(var i = 0; i "); } } 如果有人能回答,我将不胜感激。 最佳答案 如此接
我正在尝试查找 FTP 服务器上根目录的总大小。但是,我无权访问根目录中的其中一个目录。 我想用这个函数对根目录的大小求和: size = 0 for filename in ftp.nlst("."
我有以下正则表达式来匹配 html 链接: 有点效果。除了不是真的。因为它在 编辑: 这将使它只抓取引号而不是 之后的所有内容 最佳答案 我认为您的正则表达式没有按照您的意愿行事。 这会非贪婪地捕
我在提出异常方面遇到困难,例如: import csv o = open('/home/foo/dummy.csv', 'r') # Empty file! reader = csv.reader(o
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!