Makefile文件的使用

先看下面的Makefile代码:

# Makefile for boot

# Programs, flags, etc.
ASM        = nasm
ASMFLAGS    = -I include/

# This Program
TARGET        = boot.bin loader.bin

# All Phony Targets
.PHONY : everything clean all

# Default starting position
everything : $(TARGET)

clean :
    rm -f $(TARGET)

all : clean everything

boot.bin : boot.asm include/load.inc include/fat12hdr.inc
    $(ASM) $(ASMFLAGS) -o $@ $<

loader.bin : loader.asm include/load.inc include/fat12hdr.inc include/pm.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.bin
all后面紧跟的是clean和everything,这表示,如果执行“make all”,clean和everythiny所表示的动作都将分别被执行。
至此,我们已经分析完上述Makefile文件的全部代码!哦,对了,还有.PHONY没有分析,其实.PHONY关键字表示它后面的名字并不是文件,而仅仅是一种行为的标号。

当我们直接输入make命令是,make程序会从第一个名字所代表的动作开始执行。在本例中,第一个标号是everything,所以make 和 make everything是一样的。

posted @ 2011-11-07 14:01  MagiCube  阅读(2208)  评论(0编辑  收藏  举报