Makefile使用指南:规则、变量与依赖管理
1. Make的基本工作原理
Make在处理规则时,会根据第一次遍历收集的时间戳来判断是否需要执行规则中的命令。如果规则中的某个依赖项比目标更新,或者目标缺失,Make就会执行规则的命令来更新目标。在处理规则的第一次遍历中,一些变量引用会立即解析,而另一些则会在第二次遍历执行命令时解析。
2. 每个命令独立的Shell
Make在处理规则时,会独立执行每个命令,即规则下的每个单独命令都在自己的Shell中执行。这意味着不能在一个命令中导出一个Shell变量,然后在另一个命令中访问其值。若要实现类似功能,需要使用命令分隔符(如Bourne shell语法中的分号)将命令串在同一行。为避免长命令行并提高可读性,可以在每行末尾使用反斜杠进行换行,按惯例,分号后换行。以下是一些示例:
foo: bar.c sources=bar.c; \ gcc -o foo $${sources} fud: baz.c sources=baz.c; gcc -o fud $${sources} doo: doo.c TMPDIR=/var/tmp gcc -o doo doo.c在第一个示例中,两行由同一个Shell执行,因为反斜杠转义了换行符。Make在将多命令语句传递给Shell之前会移除转义的换行符。第三个示例有所不同,这里只为运行gcc的子进程定义了TMPDIR变量,注意缺少分号,对She