• <转载> diff 和 patch 命令


    本文转载自:http://blog.chinaunix.net/uid-23390992-id-3312321.html
    diffpatch命令
    diffpatch命令真可谓是天作之合,命令中的黄金搭档。老师讲了之后其实自己不是很懂,因为上课的时候没有好好听,上课走神了。怎么办呢,肯定不能放着不管了,而这两个命令确实很重要,所以只能厚着脸皮课后死啃资料自己学习咯,学了之后才有开头第一句的感慨。
     
    diffpatch是一对工具,数学上说,diff是对两个集合的差运算,patch是对两个集合的和运算。diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,就是patch文件,即补丁文件。
     
    功能说明:比较文件的差异。
     
    语  法: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 此参数的输出格式可用于edscript文件。
    -f-forward-ed 输出的格式类似edscript文件,但按照原来文件的顺序来显示不同处。
    -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的用法:
     
    patch用于根据原文件和补丁文件生成目标文件。还是拿上个例子来说,patch A C 就能得到B, 这一步叫做对A打上了B的名字为C的补丁。之一步之后,你的文件A就变成了文件B。如果你打完补丁之后想恢复到A怎么办呢?patch -R B C 就可以重新还原到A了。所以不用担心会失去A的问题。
     
    功能说明:修补文件。
     
    语  法: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=<控制数值设置以RSCSCCS控制修补作业。
    -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 详细显示指令的执行过程。
     
     
     
    一、为单个文件进行补丁操作
     
    1、建立测试文件test0、test1
     
    [armlinux@lqm patch]$ cat >>test0<
    > 111111
    > 111111
    > 111111
    > EOF
    [armlinux@lqm patch]$ more test0
    111111
    111111
    111111
    [armlinux@lqm patch]$ cat >>test1<
    > 222222
    > 111111
    > 222222
    > 111111
    > EOF
    [armlinux@lqm patch]$ more test1
    222222
    111111
    222222
    111111
     
    2、使用diff创建补丁test1.patch
    [armlinux@lqm patch]$ diff -uN test0 test1 > test1.patch
    【注:因为单个文件,所以不需要-r选项。选项顺序没有关系,即可以是-uN,也可以是-Nu。】
    [armlinux@lqm patch]$ ls
    test0 test1 test1.patch
     
    二、为多个文件进行补丁操作
     
    1、创建测试文件夹
    [armlinux@lqm patch]$ mkdir prj0
    [armlinux@lqm patch]$ cp test0 prj0
    [armlinux@lqm patch]$ ls
    prj0 test0 test1 test1.patch
    [armlinux@lqm patch]$ cd prj0/
    [armlinux@lqm prj0]$ ls
    test0
    [armlinux@lqm prj0]$ cat >>prj0name<
    > --------
    > prj0/prj0name
    > --------
    > EOF
    [armlinux@lqm prj0]$ ls
    prj0name test0
    [armlinux@lqm prj0]$ cat prj0name
    --------
    prj0/prj0name
    --------
    [armlinux@lqm prj0]$ cd ..
    [armlinux@lqm patch]$ mkdir prj1
    [armlinux@lqm patch]$ cp test1 prj1
    [armlinux@lqm patch]$ cd prj1
    [armlinux@lqm prj1]$ cat >>prj1name<
    > ---------
    > prj1/prj1name
    > ---------
    > EOF
    [armlinux@lqm prj1]$ cat prj1name
    ---------
    prj1/prj1name
    ---------
    [armlinux@lqm prj1]$ cd ..
     
    2、创建补丁
    [armlinux@lqm patch]$ diff -uNr prj0 prj1 > prj1.patch
    [armlinux@lqm patch]$ ls
    prj0 prj1 prj1.patch test0 test1 test1.patch
     
    [armlinux@lqm patch]$ cp prj1.patch ./prj0
    [armlinux@lqm patch]$ cd prj0
    [armlinux@lqm prj0]$ patch -p1 < prj1.patch
    patching file prj0name
    patching file prj1name
    patching file test0
    patching file test1
     
    [armlinux@lqm prj0]$ ls
    prj1name prj1.patch test1
     
    [armlinux@lqm prj0]$ patch -R -p1 < prj1.patch
    patching file prj0name
    patching file prj1name
    patching file test0
    patching file test1
     
    [armlinux@lqm prj0]$ ls
    prj0name prj1.patch test0
    -------------------
     
    总结一下:
    单个文件
    diff –uN from-file to-file >to-file.patch
    patch –p0 < to-file.patch
    patch –RE –p0 < to-file.patch
     
    多个文件
    diff –uNr from-docu to-docu >to-docu.patch
    patch –p1 < to-docu.patch
    patch –R –p1
  • 相关阅读:
    WF4.0 基础 InvokeMethod 调用方法
    MySQL数据库表名、列名、别名区分大小写的问题
    客户端调用Web服务
    something about Socket
    C#参数传递
    学习内容
    About HttpContext
    Best Sequence [POJ1699] TSPDP
    优先队列
    Watermelon Full of Water [ZOJ 4778]
  • 原文地址:https://www.cnblogs.com/bkyysd/p/4217102.html
Copyright © 2020-2023  润新知