方案开发时,同一个平台的代码针对不同的客户,可能有不同的需求改动。当新项目来时,可能一些需求是以往项目做过的,简单粗暴的办法是由开发人员重复的将之前的需求改动porting到新项目上来。而这种做法基本就是纯体力活,本篇文档介绍如何利用Python脚本,根据特殊标签从项目代码里抽取出bug对应的patch,减轻抽取patch的工作量。
需求描述
新项目上一些需求老项目已经做过,需要提供一种自动化方案快速的将这些需求改动抽取成一个个patch,方便快速的将需求导入新项目。项目代码通过git管理,每一个需求对应一个bug号。
需求分析
知道了bug号,则可以通过bug号查看到git提交的记录,利用命令:
git format-patch
生成patch。但如何找出bug对应的是哪个git,又如何通过bug号查找出对应的comment id。看看命令:
git log –oneline
的输出结果:
可以结合grep命令筛选出bug对应的comment id。
至于如何找bug对应的git呢?很显然不可能手动进入git目录去执行上面的命令,有没有一种方法可以将源码下所有git的git log输出结果定向到一个文件里,这样就可以在这个文件里过滤出需要的commit了。答案是肯定的,命令repo forall 就可以办到,查看repo forall的帮助信息:
-p 参数可以输出git的目录,那么将git命令和repo forall结合起来:
repo forall -p -c ’ git log –no-merges –oneline’ > allpatch
它就会将源码下所有git的输出信息汇总到allpatch文件中。顺便提下 git log –no-merges中–no-merges参数的含义:
下图是输出的部分结果:
代码实现
根据上面的分析,脚本的大致框架应该如下:
给出简单的主要代码:
#!/usr/bin/env python
import os
import sys
'''
this script use to create patch from bugnumbers.
'''
class FilterPatch:
def printBreakLine(self):
line = "################################\n"
print line
return line
def helpInfo(self):
print "need input filterPatch file which record