缘起
之前与同事交流 git
时,简单介绍了 git shell
和 tortoisegit
(戏称 小乌龟
,tortoisesvn
操作极其相似)。
tortoisegit
的命令基本上与 git bash
中的命令一一对应。在 git bash
中提交变更到本地仓库需要先 git add
添加到暂存区,再通过 git commit
命令提交到仓库,但是在 tortoisegit
中可以使用 commit
命令 ”直接“ 提交到仓库。到底会不会经过暂存区呢? 我的理解是:会先添加到暂存区,然后再提交到仓库。到底是不是这样的呢?还是通过实验来观察。
小知识
默认,tortoisegit
会尽量使用 libgit2 来实现一系列的 git
操作。但是 libgit2
还有一些功能没实现,我想这就是为什么我们在安装 tortoisegit
的时候,会要求我们指定 git bash
的路径。
如果我们不希望使用 libgit2
而是完全使用 git.exe
来实现底层操作,我们可以在 tortoisegit
中禁用 UseLibgit2
。
关于 tortoisegit
的各项设置请参考 tortoisegit 官方手册。
验证
做好设置后,我们可以开始验证了。
使用 process monitor
追踪 tortoisegit
的整个提交过程。查看执行了哪些 git
命令。
具体过程请参考下面的屏幕录像。
关键调用截图如下:
我们主要关注的是如下两条命令:
git.exe update-index -- "a"
git.exe commit -F "C:\Users\BCN\AppData\Local\Temp\TortoiseGit\Pat2E66.tmp"
其中,git update-index -- "a"
与 git add -- "a"
效果一样,都是把 文件 a
添加到暂存区。
git commit -F
表示提交,而且从文件中提取提交信息。
看来 ,在 tortoisegit
中提交的时候,也需要经过暂存区。
为什么每个指令都执行了两遍呢?我猜是因为 C:\Program Files\Git\bin\git.exe
不做实际工作。把工作都转交给相应的进程。我机器上是 C:\Program Files\Git\mingw64\bin\git.exe
。