Skip to content

Commit

Permalink
doc: update git.md jaywcjlove#109
Browse files Browse the repository at this point in the history
  • Loading branch information
jaywcjlove committed Nov 17, 2022
1 parent 74afc52 commit 1d1f877
Showing 1 changed file with 49 additions and 40 deletions.
89 changes: 49 additions & 40 deletions docs/git.md
Original file line number Diff line number Diff line change
Expand Up @@ -236,6 +236,55 @@ $ git diff branchB...branchA
$ git show [SHA]
```

### 忽略文件
<!--rehype:wrap-class=row-span-4-->

文件 `.gitignore` 指定了 `Git` 应该忽略的 **未跟踪的** 文件

:- | :-
:- | :-
行首 `#` | 全行注释,不支持行尾类注释 _(转义 `\#`)_
行首 **`!`** | 否定模式 _(转义 `\!`)_
`**` | 匹配任意路径
`*` | 匹配任意多个字符
`?` | 匹配任意一个字符
`doc/**` | 匹配 `doc` 文件夹下的全部内容
`doc/**/a` | 匹配任意深度路径下的 `a` 文件或文件夹
`/` | 表示路径分隔符,不区分操作系统
`/` 结尾 | 仅会匹配文件夹,否则会匹配文件和文件夹
空行 | 不匹配任何文件
行尾空格 | 默认被忽略,可使用`\`进行转义
行首空格 | 被正常处理,不会被忽略

当前 `.gitignore` 文件定义规则的优先级高于上级路径 `.gitignore` 定义规则的优先级;后定义的规则优先级高于前面定义规则的优先级。

```gitignore showLineNumbers
# 忽略当前目录logs文件夹下的全部内容
/logs/
/logs/*
/logs/**
# 上述几条规则等效
# 忽略 Mac 系统文件,包括任意子路径下的同名文件(夹)
.DS_store
# 忽略 node_modules 文件夹,包括任意子路径下的同名文件夹
node_modules/
# 忽略任意子路径下build、target文件夹,
# 但不忽略src/main、src/test下的build、target文件夹
build/
!**/src/main/**/build/
!**/src/test/**/build/
target/
!**/src/main/**/target/
!**/src/test/**/target/
# 使用 ! 重新包含指定文件(夹)
!logs/.gitkeep
```
<!--rehype:className=wrap-text-->

### 重构文件名

```bash
Expand Down Expand Up @@ -339,46 +388,6 @@ $ git mv [existing-path] [new-path]
$ git log --stat -M
```

### 忽略文件

`.gitignore` 文件指定了 Git 应该忽略的 **未跟踪的** 文件。

- 当面 `.gitignore` 文件定义规则的优先级高于上级路径 `.gitignore` 定义规则的优先级;后定义的规则优先级高于前面定义规则的优先级。
- 空行不匹配任何文件,可用于增加文件可读性。
-`#`开头的行为全行注释,不支持行尾类注释。如果希望匹配以`#`开头的文件或文件夹,可前缀`\`进行转义。
- 行尾空格默认被忽略,除非前缀`\`进行转义。行首空格会被正常处理,不会被忽略。
- 行首`!`表示否定模式。如果匹配的文件被其他低优先级规则忽略,则会被重新跟踪。如果希望匹配以`!`开头的文件或文件夹,可前缀`\`进行转义。
- 统一用`/`表示路径分隔符,不区分操作系统。
- 如果规则包含路径分隔符`/`,则仅在指定的文件夹这一层级进行文件搜索匹配,不会递归搜索子目录;如果规则不含路径分隔符,则会在当前文件夹内进行递归搜索匹配。
- 如果规则以路径分隔符`/`结尾,则仅会匹配文件夹;否则会匹配文件和文件夹。
- 通配符不能匹配`/``*`匹配任意个数字符,`?`匹配任意一个字符,更多细节参见[glob(7)](https://man7.org/linux/man-pages/man7/glob.7.html)
- 双星`**`匹配任意路径。以`**`开头表示在全部文件夹下去匹配,以`/**`结尾表示匹配指定文件夹下的全部内容,中间`**`匹配任意深度路径。

```gitignore showLineNumbers
# 忽略当前目录logs文件夹下的全部内容
/logs/
/logs/*
/logs/**
# 上述几条规则等效
# 忽略 Mac 系统文件,包括任意子路径下的同名文件(夹)
.DS_store
# 忽略 node_modules 文件夹,包括任意子路径下的同名文件夹
node_modules/
# 忽略任意子路径下build、target文件夹,但不忽略src/main、src/test下的build、target文件夹
build/
!**/src/main/**/build/
!**/src/test/**/build/
target/
!**/src/main/**/target/
!**/src/test/**/target/
# 使用 ! 重新包含指定文件(夹)
!logs/.gitkeep
```

### git 配置 ssh 代理

```bash
Expand Down

0 comments on commit 1d1f877

Please sign in to comment.