iOS使用OCLint做靜態(tài)代碼分析

初識(shí)OCLint

OCLint是一個(gè)靜態(tài)代碼分析工具,提高質(zhì)量和減少缺陷通過(guò)檢查C 履澳、C++ 和Objective-C 代碼和尋找潛在的問(wèn)題,如:

  • 可能的缺陷 - 空的if / else / try / catch / finally語(yǔ)句
  • 未使用的代碼 - 未使用的局部變量和參數(shù)
  • 復(fù)雜的代碼 - 很高的圈復(fù)雜度,NPath復(fù)雜性和太高的NCSS
  • 代碼異味 - 長(zhǎng)方法和參數(shù)列表
  • 長(zhǎng)方法和參數(shù)列表不好的實(shí)踐——倒邏輯和參數(shù)重新分配

  • 靜態(tài)代碼分析是一個(gè)來(lái)檢測(cè)對(duì)于編譯不可見(jiàn)的缺陷的關(guān)鍵技術(shù)怀跛。

注:* NPath 復(fù)雜度是一個(gè)方法中各種可能的執(zhí)行路徑總和 吻谋; NCSS * 有效代碼行
以上翻譯自OCLint官網(wǎng)

安裝

使用第三方的軟件會(huì)比使用xcodebuild方便些
最新xctool的build方法已經(jīng)棄用,不能配合OCLint使用阁最,推薦使用xcpretty

// 安裝OCLint
brew tap oclint/formulae
brew install oclint
// 安裝xcpretty
gem install xcpretty

如果未安裝home brew骇两,自行去官網(wǎng)按提示安裝

更新

// 以后可能需要更新
brew update
brew upgrade oclint

使用

在終端進(jìn)入項(xiàng)目目錄,然后替換workspace的名字和scheme的名字配阵,將修改好的命令粘貼到終端執(zhí)行,等待命令執(zhí)行完畢

myworkspace=haha.xcworkspace # 替換workspace的名字
myscheme=haha # 替換scheme的名字
xcodebuild -workspace $myworkspace -scheme $myscheme clean&&
xcodebuild -workspace $myworkspace -scheme $myscheme \
-configuration Debug \
| xcpretty -r json-compilation-database -o compile_commands.json&&
oclint-json-compilation-database -e Pods -- \
-report-type html -o oclint_result.html \
-rc LONG_LINE=200 \
-max-priority-1=100000 \
-max-priority-2=100000 \
-max-priority-3=100000; \
rm compile_commands.json;
if [ -f ./oclint_result.html ]; then echo '-----分析完畢-----'
else echo "-----分析失敗-----"; fi

中間可能會(huì)在Build Succeeded后面等待一段時(shí)間救拉,這是因?yàn)镺CLint在分析文件
等待命令執(zhí)行完成瘫拣,終端會(huì)打印出-----分析完畢-----字樣拂铡,
打開(kāi)項(xiàng)目目錄葱绒,會(huì)看到目錄下會(huì)多出一個(gè)** oclint_result.html **的文件

如果沒(méi)有使用cocoapods,則去掉myworkspace=haha.xcworkspace失球、-workspace $myworkspace帮毁、-workspace $myworkspace,然后再在終端執(zhí)行
另外可以自己建一個(gè)xx.sh的文件黔牵,將上面代碼粘貼進(jìn)去爷肝,每次在命令行進(jìn)入xx.sh所在目錄執(zhí)行bash xx.sh就可以了

查看

雙擊打開(kāi)oclint_result.html文件,樣式如下
OCLint的分析結(jié)果:
優(yōu)先級(jí)的級(jí)別是從Priority 1, Priority 2, Priority 3 依次降低的
Total Files 總文件數(shù)
Files with Violations 違規(guī)文件數(shù)
Compiler Warnings 表示項(xiàng)目中的警告??
Compiler Errors 表示編譯錯(cuò)誤
Location 表示警告的位置
報(bào)告中的描述其實(shí)非常清晰金赦,一般找到代碼位置对嚼,結(jié)合代碼理解下纵竖,自己基本都能明白了
可以直接復(fù)制路徑到Chrome打開(kāi)查看,右擊查看源碼就有行號(hào)

Paste_Image.png

自定義規(guī)則

