默认的git差异行为是依次打开每个差异文件(等待上一个文件关闭后再打开下一个文件)。
我正在寻找一种方法来打开所有的文件一次-在BeyondCompare例如,这将打开所有的文件在选项卡内同一BC窗口。
这将使审查一组复杂的变更更加容易;在差异文件之间来回切换,忽略不重要的文件。
默认的git差异行为是依次打开每个差异文件(等待上一个文件关闭后再打开下一个文件)。
我正在寻找一种方法来打开所有的文件一次-在BeyondCompare例如,这将打开所有的文件在选项卡内同一BC窗口。
这将使审查一组复杂的变更更加容易;在差异文件之间来回切换,忽略不重要的文件。
当前回答
Diffuse也有VCS集成。它与大量其他VCS进行互操作,包括SVN、Mercurial、Bazaar……对于Git来说,如果部分更改(但不是全部更改)是阶段性的,它甚至会显示三个窗格。在冲突的情况下,甚至会有四个窗格。
使用
diffuse -m
在Git工作副本中。
要我说,这是十年来我见过的最好的视觉差异。(我也试过融合。)
其他回答
您可以使用gitk同时查看所有的差异
Git meld => https://github.com/wmanley/git-meld是一个很棒的脚本,它将在一个窗口中打开所有文件的整齐差异。
注意这里Araxis Merge有一个'-nowait'命令选项:
-nowait防止compare等待比较被关闭
也许这会返回一个立即退出码,可以工作,有人经历过吗?找不到类似的BeyondCompare选项…
下面使用meld和kdiff3
git difftool --dir-diff origin/branch1..origin/branch2
在您可以轻松浏览的窗口中打开所有文件。 可以在原点/分支名称的地方使用变更集吗
例如:git difftool——dir-diff origin/master..24604fb72f7e16ed44115fbd88b447779cc74bb1
如果你想要做的就是打开当前修改过的所有文件,试试下面的方法:
vi $(git status | sed -n '/.*modified: */s///p')
如果您正在提交“复杂的更改集”,您可能需要重新考虑您的工作流。git的一个非常好的特性是,它使开发人员可以轻松地将复杂的更改集简化为一系列简单的补丁。与其尝试编辑当前修改的所有文件,不如查看git add——patch,它将允许您有选择地分段块。