程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言代碼行數統計bash實現

C語言代碼行數統計bash實現

編輯:關於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"


作者:firefoxbug

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved