- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
所以,这个问题我遇到过几次。在一轮更改中,我删除了 functionA()
并在同一位置添加了 functionB()
。当我运行 diff
时,我最终得到了一组可怕的困惑更改,它尝试在它们的公共(public)括号上匹配两个函数,而不是将所有 functionA
显示为删除所有 functionB
作为添加。举个简单的例子:
int functionA(int a, bool b)
{
int c;
bool d;
if (a == b)
{
//do stuff
}
//do more stuff
}
替换为
void functionB()
{
// do different stuff
for (int x=0; x<10; x++)
{
//do more different stuff
}
//do even more different stuff
}
差异可能产生
-int functionA(int a, bool b)
+void functionB()
{
- int c;
- bool d;
- if (a == b)
+ // do different stuff
+ for (int x=0; x<10; x++)
{
- //do stuff
+ //do more different stuff
}
- //do more stuff
+ //do even more different stuff
}
这是无用且难以阅读的,因为除了大括号之外真的没有共同点。它甚至会跳过不对齐的大括号,直到找到对齐的大括号为止,这很常见。在我现在看到的一个案例中,我删除了 7 个连续的函数并添加了 3 个,它们以更易于阅读/维护的方式做大致相同的事情。 diff 算法通过所有 7 个删除的函数以分散的方式分配添加,造成不可读和困惑的困惑。
有什么方法可以调整 git diff 以忽略唯一的共同点是大括号的情况吗?
如果重要的话,我的系统目前有 git 1.9.0 和 diff (GNU difftools) 2.8.1我标记 C++ 是因为我工作的系统是(主要是 C 风格的)C++,但这应该适用于许多其他语言。
在寻找现有问题时,我能找到的最接近的是 What is git diff --patience
for?但是,这对我的差异影响很小。 (它是不同的,但不是明显更清楚)
我还在 git diff 手册页中看到 --break-rewrites 选项,它可以满足我的要求,但仅限于文件级别,而不是函数级别。
如果没有别的,我想我可以尝试在未来养成一个习惯,在我希望差异在一个 block 中显示添加的情况下,将新逻辑放在文件的任何删除部分完全不同的部分,但我更愿意将相关逻辑放在一起。
最佳答案
Git 目前1 提供四种 diff 算法,称为 myers
(默认)、minimal
、patience
和 直方图
。最后一个是对 patience
的轻微调整。不过,这些都在 Git 版本 1.9.0 中。如果它们都不符合您的要求,您可以告诉 Git 使用外部 diff。参见 the "Generating diff text" section of the gitattributes
documentation (引用主要的 git 文档)以获取详细信息。这有点复杂,但总而言之,您使用 gitattributes
强制 Git 运行外部差异程序,并且您通过编写脚本(通常是 sh)定义外部差异程序/bash) 并在您的全局或每个存储库设置中配置它。
1从 2.8.x 版开始; 2.9 快出来了,没有任何新的。
关于c++ - 完全替换功能时是否有可能获得清晰的 git diff?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37685266/
我在我们的系统中使用了多种不同的查询,我们想要获取分页的“总”记录。 我所遵循的所有地方都遵循这种结构 - var query1 = "select SQL_CALC_FOUND_ROWS ...."
我是 diff 的新手。我过去用过它。但我想知道,是否可以使用 diff 来跟踪希伯来语中两个文件之间的差异?我想比较具有元音点和重音符号的圣经希伯来文文件。 最佳答案 我不知道有任何“差异”(文件比
在Word中,有一个选项可以比较两个文档并找出两个文档之间的差异。我正在寻找一个类似的功能来比较两个Powerpoint文档。理想情况下,它将列出不同的单个幻灯片,每个幻灯片之间版本之间的差异以及进行
Bizzaro-Diff!!! 有没有办法做一个只显示一组文件中相同部分的 bizzaro/inverse-diff? (即远超过 three files ) 奇怪的问题,我知道...但我正在将某人的
我将 git 与默认的 Ubuntu 12.04 软件包一起使用: git --version git version 1.7.9.5 我找不到任何可以让 git diff 打开外部差异工具的机制,它
这是我的树 ├── test │ ├── dir1 │ └── dir2 │ ├── file │ └── file2 └── test2 └── dir2
我在 source forge ( cocoa.diff ) 上找到了这个补丁,这意味着我可以使用 cocoa.diff 文件进行补丁。但是,我似乎无法弄清楚如何使用 .diff 文件。 谢谢你的帮助
我修改了某个文件的第 494 行,并使用 cvs diff -u4 来查看我修改的内容,cvs 输出如下内容: @@ -490,9 +490,9 @@ if (!(hPtr->hSta
我需要知道这两个补丁是否有效相同。 我有一个旧补丁文件和使用 unix diff 命令创建的新补丁文件。由于补丁创建时的时间戳,只是比较补丁会报告差异。 有没有办法(有差异?)可以可靠地告诉我这两个补
我有这样的东西 src/sim/simulate.cc 41d40 public: > 61,62c60,61 a.patch 用于创建补丁文件,尽管也可能会抛出一些其他开关(-N?)
我想知道是否有工具可以显示与 debian 打包相关的补丁中使用的 *.diff 文件。我需要从该工具中获得的是它可以只读取 diff 文件并显示随更改的行更改的实际文件,就像 kdiff 或 mel
主要有3个git diff版本: git diff - difference between WORKING DIRECTORY & STAGE git diff --staged - differe
根据 Ender 的 Applied Econometric Time Series ,变量 y 的二阶差分定义为: Pandas 提供了 diff 函数,它接收“periods”作为参数。尽管如此,
这是我的差异的开始部分。 #!/usr/bin/env python import fileinput import difflib import subprocess import sys # fo
有没有办法在 svn diff 或任何其他工具(基于 linux)到 仅显示空格/制表符更改 ?. 目的,我不希望 checkin 这些差异。如果工具可以捕获这些差异,我可以在 checkin 之前将
我正在尝试比较忽略回车符的文件 - diff -b 在任何其他 unix 上的表现令人钦佩。但是在这个 AIX 5.3 机器上: tst1:tst2$ od -c testfile 00000
这个问题已经有答案了: What does the “@@…@@” meta line with at signs in svn diff or git diff mean? (3 个回答) 已关闭
我在使用 git diff --word-diff 时遇到了问题。问题是当 diff 获取没有换行符的文件(单行文件)时,它会逐行区分。我想逐字区分。 以下是当我在没有换行符的情况下比较文件时发生的情
这个问题在这里已经有了答案: Highlight changed lines and changed bytes in each changed line (12 个答案) 关闭 7 年前。 给定一
我正在尝试使用两个大文件夹(〜7GB)创建一个补丁。 这是我的做法: $ diff -Naurbw . ../other-folder > file.patch 但可能由于文件大小而导致未创建补丁并给
我是一名优秀的程序员,十分优秀!