posts - 134,comments - 22,trackbacks - 0
          <2009年12月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(4)

          我參與的團隊

          隨筆分類

          隨筆檔案

          收藏夾

          C++ 社區

          常用網站

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          1.根據例子說明,一下是linux下oracle10的程序編譯簡單的makefile文件

          CC=cc -g
          PROC=proc
           
          CFLAGS=-DPRECOMP -I$(ORACLE_HOME)/precomp/public "
                  -I$(ORACLE_HOME)/xdk/include -I.
          FLAGS= -D_ALL_SOURCE=1 -D_LINUX -g  -I../../incl -D_GNU_SOURCE -D_IS_EAB=1 -D__USE_GNU=1 -D__GCC_296 -I/usr/include/libxml2 -I../csrc -I../../csrc/ -DPOSIX=1 -DLINUX


          LIBHOME=$(ORACLE_HOME)/lib

          LLIBSQL= `cat $(LIBHOME)/sysliblist` "
                   `cat $(LIBHOME)/ldflags` "

                   -lclntsh


          LIBS= -L$(LIBHOME) $(LLIBSQL) -lmylib
           
          .SUFFIXES: .sqc .c .o
          %.c:%.sqc
                  $(PROC) $(PROCPLSFLAGS) iname=$^ hold_cursor=yes
          %.o:%.c
                  $(CC) -c $(FLAGS) $(LIBS) $^
           
          test:test.o test1.o test1.o
                  cc -o $@ $(FLAGS) $(LIBS) $^
                  rm -rf $^

          haha:test.o test1.o test1.o
                  @echo "+="$+
                  @echo "?="$?
                  @echo "^="$^
                  @echo "<="$<
                  @echo "@="$@
                  @echo "*="$*
                  @echo "%="$%

          2.說明

          2.1一般makefile編寫有3個步驟

                 1.宏定義。主要功能是定義一些宏變量已替代較長的編譯支持信息。一般情況下針對編譯所需要得.h頭文件,.a/.so的庫文件路徑。比如例子中的CFLAGS是oracle預編譯需要數據庫支持的頭文件路徑。LIBHOME是oracle環境編譯需要數據庫庫文件路徑。

                 2.源文件之間的相互依賴關系。列出需要產生目標文件編譯依賴的文件。比如例子中的test目標,其產生時會檢測(test.o test1.o test1.o)這些依賴文件的變化,如果依賴文件有變化會自動先編譯依賴文件。

                 3.可執行的命令.即針對目標關系,所作出的編譯行為。比如test其檢測完依賴文件后執行(cc -o $@ $(CFLAGS) $(LIBS) $^)編譯鏈接產生目標執行文件test.

                   4.宏使用時用(),{}來確認宏名稱例如${LIB}加{}會查找LIB的宏內容,$LIB會查找L的宏內容。

             2.2 :常用編譯項說明

                      1. -I:制定頭文件搜索的路徑

                      2. -L:連接需要的庫文件路徑

                      3. –l:連接需要的庫文件(比如:libmylib.so寫作 –lmylib)

             2.3: 自動化變量說明:

          $+ :所有的依賴文件,以空格分開,并以出現的先后為序,可能包含重復的依賴文件。

          $?:所有的依賴文件,以空格分開,這些依賴文件的修改日期比目標的創建日期晚

          $^ :所有的依賴文件,以空格分開,不包含重復的依賴文件。
          $< :第一個依賴文件的名稱。
          $@ :目標的完整名稱。

          $* :不包含擴展名的目標文件名稱。
          $% :如果目標是歸檔成員,則該變量表示目標的歸檔成員名稱。

          具體對照使用以上makefile,執行make haha得到如下對照信息:

          $ make haha

          test.o test1.o test1.o

          test.o test1.o

          test.o test1.o

          test.o

          haha

             2.4:后綴規則:

                      .SUFFIXES: .sqc .c .o制定新的后綴規則。(%.c:%.sqc),( %.o:%.c)即規則行為。就是將所有.sqc轉為.c,.c再轉為.o。

                      .c.o:等價于%.o:%.c

          3.注意:

              分行符"后面不能再有其他任何內容。

              對齊行最好采用^I(tab鍵)

              注釋符號#

              include包含編譯文件

          posted on 2009-12-09 13:36 何克勤 閱讀(422) 評論(0)  編輯  收藏 所屬分類: GNU Linux/Unix
          主站蜘蛛池模板: 洛浦县| 通化县| 剑河县| 丰城市| 阿坝县| 茂名市| 济宁市| 睢宁县| 文山县| 江川县| 遵义县| 梁平县| 米林县| 广南县| 贞丰县| 河源市| 祁阳县| 阿尔山市| 准格尔旗| 鲜城| 开阳县| 册亨县| 海南省| 萝北县| 丰原市| 德保县| 建德市| 蓝田县| 双鸭山市| 格尔木市| 龙江县| 武冈市| 龙陵县| 鄂托克前旗| 天祝| 邮箱| 康保县| 正宁县| 广宗县| 秀山| 沙湾县|