上面的命令中
-e Pods 表示移除Pods文件夾里代碼的分析, 如果有繼續(xù)-e Debug.m
-report-type html 表示分析后輸出的文件類型為HTML沽甥,查看其他支持的文件類型
-o oclint_result.html 表示輸出到oclint_result.html這個(gè)文件中()
-rc LONG_LINE=200 表示每行最大字節(jié)長(zhǎng)度為200(默認(rèn)值為100乏奥,感覺(jué)在OC中100完全不夠用啊)

一些常用規(guī)則的注釋
# --命名
# 變量名字最長(zhǎng)字節(jié)
#-rc=LONG_VARIABLE_NAME=20 \
# 變量名字最短字節(jié)
#-disable-rule ShortVariableName \
# --size
# 圈復(fù)雜度
#-re=CYCLOMATIC_COMPLEXITY=10 \
# 每個(gè)類最行數(shù)
#-rc=LONG_CLASS=700 \
# 每行字節(jié)數(shù)量
#-rc=LONG_LINE=200 \
# 每個(gè)方法行數(shù)
#-rc=LONG_METHOD=80 \
# 忽略注釋后括號(hào)后的有效代碼行數(shù)
#-rc=NCSS_METHOD=40 \
# 嵌套深度
#-rc=NESTED_BLOCK_DEPTH=5 \
# 字段數(shù)量
#-rc=TOO_MANY_FIELDS=20 \
# 方法數(shù)量
#-rc=TOO_MANY_METHODS=30 \
# 方法參數(shù)
#-rc=TOO_MANY_PARAMETERS=6

oclint-json-compilation-database命令手冊(cè)
oclint命令手冊(cè)
OCLint自定義規(guī)則介紹
OCLint全部規(guī)則介紹
文檔里面有每個(gè)規(guī)則的demo和對(duì)應(yīng)的命令名字媳瞪,上面沒(méi)介紹到的大家可以去文檔查詢

Xcode集成OCLint

這里有官網(wǎng)指導(dǎo)網(wǎng)址照宝,十分簡(jiǎn)單
http://oclint-docs.readthedocs.io/en/stable/guide/xcode.html
但是有點(diǎn)小坑:可能出現(xiàn)下面錯(cuò)誤

