当前位置:网站首页>Makefile语法

Makefile语法

2022-08-03 05:10:00 El mundo

赋值符号

符号说明示例
=变量的值是整个makefile中最后被指定的值;与在文中的位置无关。x = A
y = $(x)B
x = B
#y的结果是 BB;而不是AB.
:=覆盖之前的值x = A
y := $(x)B
x = B
#y的结果是 AB
?=如果没有被赋值过就赋予等号后面的值VIR ?= new_value
#VTR 的结果是new_value
VIR := old_value
VIR ?= new_value
#VIR 的结果是 old_value
+=添加等号后面的值VIR := A
VIR += B
#VIR 的结果是A B

自动化变量

自动化变量会把模式中所定义的一系列的文件自动的挨个取出,
直至所有的符合模式的文件都取完,
自动化变量只应该出现在规则的命令中。

符号说明
[email protected]规则中的目标集合。
在模式规则中,如果有多个目标的话,“[email protected]”表示匹配模 式中定义的目标集合
$%当目标是函数库的时候表示规则中的目标成员名,如果目标不是函数库文件, 那么其值为空。
$<依赖文件集合中的第一个文件。
如果依赖文件是以模式(即“%”)定义的,那么“$<”就是符合模式的一系列的文件集合。
$?所有比目标新的依赖目标集合,以空格分开。
$^所有依赖文件的集合,使用空格分开。
如果在依赖文件中有多个重复的文件,“$^”会去除重复的依赖文件,值保留一份

常用函数

函数说明示例
call唯一一个可以用来创建新的参数化的函数。
使用这个函数可以实现对用户自己定义函数引用。
reverse = $(1) $(2)
foo = $(call reverse,a,b)
#foo 的结果是 a b
#$(1)和 $(2) 表示函数 reverse 的参数。
dir取目录$(dir $(realpath (MKFILE_PATH)))
#realpath $(MKFILE_PATH) 返回变量MKFILE_PATH 的绝对路径。
#(dir $(realpath $(MKFILE_PATH)))取该绝对路径的目录部分。
#目录部分是指最后一个反斜杠(“/”)之前的部分。
eval根据其参数的关系、结构,对它们进行替换展开。$(eval include /subdrv.mk)
#包含子目录下的subdrv.mk, 并被当前makefile 解析和执行
foreach循环处理文件列表。$(foreach < var >,< list >,< text >)
#把 list 中的参数单次逐一取出来放到参数var中,然后再执行 text 所包含的表达式。
#每次text都会返回一个字符串
ifeq
else
endif
条件语句的开始,判断表达式与某个值是否相等。
表示条件表达式为假的情况
表示一个条件语句的结束,任何一个条件表达式都应该以endif结束
lastword返回最后一个字符串MKFILE_PATH := $(lastword $(MAKEFILE_LIST))
#返回变量 MAKEFILE_LIST 的最后一个字符串,赋值给MKFILE_PATH
patsubst模式字符串替换函数$(patsubst % , dir% , $(SUBDIRS) )
# 在变量SUBDIRS所有的名字前面加上 “dir” **
$(patsubst %/, %, $(dir $(mkfile_path)))
#将字符串中后缀为 “/” 替换为空**
realpath返回一个绝对路径ROOT = $(realpath ./)
#返回当前路径的绝对地址,赋值给ROOT
subst字符串替换函数$(subst < from >, < to >, < string> )
#把字串< string >中的< from >字符串替换成< to >
wildcard扩展通配符$(wildcard *.c)
#获取当前目录下所有的.c文件

参考

《【正点原子】I.MX6U嵌入式Linux驱动开发指南V1.4》

原网站

版权声明
本文为[El mundo]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_47491758/article/details/125965415