国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Linux > 正文

Shell腳本實現(xiàn)C語言代碼行數(shù)統(tǒng)計

2019-10-26 18:45:46
字體:
供稿:網(wǎng)友

寫了一個比較粗糙的C語言代碼行數(shù)統(tǒng)計腳本,目前還有些bug,而且效率也不高。腳本主要就是去除大部分的注釋后統(tǒng)計行數(shù),相當于做了一部分預處理的工作。下面是代碼:

#!/bin/bash filename=$1echo "`whoami`"if [ $# -lt 1 ];then echo "usage : ./scripts filename" exit -1fiif [ ! -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 + spacesed '/^[[: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 linedo #得到起始行 START=`echo "$line" | awk 'BEGIN{FS="/t"}{print $1}'` #得到結束行 END=`echo "$line" | awk 'BEGIN{FS="/t"}{print $2}'` #這里有一個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"

腳本只能實現(xiàn)大概的代碼行數(shù)的統(tǒng)計,不能做到精確統(tǒng)計!
因為沒有做很多的測試,而且也不排除有些比較少見的注釋我沒考慮到,另外腳本的效率也比較差,用了很多tmp文件。
所以希望大家多提提意見!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 交城县| 邵阳县| 静安区| 金门县| 南江县| 襄城县| 灵武市| 玉树县| 马边| 天镇县| 来安县| 万年县| 库伦旗| 方山县| 台北市| 尼勒克县| 武强县| 宝兴县| 巴东县| 辽宁省| 曲松县| 利川市| 刚察县| 密山市| 琼中| 永年县| 康保县| 星座| 大庆市| 广宗县| 怀仁县| 六安市| 无锡市| 江都市| 恩施市| 静海县| 菏泽市| 文登市| 万年县| 沂南县| 常山县|