Windows下程式向Linux下移植實踐2-草原之狼-搜狐部落格

來源:互聯網
上載者:User
導讀:

3.1.Makefile的編寫

      
Linux下一般都是使用make工具來管理和編譯一個大的開發工程的所有源檔案,make命令執行時,需要一個
Makefile 檔案,以告訴make命令需要怎麼樣的去編譯和連結程式,makefile關係到了整個工程的編譯規則。一個工程中的源檔案不計其數,其按類型、功能、模組分別放在若干個目錄中,makefile定義了一系列的規則來指定,哪些檔案需要先編譯,哪些檔案需要後編譯,哪些檔案需要重新編譯,甚至於進行更複雜的功能操作,因為makefile就像一個Shell指令碼一樣,其中也可以執行作業系統的命令。在Windows的一些IDE如VC中將自動幫你產生相應的makefile,所有這些都是透明的,但在Linux下你就不能不自己寫makefile了,會不會寫makefile,從一個側面說明了一個人是否具備完成大型工程的能力。

     make工具採用增量編譯的方式,每次只編譯被改動過確實需要編譯的源檔案,每次編譯時間make工具將自動判斷那些源檔案需要重新編譯,當一個工程很大而又只改動了很少的幾個源檔案,這將節省很多時間。

具體makefile檔案的編寫規則可以查看make的man
和info文檔(在Linux命令列方式下輸入:man
make 或info make)。makefile檔案的編寫規則很多,重要的是怎樣使用最簡單的方式寫出我們自己需要的makefile檔案。

   
網上也有很多介紹資料,網上有一篇很好的介紹makefile檔案編寫的文章:

下文將著重介紹使用pwlib開發庫的工程的makefile的編寫,但對於其它工程只需將common.mak檔案中對pwlib庫進行編譯的指令碼去掉也可適用。

3.1.1使用pwlib開發庫的工程的makefile的編寫

PWLib是Portable
Windows Library的縮寫,翻譯為輕便的Windows類庫.PWLib採用C++編寫,設計初衷是為了能讓Openh323在Windows和Unix的X-Windows下運行,
不過隨著一步步的完善PWLib已經被跨平台的程式所廣泛採用。

查看Pwlib的主目錄下/samples/hello_world/目錄下例子程式的makefile檔案可以發現該Makefile檔案內容如下:

# Simple makefile
for the hello world program

PROG   
= hello

SOURCES =
hello.cxx

ifndef
PWLIBDIR

PWLIBDIR=$(HOME)/pwlib

endif

include
$(PWLIBDIR)/make/ptlib.mak

# End of
Makefile

實際上就是使用了Pwlib庫的ptlib.mak檔案,編譯時間需要的標頭檔,相應的編譯選項都在ptlib.mak檔案中設定好了。

我們只需在該makefile檔案所在目錄下,命令列輸入make all命令即可編譯出程式的Release版本和Debug版本,它們分別放在目前的目錄的obj_linux_x86_r和obj_linux_x86_d子目錄下。

下面對該makefile中的內容進行解釋:

l         PROG變數為編譯出來的程式名稱。

l         SOURCES變數儲存的為本工程要進行編譯和連結的源檔案,當有多個源檔案時可以用空格隔開,雖然檔案名稱可以帶上路徑,但路徑在SOURCES變數中不起作用,實際編譯時間對於每個檔案它將截掉最後一個”/”字元前面的所有內容只保留檔案名稱。

l         PWLIBDIR為pwlib的安裝目錄,需要設定該環境變數(若要系統每次重啟都自動化佈建好該環境變數則將該環境變數的設定放入/etc/profile檔案中),若沒設定好則自動以”使用者主目錄/pwlib”作為pwlib的安裝目錄。

3.1.2深入分析ptlib.mak檔案

分析ptlib.mak檔案,它的內容如下;

ifndef PWLIBDIR

PWLIBDIR=$(HOME)/pwlib

endif

 

include
$(PWLIBDIR)/make/unix.mak

include
$(PWLIBDIR)/make/common.mak

也就是ptlib.mak包含了另兩個檔案unix.mak和common.mak檔案,其中unix.mak為定義編譯選項變數的檔案,編譯規則放在common.mak檔案中。

通過對這兩個檔案的分析,歸納出一些我們寫makefile檔案要用到的一些變數,列出如下:

l         STDCCFLAGS:所有標頭檔的include目錄編譯選項、先行編譯宏定義選項、警告選項、最佳化選項都放在該變數中,各編譯選項之間用空格分開。

l         LDFLAGS:共用庫、靜態庫搜尋目錄設定放入該變數中。

l         LDLIBS:連結時要用的庫的設定放入該變數中。

l         VPATH_CXX:*.cxx源檔案的搜尋路徑放入該變數中,多個目錄以空格分開,編譯時間將首先在makefile所在目錄尋找相應源檔案,沒找到則按照VPATH_CXX中的路徑設定進行尋找。

l         VPATH_C:*.c源檔案的搜尋路徑放入該變數中,多個目錄以空格分開,檔案尋找順序和VPATH_CXX變數的類似。

3.1.3加入新的編譯規則

common.mak檔案中只對*.c和*.cxx的源檔案定義了編譯規則,而一般windows下程式大多都使用了.cpp來作為C++源檔案的尾碼。

怎樣加入對於.cpp尾碼的源檔案的編譯規則呢,這需要修改pwlib的common.mak檔案,具體步驟如下:

      
1.加入對於.cpp檔案的搜尋目錄設定

在vpath %.cxx $(VPATH_CXX)語句後面加入如下語句:

             
vpath %.cpp $(VPATH_CXX)

      
2.加入對於.cpp檔案的編譯規則

             
在$(OBJDIR)/%.o : %.cxx語句的前面加入如下語句:

$(OBJDIR)/%.o : %.cpp

       @if [ !
-d $(OBJDIR) ] ; then mkdir -p $(OBJDIR) ; fi

       $(CPLUS)
$(STDCCFLAGS) $(OPTCCFLAGS) $(CFLAGS) $(STDCXXFLAGS) -x c++ -c $< -o
$@

      
3.加入對於.cpp檔案的.o檔案(目標代碼檔案)的命名規則

      
在SRC_OBJS := $(SRC_OBJS:.cxx=.o)語句後面加入如下語句

SRC_OBJS :=
$(SRC_OBJS:.cpp=.o)

      
4.加入對於.cpp檔案的.dep檔案(依賴檔案)的命名規則

      
在SRC_DEPS := $(SRC_DEPS:.cxx=.dep)語句後面加入如下語句

SRC_DEPS :=
$(SRC_DEPS:.cpp=.dep)

      
5.加入對於.cpp檔案產生.dep檔案的建置規則,加入如下語句:

      
在$(DEPDIR)/%.dep : %.cxx語句前面加入如下語句

$(DEPDIR)/%.dep : %.cpp

       @if [ !
-d $(DEPDIR) ] ; then mkdir -p $(DEPDIR) ; fi

       @printf
%s $(OBJDIR) > $@

       $(CPLUS)
$(STDCCFLAGS:-g=) -M $< >> $@

本文轉自
http://larryjiazhiqiang.blog.sohu.com/67531576.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.