Shell脚本实现C语言代码行数统计
写了一个比较粗糙的C语言代码行数统计脚本,目前还有些bug,而且效率也不高。脚本主要就是去除大部分的注释后统计行数,相当于做了一部分预处理的工作。下面是代码:
#!/bin/bash
filename=$1
echo "`whoami`"
if [ $# -lt 1 ];then
echo "usage : ./scripts filename"
exit -1
fi
if [ ! -f $filename ];then
echo "$filename is not a file"
exit 0;
fi
user="`whoami`"
if [ "$user" != "root" ];then
echo "use scripts with root"
exit 0;
fi
#删除空行,空行包括:tables + space
sed '/^[[:blank:]]*$/d' $filename > "${filename}_backup"
#删除 // 所在的行
sed -i '/^[[:blank:]]*\/\//d' "${filename}_backup"
#/*xxxxx*/
#打印/*所有的开始行
grep -n '[[:blank:]]*/[*]' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "start.txt"
#打印*/所有的结束行
grep -n '[*]/[[:blank:]]*' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "end.txt"
#合并两个文件,final.txt里面每行就是/*xx....\n....xx*/这种类型注释的开始行和起始行号
paste "start.txt" "end.txt" > "final.txt"
while read line
do
#得到起始行
START=`echo "$line" | awk 'BEGIN{FS="\t"}{print $1}'`
#得到结束行
END=`echo "$line" | awk 'BEGIN{FS="\t"}{print $2}'`
#这里有一个bug,如是/*xxxx*/中的/*和*/在同一行出现,并且有代码也在同一行
# printf("hello world\n"); /*打印字符串*/
# /*打印字符串*/
#上面两种情况的就没法判断,希望大家优化
if [ $START -eq $END ];then
continue
fi
#删除/*到*/中间所有行
sed -i "${START},${END}d" "${filename}_backup"
done < "final.txt"
wc -l "${filename}_backup"
rm -f "final.txt" "start.txt" "end.txt"
脚本只能实现大概的代码行数的统计,不能做到精确统计!
因为没有做很多的测试,而且也不排除有些比较少见的注释我没考虑到,另外脚本的效率也比较差,用了很多tmp文件。
所以希望大家多提提意见!
栏 目:其它服务器
下一篇:Shell、Perl、Python、PHP访问 MySQL 数据库代码实例
本文标题:Shell脚本实现C语言代码行数统计
本文地址:https://zz.feitang.co/server/34920.html
您可能感兴趣的文章
- 01-06nginx从安装到配置详细说明(安装,安全配置,防盗链,动静分离,配置 HTTPS,性能优化)
- 01-06Nginx性能优化之Gzip压缩设置详解(最大程度提高页面打开速度)
- 01-06Linux系统 Centos7.4手动在线升级到Centos7.7
- 01-06详解nginx安装过程并代理下载服务器文件
- 01-06shell脚本根据进程查找指定容器的方法
- 01-06微服务架构拆分策略详解
- 01-06使用 Apache Dubbo 实现远程通信(微服务架构)
- 01-06微服务架构之服务注册与发现功能详解
- 01-06使用Zabbix 5.4.3监控IPMI的方法
- 01-06微服务架构之服务注册与发现实践示例详解






