Shell脚本实现的基于SVN的代码提交量统计工具

   这篇文章主要介绍了Shell脚本实现的基于SVN的代码提交量统计工具,本文直接给出实现脚本代码,需要的朋友可以参考下

  最近没啥事,就用bash写了一个基于svn的代码统计小工具。 可以指定统计的目录,默认递归统计子目录。

  目前还没有屏蔽指定目录的功能。哈 代码比较粗糙。不过先晒出来。

  ?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171

#!/bin/bash -
#""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
# FILE: lines.sh
#
# USAGE: ./lines.sh [dir]
# AUTHOR: william
#
# DESCRIPTION: 基于SVN的代码提交量统计工具
# OPTIONS: ---
# CREATED: 06/05/2012 12:49:20 PM CST
#"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
 
set -o nounset # Treat unset variables as an error
 
 
# 关注的文件类型 后罪名
FILES_TYPE="*.cpp *.h *.lua"
 
# 需要统计的人员,在这里写入需要统计的人,用空格隔开。哈还不智能
declare -r CODER_LIST="coder1 coder2"
declare -i coder1
declare -i coder2
 
 
declare -r USAGE="Usage: $0 [dir]. default dir is current dir.n"
 
# ERROR CODES;
declare -r E_BAD_PATH=1
declare -r E_INVAILED_ARGU=2
declare -r E_NOT_SVN_DIR=3
 
 
#TODO 屏蔽一些dir 还没写哈
# TODO other way get path not with / end
getpath()
{
#debug
#echo dir_name: ${dir_name}
#echo base_name: ${base_name}
if [ $dir_name == "/" ] || [ $base_name == "/" ]; then
work_path="/"
else
work_path=${dir_name}/${base_name}
fi
}
 
