svn分支管理以及增量更新_第1頁
svn分支管理以及增量更新_第2頁
svn分支管理以及增量更新_第3頁
svn分支管理以及增量更新_第4頁
svn分支管理以及增量更新_第5頁
免費(fèi)預(yù)覽已結(jié)束,剩余13頁可下載查看

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、svn分支管理與增量更新 項(xiàng)目中經(jīng)常出現(xiàn)需求優(yōu)先級(jí)和進(jìn)度不同產(chǎn)生的代碼混亂,決該問題實(shí)施 svn 分支管理和增量更新。 使用環(huán)境:MyEclipseEnterpriseWorkbenchVersion:2014 svn分支管理 使用分支最主要的目的是,多個(gè)分支可以并行,相互不干擾,而且任何時(shí)候都可以合并。其 次,容易保證主干的穩(wěn)定性。 1.創(chuàng)建分支 (1)在主干項(xiàng)目右擊-Team-分支標(biāo)記。如圖所示: 無法打出需要的測(cè)試包問題。為解 ,svn插件 next。如圖所示: (3)選擇復(fù)制的版本,一般選擇最新修訂版,就是 HEAD修訂版, 點(diǎn)擊 next。如圖所示: 彈出分支 URL信息編輯框輸入

2、svn:3/sengnon/ land3,紅色部分為分支名稱,點(diǎn)擊 (4)填寫創(chuàng)建分支原因,如需要馬上切換到新分支則勾選切換選項(xiàng) 點(diǎn)擊 finish。如圖: 10復(fù)本(分支/六)I三:回雙 Branch/TagComment Enterthebranch/tagcomment. 埔人分支/標(biāo)懿注程; 若胃麥葭脆* V 選擇以前的;據(jù) A CunflQUiruRrniniuritTemHmtu%口噫L忤復(fù)本為新物濃/標(biāo)記 FinishCancel (5)切換之后結(jié)果如圖: 金島landlgengnorvl呂rid3 0費(fèi)src test Rmv.re*;t(6)在分支上修改

3、提交比較等功能與 svn普通操作一致 2.合并分支 (1)項(xiàng)目右擊-Team-切換(s), (2)切換時(shí)會(huì)彈出下圖,默認(rèn)選擇是標(biāo)記本地和要切換的地址內(nèi)容 沖突 Switch 切換至分支/標(biāo)記 Updatetheworkingegpytosnptherrevisknand/c?rlection. 至URL:svn;/l92.168r2.73/sengnon/land1 y:SwitchtoHEADrevision Revision;顯示日于 Depth:Workingcopy /Chargeworkingcopytospecifieddepth |._iIgnoreexternal? _Allo

4、wuriversionedobstructions Ignoreancest7 Conflicthandling: Textfile5: PromptmeforeachconflictandletmedecideqMarkconflicts,letmeresolvethemlater Binary制es: Promptm旺foreachconflictandletmedecideuMarkconflictsletmeresolvethemlater Resolvetheconflictbyusingmyversionofthefile REEOIvetheconflictbyLiningthe

