Posted on 2010-02-08 10:43
Prayer 閱讀(384)
評論(0) 編輯 收藏 引用 所屬分類:
makefile
后綴規(guī)則是一個比較老式的定義隱含規(guī)則的方法。后綴規(guī)則會被模式規(guī)則逐步地取代。因為模式規(guī)則更強更清晰。為了和老版本的Makefile兼容,GNU make同樣兼容于這些東西。后綴規(guī)則有兩種方式:"雙后綴"和"單后綴"。
雙后綴規(guī)則定義了一對后綴:目標(biāo)文件的后綴和依賴目標(biāo)(源文件)的后綴。如".c.o"相當(dāng)于"%o : %c"。單后綴規(guī)則只定義一個后綴,也就是源文件的后綴。如".c"相當(dāng)于"% : %.c"。
后綴規(guī)則中所定義的后綴應(yīng)該是make所認識的,如果一個后綴是make所認識的,那么這個規(guī)則就是單后綴規(guī)則,而如果兩個連在一起的后綴都被make所認識,那就是雙后綴規(guī)則。例如:".c"和".o"都是make所知道。因而,如果你定義了一個規(guī)則是".c.o"那么其就是雙后綴規(guī)則,意義就是".c"是源文件的后綴,".o"是目標(biāo)文件的后綴。如下示例:
.c.o:
$(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<
后綴規(guī)則不允許任何的依賴文件,如果有依賴文件的話,那就不是后綴規(guī)則,那些后綴統(tǒng)統(tǒng)被認為是文件名,如:
.c.o: foo.h
$(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<
這個例子,就是說,文件".c.o"依賴于文件"foo.h",而不是我們想要的這樣:
%.o: %.c foo.h
$(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<
后綴規(guī)則中,如果沒有命令,那是毫無意義的。因為他也不會移去內(nèi)建的隱含規(guī)則。
而要讓make知道一些特定的后綴,我們可以使用偽目標(biāo)".SUFFIXES"來定義或是刪除,如:
.SUFFIXES: .hack .win
把后綴.hack和.win加入后綴列表中的末尾。
.SUFFIXES: # 刪除默認的后綴
.SUFFIXES: .c .o .h # 定義自己的后綴
先清楚默認后綴,后定義自己的后綴列表。
make的參數(shù)"-r"或"-no-builtin-rules"也會使用得默認的后綴列表為空。而變量"SUFFIXE"被用來定義默認的后綴列表,你可以用".SUFFIXES"來改變后綴列表,但請不要改變變量"SUFFIXE"的值。