先看下面的Makefile代码:
# Makefile for boot# Programs, flags, etc.ASM = nasmASMFLAGS = -I include/# This ProgramTARGET = boot.bin loader.bin# All Phony Targets.PHONY : everything clean all# Default starting positioneverything : $(TARGET)clean : rm -f $(TARGET)all : clean everythingboot.bin : boot.asm include/load.inc include/fat12hdr.inc $(ASM) $(ASMFLAGS) -o $@ $
在上述代码中,以字符#开头的行是注释,=是用来定义变量的,这里ASM和ASMFLAGS就是2个变量,要注意的是:使用这些变量的时候要使用如下格式:$(ASM)和$(ASMFLAGS),其分别代表 nasm 和 -I include/ ,而不是直接使用他们的原型。MakeFile语法:target : prerequisites command上述形式的格式代表两层含义:1. 要想得到target,需要执行命令command。2. target依赖prerequisites,当prerequisites中至少有一个文件比target文件新时,command才被执行。现在我们根据上述语法来翻译上述代码中的最后2行:loader.bin : loader.asm include/load.inc include/fat12hdr.inc include/pm.inc $(ASM) $(ASMFLAGS) -o $@ $<1. 要想得到loader.bin,需要执行“$(ASM) $(ASMFLAGS) -o $@ $<”。2. loader.bin依赖下述文件: loader.asm include/load.inc include/pm.inc include/fat12hdr.inc 当它们中至少有一个比loader.bin新时,command命令被执行。那么“$(ASM) $(ASMFLAGS) -o $@ $<“ 又是什么呢?其中,$@ 代表 target;$< 代表prerequisites的第一个名字;联系我们之前说的$(ASM)和 $(ASMFLAGS)的含义,我们知道:$(ASM) $(ASMFLAGS) -o $@ $<等价于:nasm -I include/ -o loader.bin loader.asm在上述Makefile文件中,我们注意到:不但boot.bin和loader.bin两个文件后面有冒号,everything/clean/all后面也有冒号,可是他们3个并不是3个文件,仅仅是动作名称而已。如果运行“make clean“,将会执行“rm -f $(TARGET)”,即rm -f boot.bin loader.binall后面紧跟的是clean和everything,这表示,如果执行“make all”,clean和everythiny所表示的动作都将分别被执行。至此,我们已经分析完上述Makefile文件的全部代码!哦,对了,还有.PHONY没有分析,其实.PHONY关键字表示它后面的名字并不是文件,而仅仅是一种行为的标号。当我们直接输入make命令是,make程序会从第一个名字所代表的动作开始执行。在本例中,第一个标号是everything,所以make 和 make everything是一样的。