.gitignore
文件忽略目录中文件的正确语法是什么?
是不是
config/databases.yml
cache/*
log/*
data/sql/*
lib/filter/base/*
lib/form/base/*
lib/model/map/*
lib/model/om/*
或
/config/databases.yml
/cache/*
/log/*
/data/sql/*
/lib/filter/base/*
/lib/form/base/*
/lib/model/map/*
/lib/model/om/*
答案 0 :(得分:359)
模式格式
空行不匹配任何文件,因此它可以作为分隔符以便于阅读。
以#
开头的行作为评论。
可选前缀!
否定模式;之前模式排除的任何匹配文件将再次包含在内。如果否定模式匹配,则将覆盖较低优先级模式源。
如果模式以斜杠结尾,则为了以下描述的目的将其删除,但它只会找到与目录的匹配项。换句话说,foo/
将匹配目录foo
和其下的路径,但不匹配常规文件或符号链接foo
(这与pathspec工作方式一致)一般在git)。
如果模式不包含斜杠/
,git会将其视为shell glob模式,并检查相对于.gitignore
文件位置的路径名是否匹配(相对于如果不是来自.gitignore
文件,则工作树的顶层。
否则,git将模式视为适合fnmatch(3)
使用FNM_PATHNAME
标记的shell glob:模式中的通配符与路径名中的/
不匹配。例如,Documentation/*.html
匹配Documentation/git.html
但不匹配Documentation/ppc/ppc.html
或tools/perf/Documentation/perf.html
。
前导斜杠与路径名的开头匹配。例如,/*.c
匹配cat-file.c
但不匹配mozilla-sha1/sha1.c
。
<强> git help gitignore
强>
或
的 man gitignore
强>
答案 1 :(得分:176)
这将是前者。也可以通过扩展而不是文件夹结构。
即。我的例子C#development忽略文件:
#OS junk files
[Tt]humbs.db
*.DS_Store
#Visual Studio files
*.[Oo]bj
*.user
*.aps
*.pch
*.vspscc
*.vssscc
*_i.c
*_p.c
*.ncb
*.suo
*.tlb
*.tlh
*.bak
*.[Cc]ache
*.ilk
*.log
*.lib
*.sbr
*.sdf
ipch/
obj/
[Bb]in
[Dd]ebug*/
[Rr]elease*/
Ankh.NoLoad
#Tooling
_ReSharper*/
*.resharper
[Tt]est[Rr]esult*
#Project files
[Bb]uild/
#Subversion files
.svn
# Office Temp Files
~$*
<强>更新强>
我想我会从下面的评论中提供更新。虽然没有直接回答OP的问题,但请参阅以下内容以获取.gitignore
语法的更多示例。
社区维基(不断更新):
.gitignore for Visual Studio Projects and Solutions
可以在这里找到更多具有特定语言用法的例子(感谢Chris McKnight的评论):
答案 2 :(得分:125)
包含斜杠的路径被认为是相对于包含.gitignore文件的目录 - 通常是存储库的顶层,但您也可以将它们放在子目录中。
所以,因为在你提供的所有例子中,路径都包含斜杠,两个版本是相同的。只有当路径中的不是时,才需要设置前导斜杠。例如,要仅在存储库的顶级忽略foo,请使用/foo
。只需编写foo
就可以忽略存储库中任何名为foo的内容。
您的通配符也是多余的。如果要忽略整个目录,只需将其命名为:
lib/model/om
使用通配符的唯一理由是,如果您打算随后忽略目录中的某些内容:
lib/model/om/* # ignore everything in the directory
!lib/model/om/foo # except foo
答案 3 :(得分:76)
前导斜杠表示ignore条目仅对.gitignore文件所在的目录有效。指定*.o
会忽略此目录和所有子目录中的所有.o文件,而/*.o
只会忽略该目录中的那些文件,而/foo/*.o
只会忽略它们/ foo / *的.o。
答案 4 :(得分:30)
如果要将.gitignore文件放在顶层并使其适用于下面的任何文件夹,请使用/**/
。
E.g。忽略*.map
文件夹中的所有/src/main/
个文件和子文件夹使用:
/src/main/**/*.map
答案 5 :(得分:28)
问题中的两个例子实际上是非常糟糕的例子,可能导致数据丢失!
我的建议:永远不要将/*
附加到.gitignore文件中的目录,除非你有充分的理由!
一个很好的理由是例如Jefromi写的:&#34;如果你打算随后忽略目录中的某些内容&#34; 。
为什么不应该这样做的原因是将/*
附加到目录上一方面以正确忽略目录的所有内容的方式工作,但另一方面它有危险的副作用:
如果您在存储库中执行git stash -u
(临时存储已跟踪和未跟踪的文件)或git clean -df
(删除未跟踪但保留被忽略的文件),则所有被忽略的目录都附加{{1将不可逆转地删除!
我必须以艰难的方式学习这一点。我团队中的某个人将/*
附加到我们.gitignore中的某些目录中。随着时间的推移,某些目录会突然消失。我们的应用程序需要具有千兆字节本地数据的目录。没有人可以解释它,我总是重新下载所有数据。过了一会儿,我得到了一个可能与/*
有关的想法。有一天,我想清理我的本地仓库(同时保留被忽略的文件),我正在使用git stash
,我的数据又消失了。这次我受够了并调查了这个问题。我终于想到原因是附加git clean -df
。
我认为可以通过/*
忽略目录的所有内容但不忽略目录本身的事实来解释它。因此,当事情被删除时,它既不被视为被跟踪也不被忽略。尽管directory/*
和git status
给出的图片略有不同。
以下是重现行为的方法。我目前正在使用Git 2.8.4。
将在本地git存储库中创建一个名为git status --ignored
的目录,其中包含一个虚拟文件(localdata/
),将important.dat
放入{{1}将忽略内容文件。当现在执行两个提到的git命令之一时,该目录将(意外地)丢失。
/localdata/*
如果你在这里.gitignore
,你会得到:
mkdir test
cd test
git init
echo "/localdata/*" >.gitignore
git add .gitignore
git commit -m "Add .gitignore."
mkdir localdata
echo "Important data" >localdata/important.dat
touch untracked-file
现在要么
git status --ignored
或
On branch master
Untracked files:
(use "git add <file>..." to include in what will be committed)
untracked-file
Ignored files:
(use "git add -f <file>..." to include in what will be committed)
localdata/
在这两种情况下,据称被忽略的目录git stash -u
git stash pop
都将消失!
不确定这是否可以被视为错误,但我想它至少是一个无人需要的功能。
我会向git开发列表报告,看看他们对此有何看法。
答案 6 :(得分:14)
第一个。这些文件路径与.gitignore文件的位置相对。
答案 7 :(得分:14)
这将是:
config/databases.yml
cache
log
data/sql
lib/filter/base
lib/form/base
lib/model/map
lib/model/om
或甚至可能:
config/databases.yml
cache
log
data/sql
lib/*/base
lib/model/map
lib/model/om
如果filter
和form
是lib中唯一具有需要忽略的base
子目录的目录(请参阅它作为您可以执行的操作的示例)星号)。
答案 8 :(得分:4)
我正在维护基于GUI和CLI的服务,使您可以在https://www.gitignore.io轻松生成.gitignore
个模板。
您可以在搜索字段中键入所需的模板,也可以安装命令行别名并运行
$ gi swift,osx
答案 9 :(得分:0)
示例 .gitignore 文件对于Android Studio项目可能如下所示
# built application files
*.apk
*.ap_
# files for the dex VM
*.dex
# Java class files
*.class
# generated files
bin/
gen/
# Local configuration file (sdk path, etc)
local.properties
#Eclipse
*.pydevproject
.project
.metadata
bin/**
tmp/**
tmp/**/*
*.tmp
*.bak
*.swp
*~.nib
local.properties
.classpath
.settings/
.loadpath
YourProjetcName/.gradle/
YourProjetcName/app/build/
*/YourProjetcName/.gradle/
*/YourProjetcName/app/build/
# External tool builders
.externalToolBuilders/
# Locally stored "Eclipse launch configurations"
*.launch
# CDT-specific
.cproject
# PDT-specific
.buildpath
# Proguard folder generated by Eclipse
proguard/
# Intellij project files
*.iml
*.ipr
*.iws
.idea/
/build
build/
*/build/
*/*/build/
*/*/*/build/
*.bin
*.lock
YourProjetcName/app/build/
.gradle
/local.properties
/.idea/workspace.xml
/.idea/libraries
.DS_Store
.gradle/
app/build/
*app/build/
# Local configuration file (sdk path, etc)
local.properties
/YourProjetcName/build/intermediates/lint-cache/api-versions-6-23.1.bin
appcompat_v7_23_1_1.xml
projectFilesBackup
build.gradle
YourProjetcName.iml
YourProjetcName.iml
gradlew
gradlew.bat
local.properties
settings.gradle
.gradle
.idea
android
build
gradle