精华内容
下载资源
问答
  • Linux初学者Patch使用指南,交给你如何来使用patch,很好的资料
  • git Patch使用

    2018-08-02 15:42:53
    生成单个patch: git format-patch -1 <commit_id> 例如:git format-patch -1 e2054ab 清除上次patch am 残存信息 (虽然我不知道为什么,但是大家都推荐要加上)  git am --abort 检查patch能否...

    单次提交

    生成单个patch:

    git format-patch -1 <commit_id>  
        例如:git format-patch  -1 e2054ab

    清除上次patch am 残存信息 (虽然我不知道为什么,但是大家都推荐要加上)

     git am --abort

    检查patch能否打入成功(有错会报错):

     git apply --check patch_filename(注意路径)

    打入patch 

    git am -s < patch_filename(注意路径)

    修改patch原有的commmit日志内容

    git commmit --amend   (注意:此命令只能修改最新commit日志)

     参考:https://blog.csdn.net/liuhaomatou/article/details/54410361(很全面)

    多个patch(后续增加)

     

    展开全文
  • JSON PATCH 使用

    千次阅读 2016-07-28 17:06:49
    可与 HTTP PATCH method 合并使用 http://jsonpatch.com/   原始文档 {  "baz": "qux",  "foo": "bar" } Patch [  { "op": "replace&...

    JSON Patch 是一个用来描述 JSON 文档变化的格式,它本身也是 JSON 文档。可与 HTTP PATCH method 合并使用

    http://jsonpatch.com/

     

    原始文档

    {
      "baz": "qux",
      "foo": "bar"
    }

    Patch

    [
      { "op": "replace", "path": "/baz", "value": "boo" },
      { "op": "add", "path": "/hello", "value": ["world"] },
      { "op": "remove", "path": "/foo"}
    ]

    结果

    {
       "baz": "boo",
       "hello": ["world"]
    }
    ---------------------------------------------------------

    目前在现在的restful web项目中,主要通过patch来变更对象。

     

    变更之前的json 和变更之后的json,通过JSON-PATCH 提供的各个语言的类库进行比较得出patchjson,从而将patchjson提交。

    感觉网络传输会小,没有发现其他的区别,web服务端先将patch 和 现在的进行merge 然后在真正保存。

     

    例子:

    public static void main(String[] args) {
           
            TextNode node1 = factory.textNode("{a:1,b:2}");
            TextNode node2 = factory.textNode("{a:2,b:1}");
            JsonNode patch = JsonDiff.asJson(node1, node2);
            System.out.println(patch.toString());
        }

    输出结果:

    [{"op":"replace","path":"/","value":"{a:2,b:1}"}]

     

    展开全文
  • diff和patch使用指南

    2013-05-31 15:35:29
    diff和patch使用指南 diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。  diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的...

    转载自 http://www.cnblogs.com/cute/archive/2011/04/29/2033011.html

    diff和patch使用指南

    diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。 
    diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的patch文件,即补丁文件。 
    patch能将diff文件运用于 原来的两个集合之一,从而得到另一个集合。举个例子来说文件A和文件B,经过diff之后生成了补丁文件C,那么着个过程相当于 A -B = C ,那么patch的过程就是B+C = A 或A-C =B。 
    因此我们只要能得到A, B, C三个文件中的任何两个,就能用diff和patch这对工具生成另外一个文件。

    这就是diff和patch的妙处。下面分别介绍一下两个工具的用法(待续)

    1. diff的用法

    diff后面可以接两个文件名或两个目录名。 如果是一个目录名加一个文件名,那么只作用在那么个目录下的同名文件。

    如果是两个目录的话,作用于该目录下的所有文件,不递归。如果我们希望递归执行,需要使用-r参数。

    命令diff A B > C ,一般A是原始文件,B是修改后的文件,C称为A的补丁文件。 
    不加任何参数生成的diff文件格式是一种简单的格式,这种格式只标出了不一样的行数和内容。我们需要一种更详细的格式,可以标识出不同之处的上下文环境,这样更有利于提高patch命令的识别能力。这个时候可以用-c开关。 
    2. patch的用法

    patch用于根据原文件和补丁文件生成目标文件。还是拿上个例子来说

    patch A C 就能得到B, 这一步叫做对A打上了B的名字为C的补丁。

    这一步之后,你的文件A就变成了文件B。如果你打完补丁之后想恢复到A怎么办呢?

    patch -R B C 就可以重新还原到A了。

    所以不用担心会失去A的问题。

    其实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

    这个时候补丁文件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文件,记录失败的地方,你可以手工修改。

    一、为单个文件进行补丁操作

    1、建立测试文件test0、test1

    [armlinux@lqm patch]$ cat  >>test0<<EOF

    > 111111

    > 111111

    > 111111

    > EOF

    [armlinux@lqm patch]$ more test0

    111111

    111111

    111111

    [armlinux@lqm patch]$ cat >>test1<<EOF

    > 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

    [armlinux@lqm patch]$ more test1.patch

    ************************************************************

    patch文件的结构

    补丁头

    补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。---开头表示旧文件,+++开头表示新文件。

    一个补丁文件中的多个补丁

    一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。

    块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。

    块的缩进

    块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。

    块的第一列

    +号表示这一行是要加上的。

    -号表示这一行是要删除的。

    没有加号也没有减号表示这里只是引用的而不需要修改。

    ************************************************************

    ***diff命令会在补丁文件中记录这两个文件的首次创建时间,如下***

    --- test0       2006-08-18 09:12:01.000000000 +0800

    +++ test1       2006-08-18 09:13:09.000000000 +0800

    @@ -1,3 +1,4 @@

    +222222

    111111

    -111111

    +222222

    111111

    [armlinux@lqm patch]$ patch -p0 < test1.patch

    patching file test0

    [armlinux@lqm patch]$ ls

    test0  test1  test1.patch

    [armlinux@lqm patch]$ cat test0

    222222

    111111

    222222

    111111

    3、可以去除补丁,恢复旧版本

    [armlinux@lqm patch]$ patch -RE -p0 < test1.patch

    patching file test0

    [armlinux@lqm patch]$ ls

    test0  test1  test1.patch

    [armlinux@lqm patch]$ cat test0

    111111

    111111

    111111

    二、为多个文件进行补丁操作

    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<<EOF

    > --------

    > 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<<EOF

    > ---------

    > 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]$ more prj1.patch

    diff -uNr prj0/prj0name prj1/prj0name

    --- prj0/prj0name       2006-08-18 09:25:11.000000000 +0800

    +++ prj1/prj0name       1970-01-01 08:00:00.000000000 +0800

    @@ -1,3 +0,0 @@

    ---------

    -prj0/prj0name

    ---------

    diff -uNr prj0/prj1name prj1/prj1name

    --- prj0/prj1name       1970-01-01 08:00:00.000000000 +0800

    +++ prj1/prj1name       2006-08-18 09:26:36.000000000 +0800

    @@ -0,0 +1,3 @@

    +---------

    +prj1/prj1name

    +---------

    diff -uNr prj0/test0 prj1/test0

    --- prj0/test0  2006-08-18 09:23:53.000000000 +0800

    +++ prj1/test0  1970-01-01 08:00:00.000000000 +0800

    @@ -1,3 +0,0 @@

    -111111

    -111111

    -111111

    diff -uNr prj0/test1 prj1/test1

    --- prj0/test1  1970-01-01 08:00:00.000000000 +0800

    +++ prj1/test1  2006-08-18 09:26:00.000000000 +0800

    @@ -0,0 +1,4 @@

    +222222

    +111111

    +222222

    +111111

    [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 <to-docu.patch


    展开全文
  • git patch 使用

    千次阅读 2014-11-06 09:03:35
    1使用git format-patch生成所需要的patch: 当前分支所有超前master的提交: git format-patch -M master 某次提交以后的所有patch: git format-patch 4e16 --4e16指的是commit名 从根到指定提交的所有patch: ...
    
    1使用git format-patch生成所需要的patch:
    当前分支所有超前master的提交:
    git format-patch -M master
    某次提交以后的所有patch:
    git format-patch 4e16                 --4e16指的是commit名
    从根到指定提交的所有patch:
    git format-patch                          --root 4e16
    某两次提交之间的所有patch:
    git format-patch 365a..4e16       --365a和4e16分别对应两次提交的名称
    某次提交(含)之前的几次提交:
    git format-patch –n 07fe             --n指patch数,07fe对应提交的名称
    故,单次提交即为:
    git format-patch -1 07fe
    git format-patch生成的补丁文件默认从1开始顺序编号,并使用对应提交信息中的第一行作为文件名。如果使用了-- numbered-files选项,则文件名只有编号,不包含提交信息;如果指定了--stdout选项,可指定输出位置,如当所有patch输出到一个文件;可指定-o <dir>指定patch的存放目录;


    2应用patch:
    先检查patch文件:git apply --stat newpatch.patch
    检查能否应用成功:git apply --check  newpatch.patch
    打补丁:git am --signoff < newpatch.patch

    (使用-s或--signoff选项,可以commit信息中加入Signed-off-by信息)


    如果应用patch出现问题:参考git am PATCH 失败的处理方法http://blog.csdn.net/sunnylgz/article/details/7660638


    参考资料:

    git-format-patch(1) - Linux man page http://linux.die.net/man/1/git-format-patch

    How to create and apply a patch with Git http://ariejan.net/2009/10/26/how-to-create-and-apply-a-patch-with-git

    展开全文
  • draw9patch使用问题

    千次阅读 2017-05-14 21:32:07
    好久没使用draw9patch做图,才发现sdk的tools里面已经没有了draw9patch,原来Intellij idea和AndroidStudio已经把该工具内置了,使用时你只需要将图片后缀改为.9.png,打开图片选择9-Patch即可编辑,但是使用发现不...
  • git 补丁 - diff 和 patch 使用详解

    万次阅读 2019-04-27 20:15:16
    diff 和 patch 的区别 Git 提供了两种补丁方案,一种是通过 git diff 生成的 .diff 文件,第二种是通过 git format-patch 生成的 .patch 文件。 通过 git diff 生成的文件不含有 commit 信息,可以指定文件生成 diff...
  • git 中的 patch 使用

    千次阅读 2018-11-26 15:48:16
    介绍 git 协同开发时, patch 在某些场景下, 是个不错的...没有网络时候, 同步一个 feature/fix 给其他开发者/测试人员/客户使用 公司网络出问题时, 没法通过 git cherry-pick 或其他 git 操作来同步feature/fix, 这...
  • git patch 使用方法

    千次阅读 2012-03-20 13:51:27
    【生成patch】 分支master 上是没修改前的,分支patch 上是修改以后的打patch的。 1. 先切换到 patch分支 git checkout patch 2. 生成patch git format-patch -M master 会生成一个文件名如:0002-Release...
  • linux patch使用笔记

    千次阅读 2010-08-30 17:33:00
    介绍diff和patch使用
  • diff和patch使用总结

    千次阅读 2017-03-07 18:29:33
    diff是Linux系统的一个很重要的工具程序,我们通常用diff对同一...diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。diff比较两个文件或文件集合的差异,并记录下来,生
  • linux kernel patch 使用说明

    千次阅读 2018-06-27 08:45:51
    内核补丁不是一定需要的,这要看你选择的...而如果使用Embedix内核,开发板是PPC体系的,内核可能本身已经支持PPC,也不需要安装补丁了。但嵌入式系统往往工作在不同的特定目标板上,如arm,这就需要使linux内核扩展...
  • google-diff-match-patch使用说明

    万次阅读 2016-10-20 14:22:46
    要对文本文件的进行比较的时候,可以考虑使用google-diff-match-patch算法,它可以对文本文件进行比较、匹配和生成补丁的操作。他的官网是:http://code.google.com/p/google-diff-match-patch/CSDN下载:...
  • diff和patch使用

    2011-10-06 18:00:58
    hello-1.0 和hello-1.1两个目录,其中hello-1.1为hello-1.0的更新  # diff -ruNa hello-1.0 hello-1.1 >hello-1.1.patch  注意:提交制作内核patch时,需要把生成的
  • diff&patch 使用

    千次阅读 2011-05-16 19:41:00
    刚开始遇到一个问题:diff 的两个参数都是dicetory. 当前目录为:current/...ur old/ new/ >patch.diff   注:如果没有指定-u选项,在后面进行patch时直接就出错:patch: **** Only garbage was
  • Android 9patch 使用

    千次阅读 2013-10-22 19:37:36
    ③:这里 zoom:的长条bar 是对导入的图放大缩小操作,这里的放大缩小只是为了让使用者更方便操作,毕竟是对像素点操作比较费眼,下面的 patch scale 是序列 ④区域中的三种形态的拉伸后的一个预览操作,可以看到操作...
  • (ZT)diff和patch使用指南

    2007-05-09 15:52:00
    diff和patch使用指南to^MS2©OldLinux论坛 -- 有关早期Linux内核代码发展的论坛。 Vjdiff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。%i0F@/diff比较两个文件或文件...
  • diff 和 patch 使用指南

    2012-09-26 15:45:18
    diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。  diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的patch文件,即补丁文件。 ...
  • git format-patch 使用方法

    千次阅读 2014-10-21 17:14:26
    使用git format-patch生成所需要的patch: # git format-patch -s 1bbe3c8c197a35f79bfddaba099270a2e54ea9c7 please replace the hash code with your repo previous commit. then you can find the ...
  • Nine-Patch使用方法

    千次阅读 2015-07-10 14:36:32
    在android中专门有一种叫nine patch图片(以 9.png结尾)来解决背景大小不一样时,只用一张背景图片。  用自带的tools/draw9patch.bat 打开一张png图片,我们可以在png图片最外面的空格画一个像
  • diff和patch使用体会

    2011-04-14 10:46:00
    <br />diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算。    diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 153,079
精华内容 61,231
关键字:

patch如何使用