5、inconningverEionofthefile Propertyconflicts; PromptmefcreachconflictndletmedecideoMarkconflicts,letmeresolvtthemlater Treeconflkt5: Promptmefor呼白匚hconflictandletmedecide uMarkconflicts,letmeresolvethemlater RMolvetheconflictuWngfddeofHieronflirt(keepIcealmove?1 MarkMarkresolved(localresolved(localmo

6、veswillmoveswillbecomebecomecopiedcopied CanceJOK (3)點(diǎn)擊 ok,切換成功 Jland!5erqr-T-irdl .Stsrc 由com.land (4)選擇項(xiàng)目-右擊選擇 team-合并 (5) 合 并 方 式 選 擇 , 選 擇mergearangeofrevisions, 去 掉performpre-mergebeatpracticeschecks 默認(rèn)勾選(該默認(rèn)勾選不靈活無法具體指定分支和配置),點(diǎn)擊 next。如圖: CollabNetK/lergeCollabNetK/lerge Mergeinput QMergearangeo

7、frevisio ChangeChange- -setteasedmergesetteasedmerge1 1 Mergetwodifferenttrtes IVl/initllyIVl/initllyrecordinfrrrrriFtirin(recordinfrrrrriFtirin(B B- -lockonpormort=rFlockonpormort=rF- -visionvision;) ) ,Manuallyremovemergeinfcrmatiori(unblockoneormorerevisions rgekrangeofreviiiori? 叵S3 Selectthemer

8、getype Usethismethodtocatch-upmfeaturebranchiiththechangesintrunkoranoth&rbranch.Youcanmergeaspecific5etofrevisionsoraIIeligiblerexdsions. Performpre-merebestprarticeschecks V VZeactZeact L L FinisnFinisn CancelCancel (6)在彈窗中選擇要合并的分支,以及默認(rèn)的所有合適的版本點(diǎn)擊 next。如圖: (7)彈出沖突處理設(shè)置,選擇默認(rèn)的通知我來處理點(diǎn)擊 finish。如 圖: (8)生

9、成合并結(jié)果日志。如圖: |Q|Q|MergeResultsNummaryMergeResultsNummary MergeResultsSummaty Mwrgefaultssummaryfor13ndi Filestatistic5; Updarted:0 Added:0 Exsting:0 0 Merged:0 Conflicts:0 Resolvedconflicts:0 Sldppedfile#0 Skippedfolder5:0 Prop-ert/ststistiC5i Updated:1 Merged:0 Conflits;Q ResolvedconlLcts:0 Cancel 增

10、量更新 1.生成差異文件 生成差異文件必須在提交代碼之前! (1)提交前創(chuàng)建補(bǔ)丁,右擊項(xiàng)目-Team-創(chuàng)建補(bǔ)丁。如圖: (2)設(shè)置創(chuàng)建補(bǔ)丁的配置,選擇保存到文件系統(tǒng)并指定具體的目錄 文件,在 changes 中選擇變更文件,點(diǎn)擊 next。如圖: (3)選擇要比較的根目錄,選擇 project,點(diǎn)擊 finish。如圖: 配置用于SVNd的超3的造項(xiàng) PatchRoot WorkQS(MuH-profectApplyPatchwizardspecific) 篁Project Selection 2.生成增量包 (1)使用這個(gè) Java 代碼來生成一個(gè)更新包。在 Java 類中需根據(jù)本 地情況修

11、改patchFile,projectPath,webContent,classPath,desPath。 packagemy.test; importjava.io.BufferedInputStream; importjava.io.BufferedOutputStream; importjava.io.BufferedReader; importjava.io.File; importjava.io.FileInputStream; importjava.io.FileOutputStream;BackBack FinihFinih CanceiCancei java.io.IOExcep

12、tion; java.io.InputStreamReader; java.text.SimpleDateFormat; java.util.ArrayList; java.util.Date; java.util.List; /* *paramargs * *throwsException */ publicstaticvoidgetversion()SimpleDateFormatdf=newSimpleDateFormat(yyyyMMddHHmmss);/設(shè) 置 日期格式version=df.format(newDate(); System.out.println(df.format(

13、newDate();/newDate()為 獲取當(dāng)前索統(tǒng)時(shí)間 importimportimportimportimportimport public classDeployAddTest publicstaticString patchFile=D:/patch.txt;/補(bǔ)丁文件,由 eclipsesvnplugin ,生成 publicstatic 目文件夾路徑 String projectPath=F:/wk20170221/land1;/項(xiàng) public static String webContent=WebRoot;/web應(yīng)用文件夾名 publicclassPaths存放路徑 s

14、tatic String =F:/wk20170221/land1/WebRoot/WEB-INF/classes ;/clas public staticString desPath=D:/deploy;/補(bǔ)丁文件包存放路徑 public staticString version;/補(bǔ)丁版本 */ publicstatic void main(String口args) throwsException getversion(); copyFiles(getPatchFileList (); /* * 根據(jù)時(shí)間生成版本號(hào) /* *獲取svn補(bǔ)丁文件中的變更文件列表 * */publicstati

15、cListgetPatchFileList()throws Exception ListfileList=newArrayList(); FileInputStreamf=newFileInputStream(patchFile); BufferedReaderdr=_newBufferedReader(new InputStreamReader(f,utf-8); Stringline; /根據(jù)文件中的index有效文件和版本來過濾哪些是需要打在增量包里面的文件 while(line=dr.readLine()!=null) if(line.indexOf(Index:)!=-1) line

16、=line.replaceAll(,); line=line.substring(line.indexOf(:)+1,line.length(); if(line.length()1) fileList.add(line); returnfileList; /找到變更文件列表根據(jù)路徑復(fù)制對(duì)應(yīng)class文件到更新文件夾 publicstaticvoidcopyFiles(Listlist) for(StringfullFileName:list)if(fullFileName.indexOf(src/)!=-1)/對(duì)源文件目錄下的文件處理 StringfileName=fullFileName.

17、replace(src,); fullFileName=classPath+fileName; if(fileName.endsWith(.java)fileName=fileName.replace(.java,.class); fullFileName=fullFileName.replace(.java,.class); )String tempDesPath=fileName.substring(0,fileName.lastIndexOf(/); StringdesFilePathStr=desPath+/+version+/+webContent+/WEB-INF/classes+

18、tempDesPath;StringdesFileNameStr=desPath+/+version+/+webContent+/WEB-INF/classes+fileName;FiledesFilePath=newFile(desFilePathStr); if(!desFilePath.exists()desFilePath.mkdirs(); ) copyFile(fullFileName,desFileNameStr); System.out.println(fullFileName+復(fù)制完成); else/對(duì)普通目錄的處理String desFileName=fullFileNam

19、e.replaceAll(webContent,);fullFileName=projectPath+/+fullFileName;/將要 復(fù)制的文件全路徑 StringfullDesFileNameStr=desPath+/+version+/+webContent+/+desFileName; String desFilePathStr=fullDesFileNameStr.substring(0,fullDesFileNameStr.lastIndexOf(/);FiledesFilePath=newFile(desFilePathStr); if(!desFilePath.exists()desFilePath.mkdirs();copyFile(fullFileName,fullDesFileNameStr); System.out.println(fullDesFileNameStr+復(fù)制完成 ); voidcopyFile(StringsourceFileNameStr, newFile(sourceFileNameStr); newFile(desFileNameStr);privatestat

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論