git 忽略文件 .gitignore

7 篇文章 0 订阅
1 篇文章 0 订阅

深入浅出 .gitignore

组成

  • # 开头的行是注释
  • 其他的都是模式
    • 不含 / 的是 shell glob 模式
    • 含 / 的是 非 shell glob 模式

glob 模式类似 shell 使用的简化版正则表达式

结论

  • * 匹配 0 到 n 个字符,但是不匹配 /

  • ** 匹配 0 到 n 个字符,匹配 /

  • ? 匹配任意单个字符

  • [abc ]匹配 a,b,c 任意单个字符

  • [a-9]匹配 0 到 9 简任意单个字符

  • ! 表示取反

  • 非斜杠结尾匹配文件和目录(特殊的文件) *xx 匹配 fxx 和 dxx/

  • 斜杠结尾匹配目录(特殊的文件) *xx/ 匹配 dxx/

  • 非斜杠开头表示递归(匹配顶层还匹递归配子目录) *xx 匹配 fxx, /fxx, /a/fxx, /a/b/dxx/

  • 斜杠开头表示非递归(只匹配顶层目录) /*xx 匹配 /fxx, /dxx/

空行也是模式但不匹配任何东西.
匹配的对象是文件路径,是字符串.
递归表示尝试匹配子目录.

陷阱

一个仓库结构如下
.
├── foo
│   ├── bar
│   │   ├── file1
│   │   └── file2
│   ├── barfile1
│   └── barfile2
├── foofile1
└── foofile2

写法一

# .gitignore
# 错误的,没有排除了/foo/bar
/*
!/foo/bar

没有跟踪到 /foo/bar 目录,所有的文件都被忽略/排除了

haha@st ~/dir $ git st -s
haha@st ~/dir $

写法二

# .gitignore
# 正确的,排除了/foo/bar
/*
!/foo
/foo/*
!/foo/bar

跟踪到 /foo/bar 目录

haha@st ~/dir $ git st -s
?? foo/
haha@st ~/dir $ git st -s ./foo/bar/
?? foo/bar/file1
?? foo/bar/file2

分析

写法一

  • /* 等价于三行 /foofile1 /foofile2 /foo/ ,这里只有三项, foo 是目录并没有递归下去(陷阱),据说出于性能考虑
  • !/foo/bar 中没有匹配上面三相中的任意一项

这里的说的递归是指在设计 gitignore 文件的行为的时候,匹配了目录后没有采用继续展开的策略.和前面说的文件路径模式匹配中的递归不是一个东西.试想如果像 Linux 内核那样的大项目,每次匹配到目录都递归,会多出多少计算量.但是,不递归的结果就是写的人要多写,具体见下面.

写法二

  • /* 等价于三行 /foofile1 /foofile2 /foo/
  • !/foo/foo/ 被重新跟踪了
  • /foo/* 等价于 /foo/barfile1 /foo/barfile2 /foo/bar/
  • !/foo/bar/foo/bar/ 被重新跟踪了

采用不递归的策略的后果,要手动层层展开(/* , /foo/*),跟踪每一个路径片段(!/foo , !/foo/bar).

gitignore 描述的对象是文件,具体点说模式匹配的对象是文件(正常的文件和目录这种特殊的文件),不是目录,不会递归目录.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值