《跟我一起写makefile》笔记

1. 多目标

all : prog1 prog2 prog3
.PHONY : all
prog1 : prog1.o utils.o
    cc -o prog1 prog1.o utils.o
prog2 : prog2.o
    cc -o prog2 prog2.o
prog3 : prog3.o sort.o utils.o
    cc -o prog3 prog3.o sort.o utils.o

  

2.静态模式

objects = foo.o bar.o
all: $(objects)
$(objects): %.o: %.c
    $(CC) -c $(CFLAGS) $< -o $@

  “%.o” 表明要所有以 “.o” 结尾的目标,也就是 “foo.o bar.o” ,也就是变量 $object 集合的模式。

依赖模式 “%.c” 则取模式 “%.o” 的 “%” ,也就是 “foo bar” ,并为其加下 “.c” 的后缀,于是,我们的依赖目标就是 “foo.c bar.c”

而命令中的 “$<” 和 “$@” 则是自动化变量, “$<” 表示所有的依赖目标集(也就是 “foo.c bar.c” ), “$@” 表示目标集(也就是 “foo.o bar.o” )

另一个例子, $(filter %.o,$(files))表示调用 Makefile 的 filter 函数,过滤 “$filter” 集,只要其中模式为 “%.o” 的内容:

files = foo.elc bar.o lose.o
$(filter %.o,$(files)): %.o: %.c
$(CC) -c $(CFLAGS) $< -o $@
$(filter %.elc,$(files)): %.elc: %.el
    emacs -f batch-byte-compile $<

 

上一篇:C语言寒假大作战02


下一篇:一个JavaWeb项目开发总结