制作和合入文件包补丁

背景

    目前流行的合入补丁方式是打patch,制作和合入补丁都比较方便,下面来记录一种文件包补丁方式。

制作补丁

    导出修改差异文件:
    diff -ruq A B > diff.txt
        -r 递归子目录
        -u 使用统一的输出格式,解决默认忽略大小写问题
        -q 不报告差异,只说明两者内容是否有差异
      (还有其他方式:svn和git工具直接导出,待扩展)

    根据diff.txt里面的描述,3种情况:
    1、Only in A/:文件,说明在B中已经删除,需要写clean.sh脚本:rm -rvf A/文件
    2、Only in B/:文件,说明在B中是新增,需要拷贝B出来
    3、Files A/ Files B/,说明有差异,需要拷贝B出来

    拷贝文件保留目录结构路径:
    cp --parents B/文件 add_dir  (输出:add_dir/B/文件)

    批量拷贝操作:
    把diff.txt需要拷贝B出来的整理成全路径输出到文件file_list.txt:
        B/文件1
        B/文件2
    批量操作:
    tar -cz -T file_list.txt -f diff.tar;(diff.tar解压tar -xf出来就是B文件夹,里面包含了文件的目录结构)

合入补丁


    0、运行clean.sh脚本
    1、自己没有修改代码就直接把补丁文件解压,然后用命令拷贝覆盖:
    cp -arf B/* dest_B/
    2、自己有少量修改代码,可以先把自己的修改导出,然后解压补丁进行拷贝覆盖,然后再合入自己的修改
    3、若自己有大量修改,建议把补丁文件与自己的文件逐一比较然后合入。
 

    有不足或还有其他更好的操作欢迎留言一起谈论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
合入patch文件的步骤如下: 1. 首先,找到发生冲突的具体patch文件。如果不想打这一系列patch了,可以使用命令`git am --abort`来放弃打patch的过程。 2. 如果还想打这个patch,可以使用命令`git apply --reject <patch_name>`来强行打这个patch。这个命令会将发生冲突的部分保存为.rej文件,未发生冲突的部分会成功打上patch。 3. 根据.rej文件,通过编辑该patch文件的方式解决冲突。 4. 如果在解决冲突的过程中发现无法解决,可以使用命令`git am --abort`来废弃已经打了的patch。 5. 最后,重新打patch,可以使用命令`git am <patch_file>`来合入patch文件。\[1\] 请注意,合入patch文件的具体步骤可能会因为不同的情况而有所不同,以上步骤仅供参考。 #### 引用[.reference_title] - *1* [Git生成和导入Patch](https://blog.csdn.net/xxdw1992/article/details/116398393)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [生成和合入patch的两种方式](https://blog.csdn.net/salmon_zhang/article/details/97015801)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [制作合入patch补丁](https://blog.csdn.net/TSZ0000/article/details/82497179)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值