我一直在寻找一段时间,仍然无法找到解决这个问题的简单方法。我想在文件的两个修订版之间产生差异,但我希望输出显示我的文件的所有行。
顺便说一句,我使用svn 1.6.17在AIX 5.3上。
示例:比较我的文件“test_file”的版本21和22之间的差异
% svn cat -r21 test_file
My Test File
line 1
line 2
line 3
line 4
line 5
line 6
line 7
line 8
line 9
% svn cat -r22 test_file
My Test File
line 1
line 2
line 3
line 4
line 5
line 6
line 7
line 8
line 9
added after 1
added after 2
added after 3
% svn diff -r21:22 test_file
Index: test_file
===================================================================
--- test_file (revision 21)
+++ test_file (revision 22)
@@ -9,3 +9,7 @@
line 7
line 8
line 9
+
+added after 1
+added after 2
+added after 3
现在这个输出显示了两个版本中的差异,但并不是所有文件的行都存在,它只显示前三个。
所以我的问题是如何在输出中获得这些线?
是否有某种svn diff配置设置?我知道我可以使用外部差异工具svn,但哪一个给我输出我想要的?我想尝试避免安装任何差异工具,因为我在公司网络上。
补充一点:到目前为止,生成2列的'sdiff'似乎是我能得到的最接近的答案,但理想情况下我想要一个带有'+'和' - '的圆柱状文件显示添加/删除的行
在此先感谢您的帮助! =)
也许以下内容接近你想要的:
首先,创建一个diff脚本,它将使用从svn收到的args:
#!/bin/sh
# file : /usr/local/bin/mydiff
# assumes less that 10,000 lines per file
/usr/bin/diff -U10000 $6 $7
然后使用svn进行diff:
svn diff --diff-cmd /usr/local/bin/mydiff
如果您想更加紧密地定制diff输出,您只需要修改mydiff
脚本。
是的,你可以使用外部diff
来实现这一目标。我通常通过这样的命令来做:
svn diff --diff-cmd diff -x "-U30"
在这里,-U30
是统一的上下文大小。你应该把它做得足够大,以包含文件中的所有行。例如,如果最长的文件有1000行,则使用-U1000
。