Chinaunix首页 | 论坛 | 博客
  • 博客访问: 403376
  • 博文数量: 78
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 940
  • 用 户 组: 普通用户
  • 注册时间: 2013-08-25 09:39
文章分类

全部博文(78)

文章存档

2016年(7)

2015年(1)

2014年(35)

2013年(35)

我的朋友

分类: 项目管理

2013-12-09 19:58:22

一、linux打补丁方法
1、处理单个文件补丁的方法:
# 产生补丁
diff -uN from-file to-file >to-file.patch
# 打补丁
patch -p0 < to-file.patch
# 取消补丁
patch -RE -p0 < to-file.patch

2、对整个文件夹打补丁的情况:
# 产生补丁
diff -uNr  from-docu  to-docu  >to-docu.patch
# 打补丁
cd to-docu
patch -p1 < to-docu.patch
# 取消补丁
patch -R -p1 注,冲突:
.orig 合并前文件备份。
.rej 文件里是冲突没合入的内容。
二、git打patch方法
1、git format-patch  (推荐)
只适用于git的patch
包含diff信息,包含提交人,提交时间等
如果git format-patch 生成的补丁不能打到当前分支,git am会给出提示,并协助你完成打补丁工作
例:从master checkout一个新分支修改然后与master对比生成patch。git format-patch -M master //-M选项表示这个patch要和那个分支比对
git am 001-xxx.patch(不必重新commit)


2、git diff
生成标准的patch,只包含diff信息
git diff生成的Patch兼容性强,可以用git apply --check 查看补丁是否能够干净顺利地应用到当前分支中。
例:从master checkout一个新分支修改然后与master对比生成patch。 git diff master > patch
git apply xxx.patch(需要重新commit)

阅读(20086) | 评论(1) | 转发(4) |
给主人留下些什么吧!~~

leadsec1112013-12-10 15:22:40

文明上网,理性发言...