场景是:
在其他机器上(相同的工作副本,但没有更改):
尝试修改不存在的文件。
在这种情况下,如何让svn diff生成可应用补丁程序,或者干净利落地应用svn diff生成的补丁程序?我不能承诺。我希望保留mergeinfo (因为明显的解决办法是将文件添加为全新的文件,而不连接到前一个文件)。
发布于 2008-11-26 05:41:33
使用subversion,您可以指定要使用的diff二进制文件,以及要传递给它的参数。参见svn diff上的the manual。
您可能希望从svn diff生成一个常规的补丁文件,因此您可能希望svn diff看起来像一个普通的diff。试试这个:
svn diff --diff-cmd /usr/bin/diff -x "-i -b" > mypatch
...
patch -p0 < mypatch
概念验证:
echo "newline" >> README.txt
svn diff --diff-cmd /usr/bin/diff -x "-i -b" > mypatch
cp README.txt README.txt.patched
svn revert README.txt
patch -p0 < mypatch
diff README.txt README.txt.patched
打补丁后,两个文件没有差别。
发布于 2016-04-27 05:06:58
如果你想在你的补丁中去掉svn属性,有一个选项可以做到:
svn diff --patch-compatible > mypatch.diff
svn help diff
说:
--patch-compatible : generate diff suitable for generic third-party
patch tools; currently the same as
--show-copies-as-adds --ignore-properties
以这种方式创建的补丁应该与传统的普通patch
实用程序兼容。
发布于 2013-03-21 04:17:54
您有没有尝试过网页上提到的和页面上描述的--show-copies-as-adds
选项?
https://stackoverflow.com/questions/317649
复制相似问题