| |
[hsy75]案本文列出了两个目录之间打patch,和生产patch的最基本也是最充足的例子,
其他细节请参考ref:
1 diff:
diff -r/*文件夹所有文件*/ [没有改动的原来的文件夹][改动后需要打补丁记录的文件] > [生成的补丁名称]
2 patch:
patch -p0/*文件夹深度默认当前目录为没有需要补丁的文件夹*/ < [补丁文件和他的路径]
深入:当然,如果你的patch需要更多的上下文的内容,那么你应该在diff的时候 加入选项: -N -u
按照下面的diff 的参考,有
-N或--new-file 在比较目录时,若文件A仅出现在某个目录中,预设会显示:【hsy75案】这里是指,如果有文件在两个比较目录中,只有一个目录里面有,那么
生产的patch会把整个文件的内容加进来,这样就可以保证你的patch不需要你改动的文件了,只需要源文件
-u,-U<列数>或--unified=<列数> 以合并的方式来显示文件内容的不同。 这里就是上下文显示方式
diff -r 源文件 改动文件 > 文件patch
diff -r DirectFB-1.4.3/configure DirectFB-1.4.3-patched/configure
1007a1008,1009
> GFX_CNXTGFX_TRUE
> GFX_CNXTGFX_FALSE
1748c1750
< matrox, neomagic, nsc, nvidia, omap, pxa3xx, radeon, savage, sh772x,
---
> matrox, neomagic, nsc, nvidia, omap,cnxtgfx, pxa3xx, radeon, savage, sh772x,
diff -rNu 源文件 改动文件 > 文件patch
GFX_NVIDIA_FALSE
+GFX_CNXTGFX_TRUE
+GFX_CNXTGFX_FALSE
GFX_OMAP_TRUE
GFX_OMAP_FALSE
GFX_PXA3XX_TRUE
@@ -1745,7 +1747,7 @@
'all' builds all drivers (default), 'none' builds none
Possible gfxdrivers are:
ati128, cle266, cyber5k, davinci, ep9x, gl, i810, i830, mach64,
- matrox, neomagic, nsc, nvidia, omap, pxa3xx, radeon, savage, sh772x,
+ matrox, neomagic, nsc, nvidia, omap,cnxtgfx, pxa3xx, radeon, savage, sh772x
ref:
功能说明:比较文件的差异。 语 法:diff [-abBcdefHilnNpPqrstTuvwy][-<行数>][-C <行数>][-D <巨集名称>][-I <字符或字符串>][-S <文件>][-W <宽度>][-x <文件或目录>][-X <文件>][--help][--left-column][--suppress-common-line][文件或目录1][文件或目录2] 补充说明:diff以逐行的方式,比较文本文件的异同处。所是指定要比较目录,则diff会比较目录中相同文件名的文件,但不会比较其中子目录。 参 数: -<行数> 指定要显示多少行的文本。此参数必须与-c或-u参数一并使用。 -a或--text diff预设只会逐行比较文本文件。 -b或--ignore-space-change 不检查空格字符的不同。 -B或--ignore-blank-lines 不检查空白行。 -c 显示全部内文,并标出不同之处。 -C<行数>或--context<行数> 与执行"-c-<行数>"指令相同。 -d或--minimal 使用不同的演算法,以较小的单位来做比较。 -D<巨集名称>或ifdef<巨集名称> 此参数的输出格式可用于前置处理器巨集。 -e或--ed 此参数的输出格式可用于ed的script文件。 -f或-forward-ed 输出的格式类似ed的script文件,但按照原来文件的顺序来显示不同处。 -H或--speed-large-files 比较大文件时,可加快速度。 -l<字符或字符串>或--ignore-matching-lines<字符或字符串> 若两个文件在某几行有所不同,而这几行同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异。 -i或--ignore-case 不检查大小写的不同。 -l或--paginate 将结果交由pr程序来分页。 -n或--rcs 将比较结果以RCS的格式来显示。 -N或--new-file 在比较目录时,若文件A仅出现在某个目录中,预设会显示: Only in目录:文件A若使用-N参数,则diff会将文件A与一个空白的文件比较。 -p 若比较的文件为C语言的程序码文件时,显示差异所在的函数名称。 -P或--unidirectional-new-file 与-N类似,但只有当第二个目录包含了一个第一个目录所没有的文件时,才会将这个文件与空白的文件做比较。 -q或--brief 仅显示有无差异,不显示详细的信息。 -r或--recursive 比较子目录中的文件。 -s或--report-identical-files 若没有发现任何差异,仍然显示信息。 -S<文件>或--starting-file<文件> 在比较目录时,从指定的文件开始比较。 -t或--expand-tabs 在输出时,将tab字符展开。 -T或--initial-tab 在每行前面加上tab字符以便对齐。 -u,-U<列数>或--unified=<列数> 以合并的方式来显示文件内容的不同。 -v或--version 显示版本信息。 -w或--ignore-all-space 忽略全部的空格字符。 -W<宽度>或--width<宽度> 在使用-y参数时,指定栏宽。 -x<文件名或目录>或--exclude<文件名或目录> 不比较选项中所指定的文件或目录。 -X<文件>或--exclude-from<文件> 您可以将文件或目录类型存成文本文件,然后在=<文件>中指定此文本文件。 -y或--side-by-side 以并列的方式显示文件的异同之处。 --help 显示帮助。 --left-column 在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容。 --suppress-common-lines 在使用-y参数时,仅显示不同之处 |
功能说明:修补文件。 语 法:patch [-bceEflnNRstTuvZ][-B <备份字首字符串>][-d <工作目录>][-D <标示符号>][-F <监别列数>][-g <控制数值>][-i <修补文件>][-o <输出文件>][-p <剥离层级>][-r <拒绝文件>][-V <备份方式>][-Y <备份字首字符串>][-z <备份字尾字符串>][--backup-if -mismatch][--binary][--help][--nobackup-if-mismatch][--verbose][原始文件 <修补文件>] 或 path [-p <剥离层级>] < [修补文件] 补充说明:patch指令让用户利用设置修补文件的方式,修改,更新原始文件。倘若一次仅修改一个文件,可直接在指令列中下达指令依序执行。如果配合修补文件的方式则能一次修补大批文件,这也是Linux系统核心的升级方法之一。 参 数: -b或--backup 备份每一个原始文件。 -B<备份字首字符串>或--prefix=<备份字首字符串> 设置文件备份时,附加在文件名称前面的字首字符串,该字符串可以是路径名称。 -c或--context 把修补数据解译成关联性的差异。 -d<工作目录>或--directory=<工作目录> 设置工作目录。 -D<标示符号>或--ifdef=<标示符号> 用指定的符号把改变的地方标示出来。 -e或--ed 把修补数据解译成ed指令可用的叙述文件。 -E或--remove-empty-files 若修补过后输出的文件其内容是一片空白,则移除该文件。 -f或--force 此参数的效果和指定"-t"参数类似,但会假设修补数据的版本为新 版本。 -F<监别列数>或--fuzz<监别列数> 设置监别列数的最大值。 -g<控制数值>或--get=<控制数值> 设置以RSC或SCCS控制修补作业。 -i<修补文件>或--input=<修补文件> 读取指定的修补问家你。 -l或--ignore-whitespace 忽略修补数据与输入数据的跳格,空格字符。 -n或--normal 把修补数据解译成一般性的差异。 -N或--forward 忽略修补的数据较原始文件的版本更旧,或该版本的修补数据已使 用过。 -o<输出文件>或--output=<输出文件> 设置输出文件的名称,修补过的文件会以该名称存放。 -p<剥离层级>或--strip=<剥离层级> 设置欲剥离几层路径名称。 -f<拒绝文件>或--reject-file=<拒绝文件> 设置保存拒绝修补相关信息的文件名称,预设的文件名称为.rej。 -R或--reverse 假设修补数据是由新旧文件交换位置而产生。 -s或--quiet或--silent 不显示指令执行过程,除非发生错误。 -t或--batch 自动略过错误,不询问任何问题。 -T或--set-time 此参数的效果和指定"-Z"参数类似,但以本地时间为主。 -u或--unified 把修补数据解译成一致化的差异。 -v或--version 显示版本信息。 -V<备份方式>或--version-control=<备份方式> 用"-b"参数备份目标文件后,备份文件的字尾会被加上一个备份字符串,这个字符串不仅可用"-z"参数变更,当使用"-V"参数指定不同备份方式时,也会产生不同字尾的备份字符串。 -Y<备份字首字符串>或--basename-prefix=--<备份字首字符串> 设置文件备份时,附加在文件基本名称开头的字首字符串。 -z<备份字尾字符串>或--suffix=<备份字尾字符串> 此参数的效果和指定"-B"参数类似,差别在于修补作业使用的路径与文件名若为src/linux/fs/super.c,加上"backup/"字符串后,文件super.c会备份于/src/linux/fs/backup目录里。 -Z或--set-utc 把修补过的文件更改,存取时间设为UTC。 --backup-if-mismatch 在修补数据不完全吻合,且没有刻意指定要备份文件时,才备份文件。 --binary 以二进制模式读写数据,而不通过标准输出设备。 --help 在线帮助。 --nobackup-if-mismatch 在修补数据不完全吻合,且没有刻意指定要备份文件时,不要备份文件。 --verbose 详细显示指令的执行过程。 |
ref:
http://linux.ccidnet.com/art/3067/20070418/1064163_1.html
edit by: huang.makin@gmail.com