我的问题类似于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)(文本)编辑器(至少是统一差异),这样:删除大块(或整个黑客)的行,它会自动更新差异计数器 - 以便编辑的补丁文件仍然可以干净地应用于原始文件?
答案 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”模式启动:
然后您可以使用鼠标选择线条,但不能使用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菜单会引发通常的文件对话框,其中编辑后的文件可以在保存时重命名。
仍然,想知道是否有替代品......