statistic_codelines()
{
if [ -z "$1" ]; then
echo "ERROR statistic_codelines not argument"
return
fi
local pwd_length=${#PWD}
echo "--------------------------"
echo "${PWD}"
for coder in $CODER_LIST; do
local num=$(echo "$1" | grep ${coder} | wc -l)
(( ${coder} += num ))
if [ $num -ne 0 ]; then
printf "%10s | %-7dn" ${coder} $num
fi
done
echo "--------------------------"
}
 
 
# init check argument set work_path
init_work_path()
{
if [ $# -eq 1 ]; then
if [ $1 == "-h" ]; then # is help
echo -e "$USAGE"
elif [ -d $1 ]; then
dir_name=$(dirname ${1})
base_name=$(basename ${1})
getpath;
else
echo -e "An invailed argument"
echo -e "Use -h get help."
exit $E_INVAILED_ARGU
fi
fi
}
 
# check work_path
check_work_path()
{
if [ -z $work_path ] || [ ! -d $work_path ]; then
exit $E_BADPATH;
fi
}
 
# enter work_path
enter_work_path()
{
cd ${work_path}
if [ ! $? ]; then
echo "Can not enter ${work_path} "
fi
}
 
# check work_pat is a svn dir
is_svn_dir()
{
(
# check if current dir is asvn dir
svn info &> /dev/null
exit $?
)
return $?
}
 
action()
{
local dir_name=.
local base_name=
local work_path=$dir_name
 
init_work_path $1
check_work_path
enter_work_path #todo can't enter
 
#echo "NOW DIR: $PWD, OLD DIR $OLDPWD"
is_svn_dir
#todo to next dir
local ret=$?
if [ $ret -ne 0 ]
then
echo -e "Current dir "${work_path}" not a svn dir."
exit $E_NOT_SVN_DIR
fi
 
# get source files
local files=$(ls ${FILES_TYPE} 2> /dev/null)
 
if [ -n "$files" ]; then
local namelist=$(echo -n ${files} | xargs -n 1 svn blame | awk '{print $2}')
#svn blame $files #| grep $1 | wc -l
statistic_codelines "$namelist"
fi
 
local sub_dirs=$(find -maxdepth 1 -type d -name "[^.]*" 2>/dev/null)
 
if [ -n "$sub_dirs" ]; then
for dir in $sub_dirs ; do
action "$dir"
done
fi
 
cd ..
}
 
total()
{
echo "-------- TOTOAL ----------"
echo " NAME | lines "
echo "--------------------------"
for coder in $CODER_LIST; do
if [ ${!coder} -ne 0 ]; then
printf "%10s | %-7dn" ${coder} ${!coder}
fi
done
echo "--------------------------"
}
 
# main
echo "-----开始统计,请耐心等待.... :) "
action $1
total
 
exit 0

时间: 2024-09-24 10:05:04

Shell脚本实现的基于SVN的代码提交量统计工具的相关文章

Shell脚本实现的基于SVN的代码提交量统计工具_linux shell

最近没啥事,就用bash写了一个基于svn的代码统计小工具. 可以指定统计的目录,默认递归统计子目录. 目前还没有屏蔽指定目录的功能.哈 代码比较粗糙.不过先晒出来. #!/bin/bash - #""""""""""""""""""""""""""

Shell脚本实现的阳历转农历代码分享_linux shell

闲来无事,想在Linux下用shell写一个阳历转农历的脚本,断断续续大概一个星期终于搞定.现在拿出来与大家分享. 1.缘由 本脚本实现原理是查表法(因为公式有误差):基于农历新年为基准,对农历新年前后两个不同的农历进行计算. 写这个脚本之前是想在Linux 终端命令提示符中加入阳历及农历日期.在Ubuntu中有Lunar软件可以获取农历日期,但在Fedora或CentOS中并没有类似软件,所以就想自己来实现一个,但网上用其他语言写的一大把,如果再写没什么必要.所以就想用shell来写一个. 2

Shell脚本批量修改文件后缀名代码分享_linux shell

早上本想将一些照片上传到相册中,但是由于所有照片的扩展名都是JPG而不是小写的jpg,因此造成了"格式不正确"而不能上传照片.此刻就产生了这样一个问题:使用shell脚本如何批量将所有文件的扩展名JPG都改成小写的jpg? 既然要批量替换文件名,那么肯定得用一个for循环依次遍历指定目录下的每个文件.对于每个文件,假如该文件的名称为name.oldext,那么我们必须原始文件名中挖出name,再将它与新的文件扩展名newext拼接形成新的文件名name.newext.依照这样的思路,就

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

最近搭建的svn服务不知道什么原因服务总是被关闭(如果你不知道怎么搭建svn可以参考linux下搭建svn版本控制软件),因此用shell脚本实现一个守护进程.用于监控svn服务是否启动,如果服务不在则启动. 创建监控脚本svnmonit.sh #! /bin/sh #进程名字可修改 PRO_NAME=svnserve PORT=58652 REP_DIR=/www/svndata while true ; do #用ps获取$PRO_NAME进程数量 NUM=`ps aux | grep ${

Java正则表达式(三)、代码量统计工具(统计java源文件中注释、代码、空白行数量)

       比如想统计一个Java程序员一天写代码的工作量(如:有效代码多少行.空行多少.注释多少行等),这个小工具也许能做为一个参考的依据.     思路:因为每个java源文件的内容基本包括java语句.空白行.注释三部份组成(不包括注解),所以要统计某个文件这三部份的内容各占多少时,只需写三个匹配这几部份内容的正则表达式即可.然后通过IO流读取文件中的每一行,并根据正则匹配的结果,累加每部份匹配的数量即可.     注释行:单行注释(//).多行注释.文档注释.正则:((//)|(/\\

详解Linux交互式shell脚本中创建对话框实例教程

当你在终端环境下安装新的软件时,你可以经常看到信息对话框弹出,需要你的输入.对话框的类型有密码箱,检查表,菜单,等等.他们可以引导你以一种直观的方式输入必要的信息,使用这样的用户友好的对话框的好处是显而易见的.如下图所示:     当你写一个交互式shell脚本,你可以使用这样的对话框来接受用户的输入.whiptail可以在shell脚本中创建基于终端的对话框,消息框的过程,类似于Zenity或xdialog GUI脚本代码.预先安装在所有的Linux发布版本中. 下面来看看whiptail的用

将PHP作为Shell脚本语言使用_php基础

我们都知道,PHP是一种非常好的动态网页开发语言(速度飞快,开发周期短--).但是只有很少数的人意识到PHP也可以很好的作为编写Shell脚本的语言,当PHP作为编写Shell脚本的语言时,他并没有Perl或者Bash那么强大,但是他却有着很好的优势,特别是对于我这种熟悉PHP但是不怎么熟悉Perl的人. 要使用PHP作为Shell脚本语言,你必须将PHP作为二进制的CGI编译,而不是Apache模式:编译成为二进制CGI模式运行的PHP有一些安全性的问题,关于解决的方法可以参见PHP手册(ht

Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例_node.js

每种语言都有自己的优势,互相结合起来各取所长程序执行起来效率更高或者说哪种实现方式较简单就用哪个,nodejs是利用子进程来调用系统命令或者文件,文档见http://nodejs.org/api/child_process.html,NodeJS子进程提供了与系统交互的重要接口,其主要API有: 标准输入.标准输出及标准错误输出的接口.   NodeJS 子进程提供了与系统交互的重要接口,其主要 API 有:   标准输入.标准输出及标准错误输出的接口 child.stdin 获取标准输入 ch

linux中shell脚本监控网站80端口与网站是否正常

监控网站80端口 很多时候我们不知道网站80端口是否正常,当然我以前的shell监控网站状态(续)这篇文章也可以监控网站,这里只是给大家提供另外一个思路去监控网站. 脚本内容:  代码如下 复制代码 vi check-80.sh #!/bin/bash nmap -P0 -p80 -sS -vv blog.slogra.com|grep 80 |tail -n1>/tmp/nmap.txt check_80=`cat /tmp/nmap.txt|awk '{print $2}'` if [ &quo