Makefile
Makefile基本规则
代码语言:text复制target ……:prerequisites ……
recipe
……
target
可以是需要生成的目标文件、可执行文件或一个标签
prerequisites
是生成该target所依赖的文件或者其他target
recipe
是生成该target所需要的任意shell命令(真正执行的部分)
当prerequisites 被更新时,运行make命令,则会重新运行recipe中对应的shell命令
示例
代码语言:text复制edit : main.o kbd.o command.o display.o
insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o
insert.o search.o files.o utils.o
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o
insert.o search.o files.o utils.o
代码中,edit为待生成的可执行文件,其依赖与main.o、kbd.o等一堆‘.o’文件,而这些‘.o'文件又各种依赖于其他文件。因此,运行make命令时,将会根据文件的依赖关系,逐步生成target的prerequisites,再运行target对应的recipe
clean
值得注意的是,代码中的clean并非可执行文件或目标文件,而是一个动作,类似于一个lable,在make时不会自动执行,需要显式输入make clean才能运行该target对应的recipe
此外,clean 更加规范的写法是,
代码语言:text复制.PHONY: clean
clean:
-rm edit main.o kbd.o command.o display.o
insert.o search.o files.o utils.o
.PHONY表示clean为伪标签,而-rm表示当shell命令出错时继续运行,删除其他文件
makefile中使用变量
示例
代码语言:text复制objects = main.o kbd.o command.o display.o
insert.o search.o files.o utils.o
edit : $(objects)
cc -o edit $(objects)
make自动推导
示例
代码语言:text复制main.o : defs.h
make会自动将与'.o'文件同名的'.c'文件加入依赖中
包含其他makefile
示例
代码语言:text复制include foo.make *.mk $(bar)
可以使用include命令将其他makefile引入makefile中,include命令会将指定makefile文件插入到include命令的位置,因此需要注意include命令的位置
通配符
可以使用‘*、?、 ~’三个通配符
文件搜寻
示例
代码语言:text复制VPATH = src:../headers
vpath %.h ../headers
可以使用特殊变量 VPATH或vpath关键字来设置搜索目录
多目标与静态模式
比较复杂,还需要复习
自动生成依赖性
通过recipe自动生成文件的依赖关系,依赖关系放到对应的.d文件中