Diff-aware编辑器,可以处理补丁程序块编辑(包括删除行)?

时间:2013-07-18 17:41:58

标签: linux user-interface editor diff patch

我的问题类似于Interactive program to selectively exclude parts of a diff file - 但有些不同......

说我有以下“原始”文件:

$ cat test-orig.h 
int varA;
int varB;
int varC;
int varD;
int varE;

...并说我已将这些更改变成“新”文件:

$ cat test-newmodified.h 
int varA;
int varB;
int varC;
// a couple of lines
// of useless comments
int var_extra1;
int var_extra2;
int varD;
int varE;

然后两者之间的差异将是:

$ diff -Naur test-orig.h test-newmodified.h | tee test.patch
--- test-orig.h 2013-07-18 19:21:25.741027138 +0200
+++ test-newmodified.h  2013-07-18 19:21:19.916998200 +0200
@@ -1,5 +1,9 @@
 int varA;
 int varB;
 int varC;
+// a couple of lines
+// of useless comments
+int var_extra1;
+int var_extra2;
 int varD;
 int varE;

让我们说,我有一个如此获得的补丁文件,(有很多人),我想删除“无用评论的行”。从diff生成的补丁文件中删除整个块通常很容易 - 但如果我只想删除一些行,那么差异计数器(上面的@@ -1,5 +1,9 @@)也必须进行修改。比如说,如果在文件中删除了注释行,则diff将是:

$ diff -Naur test-orig.h test-newmodified-nc.h
--- test-orig.h 2013-07-18 19:21:25.741027138 +0200
+++ test-newmodified-nc.h   2013-07-18 19:26:30.898540270 +0200
@@ -1,5 +1,7 @@
 int varA;
 int varB;
 int varC;
+int var_extra1;
+int var_extra2;
 int varD;
 int varE;

...也就是说,带有评论的计数器@@ -1,5 +1,9 @@ - 现在变成了@@ -1,5 +1,7 @@,而没有评论。

如果我只是删除补丁test.patch中的注释行(并将该编辑保存为test-edit.patch),并且不更新计数器,那么我得到:

$ patch -p0 <test-edit.patch
patching file test-orig.h
patch: **** malformed patch at line 10:  

...而且这样的补丁没有得到应用。如果,我只是将+1,9更改为+1.7中的test-edit.patch,那么它就会适用:

$ patch -p0 <test-edit.patch
patching file test-orig.h

... test-orig.h按预期更改(没有注释行)。

因此,给定一个补丁文件,其中包含与文件相关的所有帅哥 - 是否有diff知道的(GUI)(文本)编辑器(至少是统一差异),这样:删除大块(或整个黑客)的行,它会自动更新差异计数器 - 以便编辑的补丁文件仍然可以干净地应用于原始文件?

1 个答案:

答案 0 :(得分:1)

好吧,我现在知道我至少可以使用emacs,这要归功于这个答案:#9740489 How to edit a diff/patch file cleanly ? Are there any patch file editors?

  

如果您在emacs中打开diff文件并将编辑器置于“diff”模式,您可以实际编辑补丁,它将以智能方式更新hunk标记

请注意,在我的系统(Ubuntu Lucid)上,sudo apt-get install emacs将在安装后使emacs命令最终符号链接到emacs23-x,它在自己的窗口中运行(不在终端中) )。所以我可以打电话:

$ emacs test.patch

...并且emacs将自动以“diff”模式启动:

emacs-diff

然后您可以使用鼠标选择线条,但不能使用Del / Backspace删除它们 - 您必须使用Ctrl-W剪切选区(请参阅In Emacs, how do I cut, paste, and copy a block of text? - Knowledge Base)。从屏幕截图中可以看出,标记会自动更新。另外,不要使用M-x diff进入“差异”模式(参见Comparing Files - GNU Emacs Manual;在我的机器上,Mx是Alt-X) - 然后它将开始询问“原始”和“新”输入文件路径对它们执行diff,这不是我们想要的(假设已经加载了补丁文件)。最后,GUI菜单具有文件/另存为(以及C-x C-w快捷方式) - 单击GUI菜单会引发通常的文件对话框,其中编辑后的文件可以在保存时重命名。

仍然,想知道是否有替代品......