makefile进阶(六)-- 在makefile里引用别的文件(转)

make -f <filename>命令可以指定makefile的文件名,而不是默认的makefile、Makefile或GNUmakefile。


makefile里的include <filename>指令可以引入别的文件。注意文件名不能用字符串包围,如:
include header.mk可以引入当前路径下的header.mk,但是include "header.mk"会出现找不到文件的错误。

include也可以同时引入多个文件,比如:
include header.mk h2.mk *.mk


VPATH变量可以指定源文件的目录。只需要两行:
VPATH=src1:src2
test: foo1.o foo2.o foo3.o

make就可以得到我们想要的东西:
$ make
cc    -c -o foo1.o src1/foo1.c
cc    -c -o foo2.o src1/foo2.c
cc    -c -o foo3.o src2/foo3.c

相应的,vpath关键字(全小写,与VPATH变量不同)也可以设置搜索路径。
vpath <pattern> <directories>为匹配模式pattern的文件指定搜索路径<directories>。
把makefile修改为:
test: foo1.o foo2.o foo3.o
foo1.o foo2.o foo3.o:
vpath foo1.c src1
vpath %2.c src1
vpath foo%3.c src2

make同样会得到我们想要的东西:
$ make
cc    -c -o foo1.o src1/foo1.c
cc    -c -o foo2.o src1/foo2.c
cc    -c -o foo3.o src2/foo3.c

这是%是个通配符,等价于shell里的*。如果指定的多个规则里有重复的<pattern>,那么make会按vpath语句的先后顺序来执行搜索。
vpath <pattern>清除所有匹配<pattern>的搜索目录。
vpath清除所有已设置的搜索目录。
posted @ 2013-02-04 11:13  Mr.Shadow  阅读(760)  评论(0编辑  收藏  举报