Makefile工具的使用( 四 )


如果没有使用"-f"或"--file"选项,make会尝试缺省的makefile文件名 。和指明"-f"或"--file"选项不同,make不能确定这些文件是否应当存在 。然而,如果缺省makefile不存在但可以通过运行make规则生成,你可能希望这些规则被运行使得makefile可以使用 。
因此,如果没有缺省makefile,make试图按照makefile名查找的顺序生成它,直到成功或名字用完 。注意如果make 不能找到或生成makefile,这并不是错误;makefile不总是必需的 。
当使用"-t"或"--touch"选项时,不希望使用过时的makefile来决定那个目标来touch 。所以"-t"选项对makefile更新不起作用;类似"-q"(or ‘—question")和"-n"(or "—just-print")不阻止makefile的更新,因为过时的makefile会产生错误的输出 。这样"make –f mfile –n foo"会更新"mfile",读入它,打印出更新"foo"需要执行的命令但不运行这些命令 。与"foo"有关的命令是更新过的"mfile"中的内容 。
但是有时不希望更新makefile,可以将makefile作为命令行的目标,当makefile被显式指定为目标时,"-t"选项也适用于它们 。
这样"make –f mfile –n mfile foo"会读入"mfile",打印出更新执行的命令,"foo"的命令是当前的"mfile"中的内容 。
2.5重载makefile
可以使用"include"指令来包含其它makefile,增加目标的变量定义 。然而,make不允许同一个目标有不同的命令,有其它的途径可以达到目的 。
假设有"makefile" 和"mfile","makfile"要包含"mfile",但都有对于目标"foo"的规则 。这是可以在"makefile"中写一条匹配任意模式的规则,指明当make在"makefile"中未找到目标时,搜索"mfile":
foo:
frobnicate > foo
%: force
@$(MAKE) -f mfile $@
force: ;
当执行"make foo"时,make找到"makefile",执行命令" frobnicate > foo";执行"make bar"时,在"makefile"中未找到相应的规则,这时模式规则适用,执行命令"make –f mfile bar","makefile"中未提及的其它目标也是类似的 。
这种方法之所有工作是因为模式规则的模式是"%",可以匹配任何的目标;这条规则的依赖是"force",保证即使目标存在命令也会执行;"force"规则的命令为空防止"make"为其搜索隐式规则-这样会导致依赖循环 。
3规则
makefile中的规则描述如何生成特定的文件,即规则的目标 。规则列出了目标的依赖文件,指定生成或更新目标的命令 。
规则的次序是不重要的,除非是确定缺省目标:缺省目标是第一个makefile中的第一个规则;如果第一个规则有多个目标,第一个目标是缺省的 。有两个例外:以"."开头的目标不是缺省目标;模式规则对缺省目标没有影响 。
通常我们所写的地一个规则是编译整个或makefile中指定的所有程序 。
3.1例子
foo.o : foo.c defs.h # module for twiddling the frobs
cc -c -g foo.c
它的目标是"foo.o",依赖于"foo.c"和"defs.h",有一个命令"cc –c –g foo.c" 。命令行以TAB字符开始标识它是一个命令 。
这条规则说明两件事:
?;如何决定"foo.o"是旧的:如果它不存在,或者"foo.c"或者"defs.h"比它新 。
?;如何更新"foo.o"文件:通过运行"cc"程序 。命令未提及"defs.h",担可以猜想"foo.c"包含了它,这是"defs.h"被置于依赖关系中的理由 。
3.2规则的语法
语法如下:
TARGETS : DEPENDENCIES
COMMAND
...
或者
TARGETS : DEPENDENCIES ; COMMAND
COMMAND
...
TARGETS是以空格隔开的文件名,统配符可以使用 。通常一个规则只有一个目标,偶尔也有多个 。
命令行以TAB键开始 。第一条命令可在依赖关系的下一行;或者在同一行,在分号后面;两种方式效果相同 。
因为"$"符号被用做变量引用,如果要在规则中使用"$"符号,必须写两个:"$$" 。可以用""符号来分割一个长行,这不是必须的,因为make对行的长度没有限制 。

推荐阅读