在 tortoisegit 执行 commit 会跳过暂存区直接提交到仓库中吗?

本文探讨了TortoiseGit在执行commit操作时的工作流程,揭示了其是否跳过暂存区直接提交到仓库的真相。通过实验观察和ProcessMonitor追踪,发现TortoiseGit在提交时仍遵循git的标准流程,先将文件添加到暂存区,再提交到仓库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在 tortoisegit 执行 commit 会跳过暂存区直接提交到仓库中吗?

缘起

之前与同事交流 git 时,简单介绍了 git shelltortoisegit (戏称 小乌龟tortoisesvn 操作极其相似)。

tortoisegit 的命令基本上与 git bash 中的命令一一对应。在 git bash 中提交变更到本地仓库需要先 git add 添加到暂存区,再通过 git commit 命令提交到仓库,但是在 tortoisegit 中可以使用 commit 命令 ”直接“ 提交到仓库。到底会不会经过暂存区呢? 我的理解是:会先添加到暂存区,然后再提交到仓库。到底是不是这样的呢?还是通过实验来观察。

小知识

默认,tortoisegit 会尽量使用 libgit2 来实现一系列的 git 操作。但是 libgit2 还有一些功能没实现,我想这就是为什么我们在安装 tortoisegit 的时候,会要求我们指定 git bash 的路径。

tortoisegit 配置
tortoisegit 配置

如果我们不希望使用 libgit2 而是完全使用 git.exe 来实现底层操作,我们可以在 tortoisegit 中禁用 UseLibgit2

禁用 UseLibgit2
禁用 UseLibgit2

关于 tortoisegit 的各项设置请参考 tortoisegit 官方手册

验证

做好设置后,我们可以开始验证了。

使用 process monitor 追踪 tortoisegit 的整个提交过程。查看执行了哪些 git 命令。

具体过程请参考下面的屏幕录像。

关键调用截图如下:

git-commit-command-details
git-commit-command-details

我们主要关注的是如下两条命令:

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

参考资料

https://git-scm.com/docs/git-update-index

https://stackoverflow.com/questions/38585812/what-is-the-difference-between-git-add-and-git-update-index

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值