在實際項目中(特別是作為產品的項目),版本號是必不可少的一部分。版本號的規則也有許多種,在此不討論具體的編碼規范。對於迭代的產品,版本繁多,特別是有多個實施項目所使用產品的版本不同(基於定制需求)時,清楚的標識組件與代碼的對應關系十分重要。
本文主要說明如何在 .Net 項目使用 SVN 作為版本控制工具時生成與代碼對應的組件版本號。
我們知道,SVN 在 commit 時會生成一串數字作為序號,所以基本思路是把這個序號作為 . Net 項目編譯后生成dll的文件版本號的最后一段。下面所列方法需要使用到TortoiseSVN 提供的 SubWCRev.exe 。
首先,我們需要通過注冊表查找 TortoiseSVN 的安裝目錄。

1 Rem Search TSVN Path 2 For /f "tokens=*" %%i In ('Reg Query HKLM\Software\TortoiseSVN /v Directory') Do ( 3 ECHO %%i | Find "Directory">NUL 4 IF %ERRORLEVEL% == 0 (For /f "tokens=1,2,*" %%j In ("%%i") Do (SET TSVN_PATH=%%1)) 5 ) 6 SET TSVN_PATH=%TSVN_PATH%bin\SubWCRev.exe
SubWCRev 是通過替換文件中指定的關鍵字來實現獲得 commit 序號的,點擊查看詳細的列表。
然后我們建立以一個 AssemblyInfo.tpl 作為替換使用的模板,由於 AssemblyInfo.cs 中除了固定的值外還有類似 GUID 變化的值,所以我們不能全部替換,因此僅將需要修改的部分放在 tpl 中,內容如下:
[assembly: AssemblyVersion("1.0.0.0")] [assembly: AssemblyFileVersion("1.0.0.$WCREV$")]
接下來使用批處理替換原來的 AssemblyInfo.cs 文件,為了在每次編譯時都自動替換,我們把調用批處理的命令寫在項目生成事件的生成前事件中,例如下面這樣:
"$(TargetDir)BeforeBuildProject.bat" "$(ProjectDir)" "$(TargetDir)AssemblyInfo.tpl" .\Properties\AssemblyInfo.cs
$(TargetDir)表示編譯輸出目錄,更多可用全局變量請在生成事件中點擊“宏”查看。
替換 AssemblyInfo.cs 的批處理代碼:

1 SET WorkDir=%1 2 SET Template=%2 3 SET target=%3 4 SET AssemblyInfo=ASSEMBLY_INFO.tmp 5 6 PushD %WorkDir% 7 SET WorkDir=.\ 8 9 Rem Generate a template file 10 FindStr /v "AssemblyVersion AssemblyFileVersion" %target% > %AssemblyInfo% 11 FindStr ".*" %Template% >> %AssemblyInfo% 12 13 Rem Using TSVN Replace Tlp 14 "%TSVN_PATH%" %WorkDir% %AssemblyInfo% %target%>NUL
當然這樣還不是一勞永逸,你會發現每次編譯 AssemblyInfo.cs 文件都會變化,因此你的 commit 序號也會一直跟着增加,這並不是我們所想要的效果。這里提出一種解決方案,在每次替換后生成 dll 后又將 AssemblyInfo.cs 還原回去。
為此,我們在生成前事件中增加備份命令:
COPY /y "%target%" "%target%.bak">NUL
然后增加生成后事件,調用命令為:
"$(TargetDir)AfterBuildProject.bat" "$(ProjectDir)Properties\AssemblyInfo.cs"
在 AfterBuildProject.bat 中我們需要完成還原 AssemblyInfo.cs 和刪除備份文件的工作,代碼如下:

1 SET target=%1 2 COPY "%target%.bak" %target% 3 DEL /Q "%target%.bak" 2>NUL
就此,每次編譯時,系統都會自動將 commit 序號放到 dll 的文件版本中了。
完整代碼下載:點擊下載
本文來自 NewIdea 的博客,作者 Carey Tzou 。
原文地址:http://www.cnblogs.com/NewIdea/p/AutoVersion.html
轉載請注明出處,否則拒絕轉載!