手机
当前位置:查字典教程网 >脚本专栏 >linuxshell >Shell脚本实现C语言代码行数统计
Shell脚本实现C语言代码行数统计
摘要:写了一个比较粗糙的C语言代码行数统计脚本,目前还有些bug,而且效率也不高。脚本主要就是去除大部分的注释后统计行数,相当于做了一部分预处理的...

写了一个比较粗糙的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 worldn"); /*打印字符串*/ # /*打印字符串*/ #上面两种情况的就没法判断,希望大家优化 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脚本实现C语言代码行数统计】相关文章:

Shell脚本实现删除邮件队列

kill特定进程的shell脚本代码

Shell脚本实现根据端口号kill相应进程功能

shell脚本实现批量测试局域网主机是否在线

Bash Shell脚本学习小结

shell脚本编程之for语句、if语句使用介绍

Shell脚本实现检测进程是否正在运行

Linux shell脚本实现CPU预警

shell脚本运行5秒后自动退出的代码

Shell脚本避免重复执行的方法

精品推荐
分类导航