MakeFile 基本使用
MakeFile 文件中的规则
target(目标)…:prerequisites(先决条件)…
[tab] command(命令)
……
例如:
``
edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o
[tab] 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
[tab] cc -c main.c
kbd.o : kbd.c defs.h command.h
[tab] cc -c kbd.c
command.o : command.c defs.h command.h
[tab] cc -c command.c
display.o : display.c defs.h buffer.h
[tab] cc -c display.c
insert.o : insert.c defs.h buffer.h
[tab] cc -c insert.c
search.o : search.c defs.h buffer.h
[tab] cc -c search.c
files.o : files.c defs.h buffer.h command.h
[tab] cc -c files.c
utils.o : utils.c defs.h
[tab] cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
``
MakeFile 变量
OBJECTS = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
简化为:
objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
[tab] cc -o edit $(objects)
main.o : defs.h
kbd.o : defs.h command.h
command.o : defs.h command.h
display.o : defs.h buffer.h
insert.o : defs.h buffer.h
search.o : defs.h buffer.h
files.o : defs.h buffer.h command.h
utils.o : defs.h
clean :
[tab] -rm edit $(objects)
隐含规则中的自动变量
自动变量’¥^'的值表示规则的所有先决条件,包括它们所处目录的名称;
'¥<'的值表示规则中的第一个先决条件;'¥@'表示目标对象(另外还有一些自动变量的含义请参考 make
手册)。有时,当我们不想在命令行中指定头文件时,可以在先决条件中包含这些头文件。此时自动变量
'¥<'正是第一个先决条件。
foo.o : foo.c defs.h hack.h
cc -c $(CFLAGS) $< -o $@
其中的’¥<’就会被自动地替换成 foo.c,而¥@则会被替换为 foo.o。