这篇文章,主要用于记录一些Makefile中容易混淆,已经比较重要的重点内容,持续更新。
Makefile的详细讲解,在我的其他文章中。
重点一、@、^、
例:
smdk2410_config:unconfig
@$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
$@ 表示目标文件名称(这里就是smdk241_config),$^ 所有的依赖文件,$< 第一个依赖文件。
@$(MKCONFIG) 中@表示在执行命令时不输出命令本身(不回显),只输出命令执行的结果
$(MKCONFIG)表示(MKCONFIG) 这个变量的值mkconfig(在其他地方定义的)
$(@:_config=) 这里用到了makefile的变量替换规则,$(VAR:A=B)表示替换变量$(VAR)中的A为B,
即把$@中的_config替换为空变成smdk2410
重点二、:= ,=,?=的区别
:=不递归赋值
= 递归赋值
?=默认值
“:=” 的意思是,它右边赋得值如果是变量,只能使用在这条语句之前定义好的,而不能使用本条语句之后定义的变量;
于此对应的是“=”,当它的右边赋值是变量时,这个变量的定义在本条语句之前或之后都可以;
而“?=”是指,该符号左边的变量,如果在本条语句之前没有定义过,则执行本语句,如果已经定义,那么本语句什么都不做。
重点三、函数
字符串处理函数 | subset | patsubst | string | findstring | filter | filter-out | |
文件名操作函数 | dir | notdir | suffix | basename | addsufix | addprefix | jion |
其他函数 | foreach | if | call | origin | wildcard |
重点四、%,*
%在makefile 依赖关系中代表任意字符,*在shell command中代表任意字符
例如
all:*.c
all这个目标的依赖就是*.c
all:%.c
all目标的依赖为所有.c文件。