Eclipse下使用Subversion | ![]() | ![]() | ![]() |
作者:朱先忠編譯 轉(zhuǎn)自天極http://dev.yesky.com/356/2578856.shtml CVS很酷,但Subversion更酷。然而,如果你在使用Eclipse進(jìn)行開發(fā),那么你可能直到近來才能利用Subversion帶來的優(yōu)點(diǎn) 摘要 CVS很酷,但Subversion更酷。然而,如果你在使用Eclipse進(jìn)行開發(fā),那么你可能直到近來才能利用Subversion帶來的優(yōu)點(diǎn)。隨著Subclipse的發(fā)行,Subversion可能會最終在你的Eclipse IDE環(huán)境充分發(fā)揮其威力而壓倒CVS。 一、SCM和Subversion簡介軟件配置管理(SCM)是管理源碼并保持其安全的良好藝術(shù),它能實(shí)現(xiàn)源碼與其他團(tuán)隊(duì)成員之間保持共享,并且能夠?qū)χ右员Wo(hù)。良好地利用SCM,你能夠容易地跟蹤軟件的發(fā)行和新的開發(fā)分支;這樣以來,可以更為容易地標(biāo)識和修正發(fā)行產(chǎn)品中的錯誤。 其實(shí),有大量的SCM工具可用,既有開源的和也有商業(yè)化的,例如StarTeam,Perforce,BitKeeper和ClearCase。在開源世界里,事實(shí)上的SCM標(biāo)準(zhǔn)是并發(fā)版本管理系統(tǒng)(CVS),它被廣泛應(yīng)用于世界范圍內(nèi)的成百上千的開源和商業(yè)工程。然而,CVS也存在下列許多固有的缺陷,這使得它無法非常完美地適合于現(xiàn)代工程開發(fā): · 實(shí)質(zhì)上針對文本文件的設(shè)計(jì)使得CVS處理二進(jìn)制文件能力比較差。在每一次提交時(shí),二進(jìn)制文件被以整體形式傳輸和存儲,這將帶來帶寬和磁盤空間的浪費(fèi)。 · 在CVS中,你不能移動文件和目錄。你唯一的選擇基本上就是刪除并且重新添加它們,從而失去了整個過程中的所有的文件歷史信息。 · CVS中沒有實(shí)現(xiàn)原子提交的概念。比方說,你要把10個文件提交到服務(wù)器,而該提交操作往往在整個過程的中途停了下來。(這很可能會發(fā)生,如果某人同時(shí)提交一個文件,或甚至如果你的網(wǎng)絡(luò)失敗或你的PC重新啟動的話。)在這種情況下,服務(wù)器將僅記錄下你的修正的一半信息,這可能會使代碼基部分處于一種潛在地不穩(wěn)定的狀態(tài)。 Subversion是一種比較新的開源SCM工具,其設(shè)計(jì)目的是力圖從根本上克服原CVS所具有的限制。它是一種良好設(shè)計(jì)的工具,具有適合于現(xiàn)代開發(fā)的許多新特征: · 提交是原子化的。提交的文件都能夠被正確加入到一個新的修訂當(dāng)中,否則倉庫不會被更新;并且每一個新的修訂僅由一次提交中的變化部分組成。 · Subversion對文本和二進(jìn)制文件使用一種巧妙的二進(jìn)制技術(shù),這既優(yōu)化了網(wǎng)絡(luò)流量也優(yōu)化了倉庫磁盤空間。 · 在Subversion中,每一次修訂都代表了一個特定時(shí)間內(nèi)完整的目錄樹拷貝。文件和目錄可以不加限制地進(jìn)行移動。 · Subversion僅存儲兩個版本之間的修改內(nèi)容,這不僅節(jié)約了磁盤空間,并且意味著標(biāo)識一個新版本或創(chuàng)建一種新的子內(nèi)容幾乎可以立即實(shí)現(xiàn)。 · 你可以以多種途徑來存取一個Subversion倉庫,具體則依賴于你的需要:使用HTTP或HTTPS(與WebDAV一起使用),使用快速的專利性svn:協(xié)議,或直接經(jīng)由本地文件,等等。 二、Subclipse插件與Eclipse的集成 一種良好的SCM應(yīng)該與你的工作環(huán)境緊密地集成到一起。沒有誰真正喜歡轉(zhuǎn)到命令行以把文件添加到倉庫。Eclipse很早就實(shí)現(xiàn)了CVS集成,但是直到最近Subversion用戶仍沒有被引起重視?,F(xiàn)在,新的Subclipse插件提供了在Eclipse中的一種平滑的Subversion集成。 (一) 安裝Subclipse插件 下面,你以通常的方法從更新站點(diǎn)下安裝Subclipse: 1. 打開"Find and install"窗口("Help>Software Updates>Find and Install")。 2. 選擇"Search for new features to install"選項(xiàng)并點(diǎn)擊Next。 3. 點(diǎn)擊"New Remote Site"并且創(chuàng)建一遠(yuǎn)程站點(diǎn),使用名字Subclipse和URL http://subclipse.tigris.org/update_1.0.x(參考圖1)。 4. 在結(jié)果安裝窗口中,把"Subeclipse in the Features"選擇到安裝列表中,并且通過向?qū)黹_始安裝插件。 5. 完成這些之后,重新啟動Eclipse?,F(xiàn)在,你可以繼續(xù)往下進(jìn)行!
(二) 建立Repository定義 現(xiàn)在,既然你已經(jīng)安裝完插件;那么,接下來,你需要告訴它你的工程倉庫位于何處。你是在SVN Repository視圖中實(shí)現(xiàn)的。打開這個視圖("Windows>Show View>Other>SVN Repository")并且在上下文菜單中選擇"New>Repository Location"以顯示一個如圖2所示的對話框。輸入適當(dāng)?shù)腢RL并且點(diǎn)擊"Finish"。
![]() 圖3.SVN Repository視圖。
三、在Eclipse中使用Subversion 現(xiàn)在,既然你的支持Subversion的工程已經(jīng)啟動并且運(yùn)行起來,那么大多數(shù)必要的Subversion命令就可經(jīng)由"Team"上下文菜單存取(參考圖5)。你可以在Package Explorer中看到你的本地文件的狀態(tài)(參考圖6),其中,任何修改了的文件都被標(biāo)記上一個星號。存儲在倉庫中的文件都顯示一個小黃桶圖標(biāo)(代表了一個數(shù)據(jù)庫);還沒有被添加到倉庫中的文件以一個問號顯示。
(一) 與Repository保持同步 從倉庫中更新你的文件并且把你的變化提交到倉庫是相當(dāng)直接的過程,這可以使用"Team>Update and Team>Commit"菜單選項(xiàng)來實(shí)現(xiàn)。在提交你的變化之前,你可能想看一下自從你的上次更新以來是否服務(wù)器上有任何文件被修改。為此,你可以使用"Team >Synchronize with Repository"。這個命令讓你看到有哪些內(nèi)容已經(jīng)被局部地修改,有哪些內(nèi)容在服務(wù)器上修改,以及這兩種修改之間的任何沖突(參考圖7)。你還可以以可視化方式看到?jīng)_突的版本,并且在提交你的變化之前糾正任何比較突出的沖突。
(二) 使用屬性 屬性是Subversion具有創(chuàng)新性的特征之一。在Subversion中,你可以把元數(shù)據(jù)("properties")關(guān)聯(lián)到任何文件或目錄。你可以定義任何你喜歡的屬性,但是Subversion也提供了一些有用的內(nèi)置屬性,例如下面圖8中所提供的這些屬性: · svn:executable屬性,允許你在支持這種能力的操作系統(tǒng)上設(shè)置一個文件的可執(zhí)行標(biāo)志。 · svn:need-lock屬性,可以用來在文件(例如,對二進(jìn)制文件非常有用)上強(qiáng)加排斥鎖。一個定義了svn:need-lock屬性的文件一次只能被一個人修改。當(dāng)該文件被檢出時(shí),它是只讀的。如果你想修改該文件,你需要首先使用"Team>Lock"菜單選項(xiàng)。之后,使用"Team>Unlock"釋放該文件,或僅提交你的變化。這一行為將釋放該鎖并且讓其它的用戶也得到該文件上的一把鎖。
三) Tag和Branch 在Subversion中,很容易創(chuàng)建新的tag和branch。你可以使用tag來標(biāo)識一個特定的版本(使用一種可讀的名字,例如"Release 1.0")。;而一個branch用于新的開發(fā)工作而不影響主源碼基(稱作trunk)。在一個branch上的開發(fā)仍會繼續(xù)進(jìn)行,直到開發(fā)者已經(jīng)為把變化集成回主trunk作好準(zhǔn)備。 在Subversion中,branch和tag都是通過制作給定修訂的一個虛擬副本(以另一個名字和/或另一個目錄)創(chuàng)建的。在常規(guī)情況下,branch存儲在branches目錄下,tag位于tags目錄下,盡管在實(shí)踐中為了滿足你的工程你可以使用自己的任何定制。 從Eclipse中,"Team>Branch/Tag"菜單能夠使你創(chuàng)建branch和tag(參考圖9)。其中,Browse按鈕提供了一種方便的方法來查看有哪些branch和tag存在于倉庫中。 當(dāng)你使用"Team>Switch"創(chuàng)建成功一個新的branch或tag時(shí),你可以非常容易地在branches之間進(jìn)行切換。無論何時(shí)你切換到一個不同的branch(或返回到trunk),Subversion將僅更新文件(它需要保持你的當(dāng)前工作的副本與目的branch之間的同步)。
(四) 修訂歷史 象大多數(shù)SCM系統(tǒng)一樣,Subversion讓你跟蹤你的源碼的變化。"Team>Show in Resource History"菜單選項(xiàng)能夠使你查詢這些變化的列表(包括對一個文件,目錄或甚至整個工程的改變)(見圖10)。 記住,在Subversion中,提交是原子性的-一次提交由一組文件變化和一個全局注釋組成。"SVN Resource History"視圖向你顯示每一次提交的一個簡明視圖,包括修改的文件和相關(guān)注釋。
四、結(jié)論 Subversion是一種強(qiáng)有力的和非常靈活的SCM工具,也是CVS的一個成功的后繼者。結(jié)合Subclipse,Subversion能最終在你的Eclipse IDE環(huán)境中得到全面的發(fā)揮。
|