in `===': invalid byte sequence in US-ASCII

此時(shí)你需要在xcode的腳本的最前面,加上:

# 指定編碼
export LANG="zh_CN.UTF-8"
export LC_COLLATE="zh_CN.UTF-8"
export LC_CTYPE="zh_CN.UTF-8"
export LC_MESSAGES="zh_CN.UTF-8"
export LC_MONETARY="zh_CN.UTF-8"
export LC_NUMERIC="zh_CN.UTF-8"
export LC_TIME="zh_CN.UTF-8"
export LC_ALL=

我寫了一個(gè)簡(jiǎn)單的腳本文件oclint_xcode大家可以自己下載兢仰,可替換的變量剂碴,已經(jīng)在腳本中使用注釋標(biāo)注了出來(lái)

創(chuàng)建一個(gè)OCLint的Aggregate忆矛,將腳本放到項(xiàng)目工程根目錄下,在Run Script中加入以下代碼洽议,點(diǎn)擊運(yùn)行即可

bash ./oclint.sh

Jenkins集成OCLint

1. 創(chuàng)建一個(gè)PMDOclint.sh的文件, 將下述代碼拷貝到文件中漫拭,并將文件放入到j(luò)enkins的根目錄下 (例如我的就是/Users/buildWork/.jenkins/PMDOclint.sh) , 我自己使用的腳本放到了倉(cāng)庫(kù)中oclint_apply,可以去里面下載apply_jenkins/PMDOclint.sh
2. jenkins需要安裝PMD Plugin插件
3. jenkins新建一個(gè)項(xiàng)目儿捧,Git配置成需要代碼分析的代碼庫(kù)
4. 剩下的按照下圖配置挑宠,(將PMDOclint.sh放到Jenkins的主目錄,如果出現(xiàn)問(wèn)題懒鉴,涉及到的路徑碎浇,請(qǐng)注意檢查一下)
QQ20170628-170241.png
5. 效果
效果圖


Warning??

(一). xcodebuild命令不好用的時(shí)候奴璃,使用com + opt + shift + kcom + shift + k 有80%的可能解決??
(二). oclint: error: one compiler command contains multiple jobs:
解決方案:

1. 如果電腦里面安裝了兩個(gè)Xcode的話可能會(huì)報(bào)上面錯(cuò)誤苟穆,刪掉其他只剩一個(gè)
xcode9以后(OCLint version 0.13, Version 9.2 beta (9C34b) 測(cè)試可用):
2.1 更新到最新的oclint, brew upgrade oclint
2.2 去github下載最新的oclint.sh唱星,替換掉舊的
3. 試試手動(dòng)將 工程=> Build Settings => 搜索COMPILER_INDEX_STORE_ENABLE 該配置設(shè)成NO



oclint_apply倉(cāng)庫(kù)地址

參考文章:

用OCLint給iOS代碼做靜態(tài)分析
OCLint 規(guī)則與結(jié)果分析

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末间聊,一起剝皮案震驚了整個(gè)濱河市抵拘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尚蝌,老刑警劉巖充尉,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喉酌,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡泪电,警方通過(guò)查閱死者的電腦和手機(jī)纪铺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門鲜锚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人旺隙,你說(shuō)我怎么就攤上這事骏令。” “怎么了周拐?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵凰兑,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我勾给,道長(zhǎng),這世上最難降的妖魔是什么露泊? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任旅择,我火速辦了婚禮生真,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘柱蟀。我一直安慰自己,他們只是感情好畜眨,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布康聂。 她就那樣靜靜地躺著胞四,像睡著了一般。 火紅的嫁衣襯著肌膚如雪氓侧。 梳的紋絲不亂的頭發(fā)上导狡,一...
    開(kāi)封第一講書(shū)人閱讀 51,624評(píng)論 1 305
  • 那天旱捧,我揣著相機(jī)與錄音,去河邊找鬼廊佩。 笑死,一個(gè)胖子當(dāng)著我的面吹牛顽铸,可吹牛的內(nèi)容都是我干的料皇。 我是一名探鬼主播星压,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼娜膘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼优质!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起演怎,我...
    開(kāi)封第一講書(shū)人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤爷耀,失蹤者是張志新(化名)和其女友劉穎拍皮,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體铆帽,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡锄贼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年宅荤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了浸策。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惫确,死狀恐怖蚯舱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情陈肛,我是刑警寧澤兄裂,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布阳藻,位于F島的核電站腥泥,受9級(jí)特大地震影響啃匿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜立宜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一橙数、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧崖技,春花似錦钟哥、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)播演。三九已至冀瓦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間写烤,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工洲炊, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留感局,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓询微,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親隧膘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 寫在前面 剛?cè)肼毜臅r(shí)候,博哥交代給我一個(gè)任務(wù)艇肴,讓我調(diào)研一款叫SonarQube的靜態(tài)代碼分析工具叁温,我當(dāng)時(shí)跪在了Ce...
    雨潤(rùn)聽(tīng)潮閱讀 2,271評(píng)論 0 5
  • Code Review 代碼評(píng)審冲九,代碼靜態(tài)檢查,Objective-C代碼靜態(tài)檢查工具——OCLint Githu...
    BobWongs閱讀 3,295評(píng)論 0 4
  • WebSocket-Swift Starscream的使用 WebSocket 是 HTML5 一種新的協(xié)議冀宴。它實(shí)...
    香橙柚子閱讀 23,869評(píng)論 8 183
  • 感賞兒子學(xué)習(xí)認(rèn)真努力逃延,成績(jī)進(jìn)步明顯紧帕。 晚上打游戲時(shí)間超十分鐘,我又在一旁嘮叨數(shù)落他站绪,兒子又哭了魂挂,說(shuō)他知道會(huì)把控自己...
    吳若閱讀 124評(píng)論 0 0
  • 七月的每一天果正,就像發(fā)燒裹在被子里一樣度過(guò)秋泳,終于見(jiàn)識(shí)到了揮汗如雨這個(gè)成語(yǔ)的威力攒菠。每一次的呼吸要尔,都能體會(huì)到空氣中的...
    奶疙兒瘩閱讀 353評(píng)論 0 0