每日構(gòu)建(daily build)已經(jīng)不是什么新概念了,它已經(jīng)成為軟件項目的基本活動之一。至于它的好處,已經(jīng)有不少文章和書籍介紹了,這里不再多說了。雖然說,各種軟件開發(fā)都差不多,但在嵌入式軟件開發(fā)的這個領(lǐng)域,似乎對于新的方法和概念的接受要較晚一些。筆者曾呆過的兩家公司,以前都沒有自動構(gòu)建環(huán)境,其它公司的情況則不太清楚。 一方面可能是不知道如何實現(xiàn)自動構(gòu)建環(huán)境; 一方面也可能是工作太忙,大家都懶得到去建立這個環(huán)境,其實這反而浪費了更多的時間。筆者曾在三家公司建立過自動構(gòu)建環(huán)境,這些知識都很簡單,沒有什么值得保密的,只是知與不知的問題,如果你恰巧也在做這方面的工作,或許有點幫助。 1. 實現(xiàn)定時運行的功能。 在win32下,可以按下列步驟建立一個自動運行的任務(wù): 運行我的電腦-->控制面板-->任務(wù)計劃-->添加任務(wù)計劃。 按照提示的步驟輸入相關(guān)信息。 在Linux下,可以用at或cron建立一個自動運行的任務(wù),具體用法可以查看相關(guān)幫助。 2. 實現(xiàn)自動獲取源代碼的功能。目前管理源代碼的工具,數(shù)開源的cvs和微軟的sourcesafe的使用最為廣泛。對于前者,雖然現(xiàn)在也有GUI的客戶端,但在多數(shù)時候,用命令行的cvs反而更地道一點,在腳本中使用cvs的獲取源代碼,不會有什么問題。而后者,大家用慣了GUI的界面,甚至有人沒有聽說過sourcesafe的命令行工具,會用的人更為鮮見。幸運的是,微軟提供了一個叫作ss.exe命令行的工具,這為自動獲取sourcesafe上的源代碼大開方便之門。 3. 實現(xiàn)自動編譯的功能。 a) Makefile的情況。如果使用makefile管理你的工程,自動編譯一點問題也沒有。 b) ADS的情況。如果你使用ADS管理你的工程,你有兩種方法可以選擇。 i. 第一種方法:把mcp轉(zhuǎn)換成Makefile,但ADS本身并不提供這種轉(zhuǎn)換,你需要從網(wǎng)上下載一個mcp2make的小工具。如果你并不是經(jīng)常在工程里的增刪文件,這種方法不錯,否則每次增刪文件后,都要重新產(chǎn)生Makefile,那就比較麻煩了。 ii. 第二種方法:ADS提供了一個叫cmdide的工具,它雖然也是GUI的,但它在編譯過程中,無需用戶介入。它的使用方法很簡單,唯一不爽的就是它的編譯錯誤信息不能保存下來,如果編譯出錯了,你無法知道到底是哪里出錯了。 c) VC的情況。大多數(shù)嵌入式軟件開發(fā)組,都會在VC里建立一套模擬開發(fā)環(huán)境。這樣,在PC上可以運行大部分功能,這將節(jié)省不少調(diào)試時間。自動編譯VC也好幾種方法: i. 第一種方法:從VC工程導(dǎo)出Makefile文件,它的Makefile與gmake是不兼容的,要用微軟提供的nmake才能編譯。 ii. 第二種方法:在腳本中運行MSDEV.EXE,可以指定dsw的名稱和編譯的方式(CLEAN/BUILD/REBUILD),如:MSDEV.EXE c:\temp\t1\t1.dsw /MAKE "t1 - Win32 Debug" /REBUILD iii. 第三種方法:用VC提供的COM接口,調(diào)用VC的編譯功能。 4. 實現(xiàn)自動生成安裝包的功能?,F(xiàn)在大多數(shù)安裝工具都提供腳本控制功能,你只要寫好一個配置文件,它自動生成安裝包。在開發(fā)嵌入式軟件時,常常不需要這些功能,要做的不過是把程序bin文件、資源文件和下載工具等,拷貝到一個目錄下,再把它壓縮一個壓縮文件就行了。 5. 實現(xiàn)自動通知的功能。通知的方式有多種,郵件通知是最為常用的一種。實現(xiàn)很簡單,網(wǎng)上已經(jīng)有一些命令行的郵件工具,可以直接使用?;蛘呦螺d一個SMTP的庫,寫很少的代碼就可以實現(xiàn)一個SMTP的客戶工具。 一般來說,自動構(gòu)建就是以上幾個步驟。有的可能復(fù)雜一些,比如,有的要求,編譯前從指定的位置更新文件,如果編譯成功,則要把這些文件checkin到源代碼管理系統(tǒng)中; 也有的要求,編譯成功后運行自動測試程序。這些功能是輔助性,實施起來難度不大,這里不做詳細(xì)討論。 Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=598988 |
|