溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Shell腳本怎么實現C語言代碼行數統計

發布時間:2021-08-02 15:46:28 來源:億速云 閱讀:240 作者:chen 欄目:開發技術

這篇文章主要介紹“Shell腳本怎么實現C語言代碼行數統計”,在日常操作中,相信很多人在Shell腳本怎么實現C語言代碼行數統計問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”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"

腳本只能實現大概的代碼行數的統計,不能做到精確統計!

到此,關于“Shell腳本怎么實現C語言代碼行數統計”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女