当前位置:   article > 正文

patch:打补丁文件时,patch -p1命令的含义

patch -p1

        其实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文件,记录失败的地方,你可以手工修改。

扩展

patch:patch -p0 和patch -p1的区别
 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/559618
推荐阅读
相关标签
  

闽ICP备14008679号