Svn diff输出文件中的所有行

时间:2011-11-02 16:16:27

标签: svn shell unix merge diff

我一直在寻找一段时间,仍然无法找到解决这个问题的简单方法。我想在文件的两个修订版之间生成差异,但是我希望输出显示我文件的所有行。

顺便说一句,我使用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'似乎是我能得到的最接近的答案,但理想情况下我想要一个带有'+'和' - '的圆柱文件显示添加/删除的行

提前感谢您的帮助! =)

2 个答案:

答案 0 :(得分:16)

是的,您可以使用外部diff来完成此操作。我通常按​​照这样的命令来做:

svn diff --diff-cmd diff -x "-U30" 

此处,-U30是统一的上下文大小。你应该把它做得足够大,以包含文件中的所有行。例如,如果您的最长文件有1000行,则使用-U1000

答案 1 :(得分:6)

也许以下内容接近您想要的内容:

首先,创建一个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:

进行差异
svn diff --diff-cmd /usr/local/bin/mydiff

如果您想更加密切地自定义diff输出,只需修改mydiff脚本。