参见《嵌入式linux设计与应用》p.65makefile中设定好的内部变量,称其为内定义宏。他们根据每一个规则内容定义,下面是几个比较常用的:(这些变量不需要括号括住)
$@ 扩展成当前规则的目标文件名
$< 扩展成依靠列表中的第一个依赖文件
$- 扩展成整个依靠的文件列表(除掉了里面所有重复的文件名)
$? 表示目标文件中新的依赖文件的列表
$* 是表示依赖文件的文件名,不含扩展名在makefile中使用函数
makefile里的跟它的变量很相似。在调用时,用一个$开始,然后是开括号,函数名,再空格,然后跟一系列由逗号分隔的参数,最后用关括号结束。wildcard函数,它有一个参数,功能是展开成一列所有符合由其描述的文件名,文件名之间用空格隔开
SOURCES=$(wildcard *.c)
这行会产会产生一个所有以"*.c"结尾的文件列表,然后存入变量SOURCES中。patsubst(patten substitude,匹配替换的缩写)函数。三个参数:1.需要匹配的式样,2.用什么来替换它,3.需要被处理的由空格分隔的字列,如处理经过上面定义后的变量:
OBJS=$(patsubst %.c,%.o,$(SOURCES))
这行将要处理所有在SOURCES字列中的字(一列文件名),如果以".c"结尾,就用".o"替换".c"。这里的%符号将匹配一个或多个字符,而它每次所匹配的字串叫做一个"柄"。在第二个参数里,%被认为是用第一参数所匹配的那个柄。