make -f 命令可以指定makefile的文件名,而不是默认的makefile、Makefile或GNUmakefile。
makefile里的
include 指令可以引入别的文件。注意文件名不能用字符串包围,如:
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的文件指定搜索路径
。
把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里的*。如果指定的多个规则里有重复的,那么make会按vpath语句的先后顺序来执行搜索。
vpath 清除所有匹配的搜索目录。
vpath清除所有已设置的搜索目录。
阅读(1378) | 评论(0) | 转发(0) |