今天看书讲 makefile 老式的“后缀规则”,没怎么看明白,在网上找例子找了半天也没找到,后来自己琢磨写了一个,记录一下:
.SUFFIXES: .cxx
.cxx.o:
@echo 'suffix rule'
gcc -c $<
app: foo.out
foo.out: foo.o
gcc foo.o
这个规则已经被淘汰了,不推荐使用,只是看书的时候不弄明白心里难受。
以下是个人对后缀的理解:
.SUFFIXES: .cxx
.cxx.o:
@echo 'Suffix rule'
gcc -c $<
app: foo.out
foo.out: foo.o
gcc foo.o
其实后缀定义的就是当要生成一个跟这个后缀有关的目标时,需要执行的规则。
例如 foo.out: foo.o,foo.out 需要 foo.o 这个目标,make 发现是 .o 就会查找规则,会发现 .cxx.o 规则,然后就会调用规则的命令,其中 $< 就是foo.cxx。
如果改成 foo.out: foo1.o,make 就会提示:make: *** No rule to make target ‘foo1.o’, needed by ‘foo.out’. Stop.
如果把源文件改成 foo1.cxx,就又可以 make 成功了。不知道为什么 make 不提示找不到源文件 foo1.cxx。