statCVS的问题剖析
生活随笔
收集整理的這篇文章主要介紹了
statCVS的问题剖析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
statCVS是一個很好的OPENSOURCE的項目,可以用來生成CVS中代碼修改提交情況的報表。不過我在使用過程中,發現它只能用于主分支(即清除所有粘附位的版本)產生提交歷史和數據統計,如果有基于分支的提交,將被statCVS忽略,并且基于這個原因,也無法對一個分支進行修改統計和代碼分析了。如果對一個分支進行修改分析,因為log都是基于該分支的修改版本,所以基于主分支的修改將為空集合,所以statcvs.jar的執行結果將會出現NULLPointer異常而終止生成報表。 經過主分支和副分支的log文件對比,發現是statCVS的一個bug,因為修改已被統計成非零,而修改細節因為主分支要求零匹配,所以出現計數和元素不相符的情況而導致異常終止。 經過一個不太規范的規避,我們可以繞過這個陷阱,方法如下: 用如下方法取出某個分支(branch_name)的所有提交歷史(工作目錄通常應在本志的項目CVS根目錄下)。 F:\module-path>cvs log -rbranch_name >f:\project.log 用如下方法取出某個時間段的所有提交歷史(工作目錄通常應在本志的項目CVS根目錄下) 2009/5/1 在文本編輯器中,修改文件內容,以規避陷阱: UltraEdit:?正則表達式替換:%revision 1.[0-9.]+$ revision 1.2 意思就是將所以分支提交log換成主分支提交log格式,如 revision 1.2.2.12 --->revision 1.2 這樣就騙過statCVS了,不過也就丟失了提交版本信息了。 ? 接下來可以生成代碼統計報表了(除了提交版本信息全變成1.2): statcvs.jar的兩個參數是log文件,項目cvs本地路徑。output-dir選項為重定向報表HTML文件路徑。 0.5.0
本文轉自 dannyy1026 51CTO博客,原文鏈接: http://blog.51cto.com/dannyyuan/317177
與50位技術專家面對面20年技術見證,附贈技術全景圖
本文轉自 dannyy1026 51CTO博客,原文鏈接: http://blog.51cto.com/dannyyuan/317177
與50位技術專家面對面20年技術見證,附贈技術全景圖
總結
以上是生活随笔為你收集整理的statCVS的问题剖析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在ISA 2006标准版上定制带宽和限制
- 下一篇: perl高水线算法