注:這里的makefile指的是gnu makefile,可能跟其他的makefile略有不同。若有不同,我盡量提及。而且這也不算是一篇教程,只是我在用make的時(shí)候記得一些筆記。推薦看<
>。另外網(wǎng)上有一篇《跟我一起寫(xiě)makefile》也很好。
makefile規(guī)則分為三部分:目標(biāo)(target)、條件(prerequisite)、命令(commands)。
target:prereq1...prereqn
commans
1.自動(dòng)變量
$@:代表目標(biāo)文件名
$%:The filename element of an archive member specification.
$<:條件列表中的第一個(gè)條件的文件名
$?:條件列表中所有比目標(biāo)新的那些條件的文件名,以空格分割
$^:條件列表中所有條件的文件名,以空格分割。如果列表中有重復(fù)的條件,則會(huì)被刪掉。
$+:跟$^類似,區(qū)別在不會(huì)去掉重復(fù)的條件。
$*:目標(biāo)文件名的詞干部分(去掉擴(kuò)展名剩下的部分)
自動(dòng)變量只能用在規(guī)則的命令部分,因?yàn)檫@些變量是make匹配到規(guī)則的目標(biāo)和條件后才設(shè)置值的。
舉個(gè)例子說(shuō)明一下。假設(shè)某個(gè)工程有三個(gè)文件:cal.cpp,cal.h,test.cpp(下面再有說(shuō)明時(shí)也以此為例)。makefile如下:
OBJS=test.o cal.o cal.o
TARGET=cal.exe
all:$(TARGET)
$(TARGET):$(OBJS)
@echo $@
@echo $<
@echo $^
@echo $?
@echo $+
@echo $%
@echo $*
輸出為:
cal.exe
test.o
test.o cal.o
test.o cal.o
test.o cal.o cal.o
ECHO is off.
ECHO is off.
至于最后兩個(gè)為什么會(huì)這樣輸出我還不太清楚,有清楚地麻煩告訴我一下這兩個(gè)怎么用。先謝謝了。
2.模式規(guī)則
模式規(guī)則也是規(guī)則,也要滿足make的規(guī)則形式,分為目標(biāo)、條件、命令三個(gè)部分。只是目標(biāo)、條件中的文件名的詞干部分用%代替了,這個(gè)%跟shell中的*類似,代表任意長(zhǎng)度的字符串。還以上面說(shuō)得工程為例,makefile如下:
CPPFLAGS= -g
CC=g++
test:cal.o test.o
cal.o:cal.h
make的時(shí)候,輸出如下內(nèi)容:
g++ -g -c -o test.o test.cpp
g++ -g -c -o cal.o cal.cpp
g++ test.o cal.o -o test
這個(gè)makefile之所以能夠正確被處理,是因?yàn)閙ake內(nèi)建了一些規(guī)則。例如:
%.o: %.c
$(COMPILE.c) $(OUTPUT_OPTION) $<
%.o: %.cpp
$(COMPILE.cpp) $(OUTPUT_OPTION) $<
以及
%: %.o
$(LINK.o) $^ $(LOADLIBES) $(LDLIBS) -o $@
這些規(guī)則里面的$變量都是make的標(biāo)準(zhǔn)變量(還有上面的CPPFLAGS,CC也是。另外還有一些別的),這些標(biāo)準(zhǔn)變量有的有默認(rèn)值(例如CC的默認(rèn)值是cc),有的沒(méi)有。make在處理makefile文件時(shí),如果沒(méi)有顯式的規(guī)則,那么就會(huì)查找是否有隱式的可用規(guī)則,如果找到就會(huì)利用隱式規(guī)則來(lái)生成目標(biāo)。
2.1靜態(tài)模式規(guī)則
靜態(tài)模式規(guī)則指的是類似下面的規(guī)則:
$(OBJECTS): %.o: %c
$(CC) -c $(CFLAGS) $< -o $@
這跟上面的模式規(guī)則類似,不同在于將規(guī)則的適用范圍限制在了$(OBJECTS)。也就是只針對(duì)這些目標(biāo)來(lái)應(yīng)用規(guī)則。
2.2后綴規(guī)則
后綴規(guī)則是指用一個(gè)或者兩個(gè)后綴連接起來(lái)作為目標(biāo),同時(shí)省略掉條件部分。如下:
.c.o:
$(COMPILE.c) $(OUTPUT_OPTION) $<
容易混淆的地方是條件后綴在前,目標(biāo)后綴在后。
這跟上面的規(guī)則:
%.o: %.c
$(COMPILE.c) $(OUTPUT_OPTION) $<
功能是一樣的,只是為了兼容一些老的make系統(tǒng)。
需要注意的是,這里用到的后綴必須在已知后綴列表里面。有個(gè)專用的目標(biāo)(target)——.SUFFIXES——用來(lái)設(shè)定后綴列表。例如:.SUFFIXES:.pdf .o .c 。而.SUFFIXES:(也就是后面列表為空)用來(lái)清空后綴列表。
3.自動(dòng)依賴生成
還沒(méi)發(fā)現(xiàn)這個(gè)在實(shí)際應(yīng)用中有多方便,有興趣的可以看看我開(kāi)始推薦的兩個(gè)文檔。