关闭

git提交patch,并发送邮件列表

138人阅读 评论(0) 收藏 举报
分类:
一. 先配置git send-mail 的 smtp服务器:
1. 安装git-email:
# apt-get install git git-core git-email


修改gitconfig文件:vim ~/.gitconfig
[color]

ui = auto

[commit]

template = ~/.commit_template

[user]

name = ***

email = ***@***.com

[alias]

pretty = log --branches --remotes --tags --graph --oneline
--decorate

[sendemail]

smtpencryption = tls

smtpserver = smtp.gmail.com

smtpuser = *****.****@gmail.com

smtpserverport = 587

smtppass = abcdef


suppresscc = all //will suppress all auto cc values

confirm = always



#to = *****.****@gmail.com //Specify the primary recipient

#cc = s***linux@freelists.org //CC list




2. Then editthe .git/hooks/pre-commit fileto contain only the following two lines:
#!/bin/sh
exec git diff --cached | scripts/checkpatch.pl --no-signoff - || true

二. 好了,下面就是提交的步骤了。
1. 按功能分类提交commit ,提交之前先执行脚本 ./scripts/cleanfile xx.   1)加-s选项,自动Signed-off-by. 
 
   2)git commit--amend --author " Xxx Zhang "(添加实际的author,如果author是本人,则不要写)
    3)commit message第一行要是patch的主题(包括patch的从属子系统,和概述),第二行是patch的详细描述。
    4)如果想修改其中的一个commitmessage:
         a)gitformat-patch -n --cover-letter(有必要的话,将测试结果和基于的主线版本写在0000-cover-letter.patch中的详细描述中)
         b)gitreset到那个commit,如要更改或添加某个文件,git add; 如要删除某个commit的文件,(git resetHEAD^ file),然后 commit --amend
         c)git am *.patch (不用gitapply,因为apply命令只将patch应用到index,而不会将commitmessage同时应用到git仓库上。如果当前目录下之前执行过git-am,而没有发送email,需要先执行git am--abort放弃掉之前的am信息。遇到了一次abort不掉的时候,执行rm -rf.git/rebase-apply/就可以了,参照如下Linkhttp://git.661346.n2.nabble.com/Dangerous-quot-git-am-abort-quot-behavior-td5853324.html)

2. 生成patch:
   1)git format-patch -2 --cover-letter//2表示从HEAD的commit开始,向前生成两个commit的patch。--cover-letter会生成一个0000-cover-letter.patch,格式和commitmessage类似,第一行是patchset的主题,第二行描述这组patchset的详细信息,它就是邮件中的【PATCH0/n】。
    2)git format-patch -numbered --cover-letter--subject-prefix="PATCH v2" (如果不是第一版    patch需要添加版本号,以v2为例)

3. 检查patch:
  ./scripts/checkpatch.pl0001-nfs-add-a-pr_info.patch (不用检查0000-cover-letter.patch


4. 发邮件列表:
   git send-email *.patch
   如果想要编辑patch邮件内容,加--annotate选项。
   编辑完一个退出vim用:wn命令,编辑下一个patch,直到最后一个直接wq退出vim即可。

$ git send-email*.patch
/tmp/59yD80Mjvb/0000-cover-letter.patch
/tmp/59yD80Mjvb/0001-clone-patch-test-001.patch
/tmp/59yD80Mjvb/0002-revised-text.patch
3 files to edit
Who should the emails appear to be from? [chunyan.zhang ]zh**.****@gmail.com//输入发件人邮箱
Emails will be sent from: zhang.lyra@gmail.com
Who should the emails be sent to? z***@gmail.com //输入收件人邮箱
Message-ID to be used as In-Reply-To for the first email?for_test//随便输入一个ID


附:标准的patch格式
The canonical patch subject line is:

Subject: [PATCH 001/123] subsystem: summary phrase

The canonical patch message body contains the following:

- A "from" line specifying the patch author.

- An empty line.

- The body of the explanation, which will be copied to the
permanent changelog to describe this patch.

- The "Signed-off-by:" lines, described above, which will
also go in the changelog.

- A marker line containing simply "---".

- Any additional comments not suitable for the changelog.

- The actual patch (diff output).


参考:
http://www.freedesktop.org/wiki/Software/PulseAudio/HowToUseGitSendEmail/
http://blog.chinaunix.net/uid-28453894-id-3552774.html
http://kernelnewbies.org/OPWfirstpatch
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

如何向 Linux 内核上游提交 Patch ?

在GitHub上有本内核电子书叫《Linux Inside》,虽然完成度不高但还是很火的,它还有了自己的中文版翻译项目,我也参与了该项目的翻译工作,以下内容即为该书第 13.3 节的翻译版,主要讲解了...
  • u010035971
  • u010035971
  • 2016-12-31 17:22
  • 1280

Git 上多次commit 合并成一个 patch

对于一个test 工程   git log 看其提交的过程: commit 9fdd76eb5fd06b1b7f2af6800dc13e51099c40d9 Author: ShichaoXu ...
  • GZgengzhen
  • GZgengzhen
  • 2016-12-15 14:04
  • 2565

步骤:用git提交patch,并发送邮件…

一. 先配置git send-mail 的 smtp服务器: 1. 安装git-email: # apt-get install git git-core git-email 修改gitconfig...
  • zcy33415
  • zcy33415
  • 2014-11-27 18:07
  • 367

Git patch生成以及更新的命令

1 使用git format-patch生成所需要的patch: 当前分支所有超前master的提交: git format-patch -M master 某次提交以后的所有patch: g...
  • daydring
  • daydring
  • 2015-01-13 15:10
  • 10382

多个commit 合并为一个patch

有时候开发一个功能需要commit 很多次才能有一个比较精简的版本。  但是此时只允许打一个patch,如果这样就要把这几个commit 信息合并。 可以通过git reset + git mer...
  • XscKernel
  • XscKernel
  • 2013-12-31 18:04
  • 6352

git 远程版本库,github提供服务原理,git自动更新发送邮件

1.安装好linux,安装好git(192.168.1.239) 2.创建一个用户zph(让此用户提供git on server),密码设置为12345678 [python] vie...
  • G_wenjie
  • G_wenjie
  • 2016-09-08 09:20
  • 799

如何使用git 生成patch 和打入patch

平时我们在使用git 管理项目的时候,会遇到这样一种情况,那就是客户使用git 生成patch 给到我们,那我们就需要把客户给到patch 打入到我们的project ,基于这样一个场景,我把git ...
  • liuhaomatou
  • liuhaomatou
  • 2017-01-13 17:36
  • 12507

git 生成patch和使用patch

啰嗦下:发现自己的blog被转载了,不过没有注明出处,有点痛并快乐着的感觉。这里正式申明下:转载请注明出处,感谢。如有商用目的请务必知会本人。           在android大环境下工作,迟...
  • ts1122
  • ts1122
  • 2013-03-21 23:46
  • 81305

我的git学习笔记——git 邮件发送

10、git send-email *.patch发送邮件: 配置: git config sendemail.smtpencryption tls git config sendemail.smt...
  • lwx2615
  • lwx2615
  • 2014-03-04 09:39
  • 4224

git 回退某个版本或者去掉某些patch

diff -urN linux-x.y.z/    linux/     >   xxx_patch patch -p1 diffstat -p1 xxx_patch git checkout  ....
  • xiaolubk
  • xiaolubk
  • 2015-09-11 10:13
  • 2068
    最新评论
    个人资料
    • 访问:65709次
    • 积分:154
    • 等级:
    • 排名:千里之外
    • 原创:6篇
    • 转载:111篇
    • 译文:1篇
    • 评论:3条