赞
踩
其实patch在具体使用的时候是不用指定原文件的,因为补丁文件中都已经记载了原文件的路径和名称。patch可以自己识别出来。但是有时候会有点小问题。比如一般对两个目录diff的时候可能已经包含了原目录的名字,但是我们打补丁的时候会进入到目录中再使用patch,这时就需要你告诉 patch命令怎么处理补丁文件中的路径。可以利用-pn开关,告诉patch命令忽略的路径分隔符的个数。
举个栗子:
A文件在 DIR_A下,修改后的B文件在DIR_B下,一般DIR_A和DIR_B在同一级目录。我们为了对整个目录下的所有文件一次性diff,我们一般会到DIR_A和DIR_B的父目录下执行以下命令
diff -rc DIR_A DIR_B > C
怎么理解上面这段话呢?我们来看下面这个语句,a/bin/minindn是一个目录,下面有很多文件,b/bin/minindn也是一个目录,下面有很多文件
diff --git a/bin/minindn b/bin/minindn
这时候,我们就会在bin目录下,进行diff动作,来以此达到对minindn整个目录下的所有文件的一次性diff。
这个时候补丁文件C中会记录了原始文件的路径为 DIR_A/A
现在另一个用户君得到了A文件和C文件,其中A文件所在的目录也是DIR_A。 一般,用户君会比较喜欢在DIR_A目录下面进行patch操作,它会执行
patch < C
但是这个时候patch分析C文件中的记录,认为原始文件是./DIR_A/A,但实际上是./A,此时patch会找不到原始文件。为了避免这种情况我们可以使用-p1参数如下
patch -p1 < C
此时,patch会忽略掉第1个”/”之前的内容,认为原始文件是 ./A,这样就正确了。
最后有以下几点注意:
1、一次打多个patch的话,一般这些patch有先后顺序,得按次序打才行。
2、在patch之前不要对原文件进行任何修改
3、如果patch中记录的原始文件和你得到的原始文件版本不匹配(很容易出现),那么你可以尝试使用patch, 如果幸运的话,可以成功。大部分情况下,会有不匹配的情况,此时patch会生成rej文件,记录失败的地方,你可以手工修改。
扩展
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。