实现的功能

git

根据传入的三个参数:起始统计日期、结束统计日期、git仓库地址。

脚本统计的是git仓库内的所有分支的log信息。

脚本统计的是指定时间段内、每一个提交人指定的git地址的所有分支里的提交代码行的新增情况。

其中代码行可分别统计出:新增的有效代码行数、新增的空行数、新增的注释行数。

并且脚本中还做了相应的提交历史“去重”,避免了这种情况:“某个分支是以其他分支为基础拉出来的,所以会将其他分支的git历史log一并复制,导致log历史重复了两份”,在统计时会去重,多次重复的git提交log只会算作一次提交。

svn

svn的统计方式与git有很大不同,svn要查看log不需要将代码checkout到本地。

svn的log命令最多只能看出,某个时间段内什么用户在什么版本号下修改了那些文件,

至于具体的修改内容,需要结合diff命令对每一个文件进行检查。

有相关log统计需求的朋友可以按照自己的需要修改后使用。

脚本内容

git

脚本布置在jenkins的job上,需要提前传入以下参数:

start_time(起始统计日期,格式为:xxxx-xx-xx xx:xx:xx)

end_time(结束统计日期,格式为:xxxx-xx-xx xx:xx:xx)

repo_url(git仓库地址,如:http://xxx.xxx.xxx.xxx/xxxxx/xxxxx.git

#clone主分支
git clone ${repo_url}
#cd进主分支文件夹
#拆分出url地址的最后一个路径,该路径是clone下来的文件夹名
newurl=${repo_url%.git};
array=(${newurl//// })
filename=${array[${#array[*]}-]}
cd ./$filename
cat>>chash_array
#循环切换各个分支
git branch -r |
grep -v '\->' |
while read remote;
do
#将一个分支拉下来
git checkout "$remote";
#遍历该分支在指定时间节点上的所有提交人
git log --format='%cn' --since="${start_time}" --until="${end_time}" | sort -u | while read name;
do
#遍历该提交人的所有提交hash码
git log --format='%H' --committer="${name}" --since="${start_time}" --until="${end_time}" | while read chash;
do
#0表示当前chash不在总数组中
flag=
while read line;
do
if [ $line = ${chash} ];then
flag=
break
fi
done < chash_array
#如果当前chash值在其中,则不进行log统计,否则将该chash存入总数组,并统计该chash的log
if [ ${flag} -eq ];then
#将chash存入文件
echo $chash>>chash_array
#计算三种该chash的三种代码行数
num_null=`git show ${chash} | awk '/^\+\s*$/' | wc -l`;
num_ann=`git show ${chash} | awk '/^\+\s*\/|^\+\s*\*|^\+\s*\#|^\+\s*\<\!\-\-|^\+\s*\-\-\>/' | wc -l`;
num_all=`git show ${chash} | awk '/^\+/' | wc -l`;
num_code=$(($num_all-$num_null-$num_ann))
#以下开始为有效代码行赋权值,weight为1表示权值是1,为2表示权值是1.,为3表示权值是1.,为4表示权值是1.
weight=
this_file=`git show ${chash} | awk '/diff.*\.js$/' | wc -l`;
if [ $this_file -ne ]; then
weight=
else
this_file=`git show ${chash} | awk '/diff.*\.py$|diff.*\.cpp$|diff.*\.c$|diff.*\.h$|diff.*\.go$|diff.*\.m$|diff.*\.swift$/' | wc -l`;
if [ $this_file -ne ]; then
weight=
else
this_file=`git show ${chash} | awk '/diff.*\.scala$/' | wc -l`;
if [ $this_file -ne ]; then
weight=
fi
fi
fi
#将所有参数传给python脚本 fi
done
done
echo "下一个分支"
done

svn

需提前传入以下参数:

start_time(起始统计日期,格式为:xxxx-xx-xx xx:xx:xx)

end_time(结束统计日期,格式为:xxxx-xx-xx xx:xx:xx)

trunk_repo_id(trunk仓库id号)

trunk_url(trunk仓库地址,如:svn://xxx.xxx.xxx.xxx/项目名/xxx/trunk)

branches_repo_id(branches仓库id号)

branches_url(branch仓库地址,如:svn://xxx.xxx.xxx.xxx/项目名/xxx/branches)

# 1表示当前行内容为“用户名、版本号”。2表示当前行内容为“该版本的某一个被修改了的文件的路径”
dothings=''
#当前正在统计的用户的用户名
username=''
#当前正在统计的版本号
rversion=''
#拼接出文件路径的前缀
OLD_IFS="$IFS"
IFS="/"
arr=($trunk_url)
IFS="$OLD_IFS"
urlpre="svn://""${arr[2]}""/""${arr[3]}""/"
#将需要查询的svn仓库地址装入数组
svn_url_arr=("${trunk_url} ${trunk_repo_id}" "${branches_url} ${branches_repo_id}") for i in "${svn_url_arr[@]}" ;
do
one=($i)
now_url=${one[]}
repo_id=${one[]}
svn log -v -r {"$start_time"}:{"$end_time"} ${now_url} | while read line
do
if [ "${line}" = "------------------------------------------------------------------------" ];
#如果当前行到这行,表示接下来该正则用户名与版本号了。
then
dothings=''
elif [ "${line}" = "Changed paths:" ];
#如果当前行到这行,表示接下来该正则文件路径了
then
dothings=''
elif [ ${dothings} = '' ];
#正则出当前行的用户名和版本号,并赋值
then
OLD_IFS="$IFS"
IFS="|"
arr=($line)
IFS="$OLD_IFS"
rversion=${arr[]#r}
username=${arr[]}
elif [ ${dothings} = '' ];
#正则当前行并拼接出路径,然后diff
then
fileurl=`echo ${line} | awk '/\/.*\..*/'`
#如果不为空,则表示文件格式正确,开始diff该文件详情
if [ -n "$fileurl" ]; then
OLD_IFS="$IFS"
IFS="("
arr=($line)
IFS="$OLD_IFS"
fileurl=${arr[]#*/}
fileurl="$urlpre""${fileurl}" svn diff -c $rversion ${fileurl}
#计算该文件的三种代码行数
num_null=`svn diff -c $rversion ${fileurl} | awk '/^\+\s*$/' | wc -l`;
num_ann=`svn diff -c $rversion ${fileurl} | awk '/^\+\s*\/|^\+\s*\*|^\+\s*\#|^\+\s*\<\!\-\-|^\+\s*\-\-\>/' | wc -l`;
num_all=`svn diff -c $rversion ${fileurl} | awk '/^\+/' | wc -l`;
num_code=$(($num_all-$num_null-$num_ann-)) #以下开始为有效代码行赋权值,weight为1表示权值是1,为2表示权值是1.,为3表示权值是1.,为4表示权值是1.
weight=
this_file=`svn diff -c $rversion ${fileurl} | awk '/\+\+\+.*\.js/' | wc -l`;
if [ $this_file -ne ]; then
weight=
else
this_file=`svn diff -c $rversion ${fileurl} | awk '/\+\+\+.*\.py|\+\+\+.*\.cpp|\+\+\+.*\.c|\+\+\+.*\.h|\+\+\+.*\.go|\+\+\+.*\.m|\+\+\+.*\.swift/' | wc -l`;
if [ $this_file -ne ]; then
weight=
else
this_file=`svn diff -c $rversion ${fileurl} | awk '/\+\+\+.*\.scala/' | wc -l`;
if [ $this_file -ne ]; then
weight=
fi
fi
fi #将所有参数传给python脚本 fi
fi
done
done

shell脚本实现git和svn统计log代码行的更多相关文章

  1. 使用PYTHON统计项目代码行数

    目录 一 使用PYTHON统计项目代码行数 二 应用实例 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 使用PYTHON统计项目代码行数 遇到一个非常小的需求:统计一个项目里头的各类源代码 ...

  2. VS2012 利用正则统计项目代码行数

    原文:VS2012 利用正则统计项目代码行数 #开头和/开头或者空行都不计入代码量,  搜索出来以后最后一行就是代码行数了:

  3. Visual Studio使用正则表达式快速统计总共代码行数

    原文:Visual Studio使用正则表达式快速统计总共代码行数 按CTRL+SHIFT+F,勾上支持正则表达式,然后输入搜索内容: <span style="font-family ...

  4. Atitit.Guibutton与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数.

    Atitit.Guibutton与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数. 1. Kpi:::  代码行数(凝视行数,空白的行数), 方法数,class数 1 2. ...

  5. Atitit.Gui按钮与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数.

    Atitit.Gui按钮与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数. 1. Kpi:::  代码行数(注释行数,空白的行数), 方法数,class数 1 2. 过滤器 ...

  6. IDEA 怎么统计项目代码行数

    引言 IDEA 统计项目代码行数,主要是使用 Statistic 插件来统计 第一步 点击 File->Settings,如下图所示: 第二步 点击 install 安装 Statistic 插 ...

  7. jenkins+gitlab钩子+shell脚本基于git的tag实现App增量更新

    转自:http://blog.csdn.net/kingboyworld/article/details/54175330 环境安装 jdk1.8 1.安装jenkins 首先到https://jen ...

  8. shell脚本实现网站日志分析统计

    如何用shell脚本分析与统计每天的访问日志,并发送到电子邮箱,以方便每天了解网站情况.今天脚本小编为大家介绍一款不错的shell脚本,可以实现如上功能. 本脚本统计了:1.总访问量2.总带宽3.独立 ...

  9. linux shell脚本守护进程监控svn服务

    最近搭建的svn服务不知道什么原因服务总是被关闭(如果你不知道怎么搭建svn可以参考linux下搭建svn版本控制软件),因此用shell脚本实现一个守护进程.用于监控svn服务是否启动,如果服务不在 ...

随机推荐

  1. spring-petclinic性能调优实战(转)

    1.spring-petclinic介绍 spring-petclinic是spring官方做的一个宠物商店,结合了spring和其他一些框架的最佳实践. 架构如下: 1)前端 Thymeleaf做H ...

  2. Django Form表单组件

    Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否 ...

  3. mfc双缓冲绘图

    1.要求 在界面加载本地图片并显示,每过100ms改变一张图片显示 2.现象 通过定时器控制CImage,Load,Draw,Destroy,会非常的卡顿.因为Load图片时,会是非常大的数据[所有C ...

  4. java.lang.IllegalStateException: getWriter() has already been called for this response

    出现此异常的三种可能: 1.通过response.reset(); 刷新可能存在一些未关闭的getWriter().  来源:http://blog.csdn.net/wonder4/article/ ...

  5. volatility内存取证

    最近参加了45届世界技能大赛的山东选拔赛,样题里有一个题如下: 师傅好不容易拿到了压缩包的密码,刚准备输入,电脑蓝屏 了... = =",题意简单明了,易于理解.一看就是内存取证的题并且已经 ...

  6. [opengl]Clion配置opengl

    如何在Clion中编写Opengl程序 首先下载 GLAD GLFW 创建Clion工程 在工程中创建文件夹lib.dll.include文件夹 把下载下来的东西放入对应的文件夹 CMakeLists ...

  7. oracle to_char 格式大全

    Postgres 格式化函数提供一套有效的工具用于把各种数据类型(日期/时间,int,float,numeric)转换成格式化的字符串以及反过来从格式化的字符串转换成原始的数据类型. 注意:所有格式化 ...

  8. 如何查找redis使用的是哪个配置文件

    ps -ef|grep redis 得到了进程号 xxxx 然后 ls -l /proc/xxxx/cwd ps:可以推广到其他进程,只要有pid,就能找到配置文件

  9. Testlink与MantisBT集成

    Testlink与MantisBT集成 关于两者集成的文章网上有很多,但是有些文章可能是作者写的时候自己不理解或有纰漏,有些文章写得是不够详细导致在配置中遗漏什么导致不成功.经过一天的不停尝试,终于完 ...

  10. Error:Execution failed for task ':app:preDebugAndroidTestBuild'. > Conflict with dependency 'com.android.support:support-annotations' in project ':app'. Resolved versions for app (26.1.0) and test app

    出现的问题: Error:Execution failed for task ':app:preDebugAndroidTestBuild'.> Conflict with dependency ...