默认的git差异行为是依次打开每个差异文件(等待上一个文件关闭后再打开下一个文件)。

我正在寻找一种方法来打开所有的文件一次-在BeyondCompare例如,这将打开所有的文件在选项卡内同一BC窗口。

这将使审查一组复杂的变更更加容易;在差异文件之间来回切换,忽略不重要的文件。


当前回答

meld有一个很好的特性,如果你在源代码控制下给它一个目录(Git、Mercurial、Subversion、Bazaar等),它会自动列出所有更改过的文件,你可以双击查看各个不同的文件。

在我看来,打字融合要容易得多。让它找出VCS,而不是配置VCS来启动meld。另外,无论你的项目使用什么VCS,你都可以使用相同的命令,如果你经常在它们之间切换,这是很棒的。

唯一的缺点是,meld扫描更改比从git/hg/svn传递更改要慢,尽管它是否慢到足以成为一个问题,这将取决于您如何使用它。

其他回答

对于那些有兴趣在Mac OS X和Araxis上使用git-diffall的人,我在github上分叉了git-diffall项目,并添加了一个包装Araxis合并命令的AppleScript。注意:这是Mac OS X的Araxis Merge附带的araxisgitdiff文件的一个稍微修改的克隆。

https://github.com/sorens/git-diffall

您可以使用gitk同时查看所有的差异

我写了一个powershell脚本,将复制两个工作树,并与DiffMerge进行比较。所以你可以这样做:

GitNdiff master~3 .

例如,比较三个签入前的主分支与当前工作树。

它又新又亮,可能满是虫子。一个缺点是,工作树中尚未添加的文件将被复制到两个工作树中。它也可能很慢。

http://github.com/fschwiet/GitNdiff

meld有一个很好的特性,如果你在源代码控制下给它一个目录(Git、Mercurial、Subversion、Bazaar等),它会自动列出所有更改过的文件,你可以双击查看各个不同的文件。

在我看来,打字融合要容易得多。让它找出VCS,而不是配置VCS来启动meld。另外,无论你的项目使用什么VCS,你都可以使用相同的命令,如果你经常在它们之间切换,这是很棒的。

唯一的缺点是,meld扫描更改比从git/hg/svn传递更改要慢,尽管它是否慢到足以成为一个问题,这将取决于您如何使用它。

Git meld => https://github.com/wmanley/git-meld是一个很棒的脚本,它将在一个窗口中打开所有文件的整齐差异。