Shell腳本實(shí)現(xiàn)C語言代碼行數(shù)統(tǒng)計(jì)
寫了一個(gè)比較粗糙的C語言代碼行數(shù)統(tǒng)計(jì)腳本,目前還有些bug,而且效率也不高。腳本主要就是去除大部分的注釋后統(tǒng)計(jì)行數(shù),相當(dāng)于做了一部分預(yù)處理的工作。下面是代碼:
#!/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" #打印*/所有的結(jié)束行 grep -n '[*]/[[:blank:]]*' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "end.txt" #合并兩個(gè)文件,final.txt里面每行就是/*xx....\n....xx*/這種類型注釋的開始行和起始行號(hào) paste "start.txt" "end.txt" > "final.txt" while read line do #得到起始行 START=`echo "$line" | awk 'BEGIN{FS="\t"}{print $1}'` #得到結(jié)束行 END=`echo "$line" | awk 'BEGIN{FS="\t"}{print $2}'` #這里有一個(gè)bug,如是/*xxxx*/中的/*和*/在同一行出現(xiàn),并且有代碼也在同一行 # printf("hello world\n"); /*打印字符串*/ # /*打印字符串*/ #上面兩種情況的就沒法判斷,希望大家優(yōu)化 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"
腳本只能實(shí)現(xiàn)大概的代碼行數(shù)的統(tǒng)計(jì),不能做到精確統(tǒng)計(jì)!
因?yàn)闆]有做很多的測(cè)試,而且也不排除有些比較少見的注釋我沒考慮到,另外腳本的效率也比較差,用了很多tmp文件。
所以希望大家多提提意見!
相關(guān)文章
Shell腳本實(shí)現(xiàn)C語言代碼行數(shù)統(tǒng)計(jì)
這篇文章主要介紹了Shell腳本實(shí)現(xiàn)C語言代碼行數(shù)統(tǒng)計(jì),本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-05-05查看某時(shí)間段到現(xiàn)在的系統(tǒng)日志的sed命令
查看某時(shí)間段到現(xiàn)在的系統(tǒng)日志的sed命令,需要的朋友可以參考下2013-02-02