MakeFile Implicit Rules,A Gift for Me(強大的MAKEFILE)!!!
這幾天在解決源代碼編譯時忽然遇到個問題,今天終於在網絡上學習MAKEFILE資料後得到解決,在此與大家分享。
使用GCC開發的朋友是不是會常寫MakeFile呀,一般來說COPY一個已經有的MakeFile,改一改加入自己的CFLAGS和OBJECTS就好了,其中有幾行處理OBJECT編譯的suffix rule: 它會根據.o目標的依賴自動找到對應的.c進行編譯,所以的objects使用相同的CFLAGS,平常這沒有什麼問題,可是如果其中有部分objects需要使用與衆不同的CFLAGS定義怎麼辦呢?
比如我的程序三個.c文件main.c,meth_a.c,meth_b.c,他們使用到一個DEBUG的宏來在MAKEFILE中定義用來打開 debug信息,可是我現在只希望打開meth_b.c中的debug信息怎麼辦呢,MakeFile的隱式規則可以幫助你辦到!
CFLAGS += -Wall
CFLAGS += -O2
CFLAGS += -ansi
CFLAGS += -I/usr/include
meth_b.o : CFLAGS += -DDEBUG
只要加入meth_b.o : CFLAGS += -DDEBUG就好了,它表示在編譯目標時CFLAGS自動加上-DDEBUG的宏定義,厲害,強大的MakeFile!!!
以下是參考文章轉載:
http://www.study-area.org/cyril/opentools/opentools/x1176.html
內隱規則(Implicit Rules)
簡介
通常我們編譯程式時有很多算是每個人都有的共同習慣,例如我就是把 foo.c 編成foo.o。像這樣的編譯習慣,gnu make有一些內定規則來編譯, 也就是有的target你不寫,make也可以根據內定規則把他編譯出來。不用 對每個不同的.o寫不同的規則, 如果有個程式由foo.c foo1.c foo2.c......寫這些就寫得會發瘋了,例如
foo.o:foo.c |
C程式 |
自己的內隱規則
因為可能有的時候你希望做些dependency檢查,或者加上一些gcc 用的旗標,不是很單純的編譯而已你可以給make自訂的內隱規則
自訂規則
樣式規則(pattern rule)你可以用pattern rule來做一些自定的內隱規則。像這樣
%.o : %.c prog.h |
%.pdf : %.sgml |
pattern rule也可以有特定變數設值,特定樣式(pattern)的變數,例如
%.o : CFLAGS = -O |
還有更古老的一種叫suffix rule的方法來做,這種方法就有限制性 了,因為只能用在副檔名的規則。例如
.c.o: |
自動變數與內隱規則
因為這樣動態的編譯手法,它需要像在CVS裡面的%v %V %s這種東西來代替一些 動態改變的字串(幫你複習一下CVS)。所以有所謂的自動變數
$@ 同一個規則的目標名 |
內隱規則內也預設了一些變數,例如
AR = ar |