1. 程式人生 > >如何配置msvc命令列環境(續)——編寫msvc編譯指令碼

如何配置msvc命令列環境(續)——編寫msvc編譯指令碼

在配置好msvc命令列環境後(見《配置msvc命令列環境》), 就可以使用命令列編譯一些小的示例程式了。
如果需要把編譯指令碼釋出給其他人, 或者需要測試多個VC版本, 還需要一些小技巧。

先回憶下需求:
1. 要將編譯指令碼釋出給其他人
需要儘可能減少對客戶機器配置(主要是環境變數)的依賴。

2. 要測試多個VC版本
需要儘可能避免使用本機上的全域性(系統或當前使用者)環境變數,因為切換不方便。

3. 編寫指令碼對自己也應當比較方便
因為使用命令列的目的就是為了方便

如果不夠方便, 還不如使用IDE,它比較保險
——正確編寫的工作空間檔案、解決方案檔案、工程檔案、專案檔案對安裝了VC的客戶肯定是可以使用的。
(正確也是指沒有依賴本機上的任何設定,如全域性搜尋路徑。)



一、 對VC8、VC9

如下編寫指令碼:

"call %VSXXCOMNTOOLS%vsvars32.bat"。
rem 執行相應的cl命令。

這樣, 就能滿足上面的3點要求:
1. 客戶機上有肯定有正確的VSXXCOMNTOOLS變數——除非他沒有安裝相應的VC版本。
2. 可以執行cl的命令單獨放在一個指令碼中(假設叫cpl.bat),執行VC8、9相同的編譯過程。

對不同的VC版本, 只要能在執行cpl.bat前, 執行"call %VSXXCOMNTOOLS%vsvars32.bat"即可,如:
-------- vc8.bat --------
call "%VS80COMNTOOLS%vsvars32.bat"
call cpl.bat

-------- vc9.bat --------
call "%VS90COMNTOOLS%vsvars32.bat"
call cpl.bat

3. 編譯過程都在單獨的cpl.bat中, 管理維護也比較方便。



二、 對VC6

        二.1、 使用dsw和dsp檔案

也就是使用IDE提供的工作空間檔案與工程檔案。
這是最保險的—— 只要客戶安裝了VC6, 無論是否有設定環境變數, 都可以使用。

        二.2、假設客戶擁有正確的系統或當前使用者的環境變數

那麼就不用設定其他東西, 直接使用和VC8、9相同的編譯指令碼, 如:
-------- vc6.bat --------
call cpl.bat


當假設成立時:
1. 客戶重新安裝VC6
2. 客戶手動新增環境變數, 見《》。


還有一個缺陷,如果:
二.2.1. 客戶也安裝了多個VC版本
二.2.2. 並且為非VC6的某個版本設定了系統的或者當前使用者的環境變數
二.2.3. 或者VC6的環境變數存在並且是在另一個VC版本的環境變數之後

那麼vc6.bat實際上並不是使用VC6去編譯, 而是另一個

VC版本。


         二.3、使用VCVARS32.BAT(for VC6)

                二.3.1 使用MSDevDir變數

VC6安裝時選擇“註冊環境變數”後,除了設定相應的Path、include、lib還會設定MSDevDir。
可以如下使用它:
-------- vc6.bat --------
call "%MSDevDir%/../../VC98/bin/vcvars32.bat"
call cpl.bat

有2點需要注意:
1. 依然依賴客戶機上的有正確的供VC6使用的環境變數。
與“二.2.2”不同的是,不會出現“二.2.3”的缺陷。

2. MSDevDir與vcvars32.bat的相對位置,並不一定如上面所寫!
安裝VC6時,會讓使用者先選擇一個Common資料夾位置。
安裝完畢後,它與MSDevDir的關係是:
Common/MSDev98

然後還會讓使用者選擇VC的位置。可以和上面不同。



                二.3.2 直接使用VCVARS32.BAT

如:
call VCVARS32.BAT
call cpl.bat

與“二.2”對比:
1. 當客戶安裝VC6時選擇了“註冊環境變數”
那麼Path中會加入“prefix/Microsoft Visual Studio/VC98/Bin”這個值。
而VCVARS32.BAT也恰好在這個目錄中,執行成功。

同時, 即使在這種情況下(客戶有必要的環境變數),再呼叫一次 VCVARS32.BAT也不一定就是多餘的。
因為這樣可以避免“二.2”中提到的缺陷, 最後一定是使用VC6而不是其他版本的VC進行編譯。

2. 當客戶安裝VC6時沒有選擇“註冊環境變數”
相對於“二.2”, 客戶需要做的工作會比較少: 將“prefix/Microsoft Visual Studio/VC98/Bin”加入“Path”即可。
無須加入另外的2到5個變數。


這是應該是最理想的不使用IDE的方式了。


三、 總結

1. 將編譯邏輯寫在一個單獨指令碼如cpl.bat中。

2. 對於VC8、9, 利用VSXCOMNTOOLS變數, 如下:
-------- vc8.bat --------
call "%VS80COMNTOOLS%vsvars32.bat"
call cpl.bat

-------- vc9.bat --------
call "%VS90COMNTOOLS%vsvars32.bat"
call cpl.bat

注意:是上面是VS而不是VC。


3. 對於VC6

        3.1 使用dsw和dsp檔案

這是最保險的方式。
但是不能利用已經寫好的cpl.bat檔案, 需要單獨維護。

        3.2 先直接使用VCVARS32.BAT

-------- vc6.bat --------
call VCVARS32.BAT
call cpl.bat

這樣的好處是,可以僅維護單獨的cpl.bat, 客戶上有多個VC版本也能正確編譯——如果他VC6的環境變數正確。
如果不正確, 客戶需要做的工作很少, 加入一個環境變數而已。


四、 示例

以下使用《》中的示例, 為其編寫一份使用多VC版本的編輯指令碼。點下載打包程式碼。

1. 原始碼
-------- _MSC_VER/_MSC_VER.cpp --------
內容見《預定義_MSC_VER巨集》或者打包程式碼中。

2. 總編譯邏輯
-------- _MSC_VER/vc/cpl.bat --------
cl ../_MSC_VER.cpp /W4
pause

3. 為不同VC版本編寫一個簡單的呼叫指令碼
-------- _MSC_VER/vc6/vc6.bat --------
call vcvars32.bat
call ../vc/cpl.bat

-------- _MSC_VER/vc8/vc8.bat --------
call "%VS80COMNTOOLS%vsvars32.bat"
call ../vc/cpl.bat

-------- _MSC_VER/vc9/vc9.bat --------
call "%VS90COMNTOOLS%vsvars32.bat"
call ../vc/cpl.bat


補充:

——關於指令碼批處理
文章裡提到的指令碼,都是dos下的bat批處理檔案, 功能很
這裡只是說明一種方便的使用多個VC版本的機制而已——就是“三、總結”中的 vc6.bat、vc8.bat、vc9.bat。
它們先使用相應的VCVARS32.bat註冊區域性於程序的環境, 然後呼叫cpl.bat。

實際上, cpl.bat才是編譯的邏輯, 如果dos的bat批處理不能完成其功能, 同樣可以使用其他的工具,如makefile。
所以本文總是說“編譯指令碼”, 而不是“編譯批處理”, 雖然本文的編譯指令碼就是簡單(不含一點邏輯的)的批處理檔案。