Makefile学习(二)条件判断和内嵌函数
第七章:Makefile的条件执行
条件语句可是是两个不同的变量、或者变量和常量值的比较;
7.1例子:
对变量“CC”进行判断,其值
如果是“gcc ”那么在程序连接时使用库“libgnu.so”或者“libgnu.a ”,否则不链接任
何库。
……
libs_for_gcc = -lgnu
normal_libs =
……
foo: $(objects)
ifeq ($(CC),gcc)
$(CC) -o foo $(object s) $(libs_for_gcc)
else
$(CC) -o foo $(objects) $(normal_libs)
endif
……
7.2.1.1关键字ifeq
通常我们会使用它来判断一个变量的值是否为空(不是任何字符)。参数值可能是
通过引用变量或者函数得到的,因而在展开过程中可能造成参数值中包含空字符(空格
等)。
7.2.1.2关键字ifneq
7.2.1.3关键字ifdef
判断一个变量是否已经定义。
7.2.1.4关键字ifndef
在除关键字(包括“endif”)之前、条件表达式参数中之外的其他任何地方
都可以使用多个空格或[Tab]字符,它不会影响条件判断语句的功能。
7.3标记测试的条件语句
使用条件判断语句、MAKEFLAGS和函数fingstring实现对make命令行选项的测试
archive.a: ...
ifneq (,$(findstring t,$(MAKEFLAGS)))
+touch archive.a
+ranlib -t archive.a
else
ranlib archive.a
endif
判断make命令行参数中是否包含-t,对archice.a执行不同的操作。
第八章make的内嵌函数
8.1函数的调用语法
格式如下:
$(FUNCTION ARGUMENTS)
或者:
${FUNCTION ARGUMENTS}
说明:1.对于用户自己的函数需要通过make的call函数来间接调用
2.“ARGUMENTS”是函数的参数,参数和函数名之间使用若干个空格或者[tab]字符分割
3.以“$ ”开头,使用成对的圆括号或花括号把函数名和参数括起
8.2文本处理函数
$(subst FROM,TO,TEXT) 字符串替换
$(patsubst PATTERN,REPLACEMENT,TEXT) 模式替换函数
$(strip STRINT) 去空格函数
$(findstring FIND,IN) 如果在“IN”之中存在“FIND”,则返回“FIND”,否则返回空。
$(filter PATTERN…,TEXT) 例子如下
sources := foo.c bar.c baz.s ugh.h
foo: $(sources)
cc $(filter %.c %.s,$(sources)) -o foo
$(filter-out PATTERN...,TEXT)
过滤掉字串“TEXT”中所有符合模式
“PATTERN”的单词,保留所有不符合此模式的单词。
$(sort LIST) 给字串“LIST”中的单词以首字母为准进行排序(升序),并取掉重复的单词
$(word N,TEXT) 返回字串“TEXT”中第“N”个单词
$(wordlist S,E,TEXT)
函数功能:从字串“TEXT”中取出从“S ”开始到“E ”的单词串。“S ”和“E ”
表示单词在字串中位置的数字
8.2.10 $(words TEXT) 字算字串“TEXT”中单词的数目。
$(firstword NAMES…) 字串“NAMES…”的第一个单词。
8.3文件名处理函数
8.3.1 $(dir NAMES…) 取目录函数—dir。
$(notdir NAMES…) 取文件名函数
其他一系列函数:
$(suffix NAMES…) 取后缀函数$(basename NAMES…) 取前缀函数$(addsuffix SUFFIX,NAMES…)
$(addsuffix SUFFIX,NAMES…) 加后缀函数,为“NAMES…”中的每一个文件名添加后缀“SUFFIX”。
$(addprefix PREFIX,NAMES…)
$(join LIST1,LIST2) 单词连接函数$(wildcard PATTERN)获取匹配模式文件名函数
$(wildcard *.c)
返回值为当前目录下所有.c 源文件列表。、
8.4foreach函数,它是一个循环函数
$(foreach VAR,LIST,TEXT)
执行时把“LIST”中使用空格分割的单词依次取出赋值给变量
“VAR ”,然后执行“TEXT”表达式。重复直到“LIST”的最后一个单词(为
空时结束)。
8.5if函数
$(if CONDITION,THEN-PART[,ELSE-PART])
第一个参数“CONDITION”,在函数执行时忽略其前导和结尾空字
符,如果包含对其他变量或者函数的引用则进行展开。如果“CONDITION”的
展开结果非空,则条件为真,就将第二个参数“THEN_PATR ”作为函数的计算
表达式;“CONDITION”的展开结果为空,将第三个参数“ELSE-PART”作为
函数的表达式,函数的返回结果为有效表达式的计算结果。
8.6call函数
使用这个函数可以实现对用户自己定义函数引用
“call”函数是唯一一个可以创建定制化参数函数的引用函数。
$(call VARIABLE,PARAM,PARAM,...)
我们可以将一个变量定义为一个复杂的表达式,用call函数根据不同的参数对它进行展开来获得不同的结果。
$(value VARIABLE) 提供一种在不对变量进行展开的情况下获取变量值的方法
8.8eval函数
eval函数返回值为空,
函数“eval ”是一个比较特殊的函数。使用它可以在Makefile中构
造一个可变的规则结构关系(依赖关系链),其中可以使用其它变量和函数。
8.9origin函数
函数“origin”的动作不是操作变量(它的参数)。
它只是获取此变量(参数)相关的信息,告诉我们这个变量的出处(定义方式)。
$(origin VARIABLE) 返回值:返回“VARIABLE ”的定义方式。用字符串表示。
函数返回有以下几种:
1.undefined
2.default,说明VARIABLE是一个默认定义变量(内嵌变量)
3.environment,变量“VARIABLE ”是一个系统环境变量,并且make没有使用命令行选项“-e
4.environment override,系统环境变量,make使用了-e
5.file,在某个makefile文件中定义
6.command line在命令行中定义
7.override使用该指示符声明的
8.automatic自动化变量
8.10shell
函数shell函数不同于除“wildcard”函数之外的其它函数。make可以使用它来和外部通信。
8.11make的控制函数
$(error TEXT…)产生致命错误,并提示“TEXT”信息给用户,并退出make执行
$(warning TEXT…)