规则语法:
目标(target):先决条件(prerequisites)
命令(command)
……
.PHONY(假目标,phony target)
.PHONY: clean
自动变量:
$@:用于表示一个规则中的目标。当一个规则中有多个目标时,$@所指的是其中任何造成规则命令被运行的目标。
$^:表示的是规则中的所有先决条件。
$<:表示的是规则中的第一个先决条件。
变量的类别与赋值:
递归扩展变量(recursively expanded variable):使用“=”符号定义。递归展开。
简单扩展变量(simply expanded variable):使用“:=”符号定义。只展开一次。
"?="条件赋值:当变量没有被定义时就定义它,若已定义则不改变其原值。
"+="追加赋值:在原值后面追加。
函数:
- abspath:将路径名转换成绝对路径并返回。eg:$(abspath name)
- addprefix:增加前缀并返回。eg:$(addprefix prefix, name)
- addsuffix:增加后缀并返回。eg:$(addsuffix suffix, name)
- eval:使make再一次解析text语句并返回空字符串。eg:$(eval text)
- filter:模式匹配(过滤)并返回满足pattern的内容。eg:$(filter pattern, text)
- filter-out:类似filter,只是返回是过滤后余下的部分。
- notdir:从路径中抽取文件名并返回。eg:$(notdir names)
- patsubst:将符合pattern的名字替换为replacement并返回替换后的名字。eg:$(patsubst pattern, replacement, text)
- realpath:返回name所对应的真实路径名。eg:$(realpath name)
- strip:清除名字列表中多余的空格并返回。eg:$(strip string)
- wildcard:获取满足pattern的文件或目录名列表。eg:$(wildcard pattern)