makefile

makefile 的执行步骤

  1. 读入所有的 Makefile;
  2. 读入被 include 的其它 Makefile;
  3. 初始化文件中的变量;
  4. 推导隐晦规则,并分析所有规则;
  5. 为所有的目标文件创建依赖关系链;
  6. 根据依赖关系,决定哪些目标要重新生成;
  7. 执行生成命令;

文件搜索路径

目标文件和依赖文件

执行 make 命令时,要寻找目标文件和依赖文件的路径;

  1. 设置全局访问路径 VAPTH

    通过变量 VPATH 指定依赖文件的搜索路径。在规则的依赖文件在当前目录不存在时,make 会在此变量所指定的目录下去寻找这些依赖文件。变量 VPATH 的定义中,使用空格或者冒号(:)将多个目录分开。make 搜索的目录顺序按照变量 VPATH 定义中顺序进行(当前目录永远是第一搜索目录)。

源文件所要包含的头文件等相关文件的路径;

函数

调用语法

函数调用,很像变量的使用,也是以 $ 来标识的,其语法如下:

$(<function> <arguments>)

# 或者

${<function> <arguments>}

<function> 就是函数名。 <arguments> 为函数的参数,参数间以逗号 “,” 分隔。函数名和参数之间以“空格”分隔。函数调用以 “$” 开头,以圆括号或花括号把函数名和参数括起。函数中的参数可以使用变量,为了风格的统一,函数和变量的括号最好一样。如下所示:

$(subst a,b,$(x)) #推荐使用

$(subst a,b,${x})

示例:

comma:= ,
empty:=
space:= $(empty) $(empty)
foo:= a b c
bar:= $(subst $(space),$(comma),$(foo))

$(comma) 的值是一个逗号。 $(space) 使用了 $(empty) 定义了一个空格, $(foo) 的值是 “a b c”, $(bar) 的定义用,调用了函数 subst, 这是一个替换函数,这个函数有三个参数,第一个参数是被替换字串,第二个参数是替换字串,第三个参数 是替换操作作用的字串。这个函数也就是把 $(foo) 中的空格替换成逗号,所以 $(bar) 的值 是 “a,b,c”。

addsuffix

$(addsuffix suffix, names… )

patsubst

$(patsubst <pattern>,<replacement>,<text>)

foreach

$(foreach <var>,<list>,<text>)
Table of Contents