条件语句可以根据一个变量的值来控制 make 执行或者忽略 Makefile 的特定部分;条件语句可以是两个不同变量、或者变量和常量值的比较。要注意的是:条件语句只能用于控制 make 实际执行的 makefile 文件部分,它不能控制规则的 shell 命令执行过程;
makefile中主要有以下几种条件判断:
1.判断是否相等 ifeq
ifeq 条件语句
条件成立时要做的事情
endif
或者
ifeq 条件语句
条件成立时要做的事情
else
条件不成立时要做的事情
endif
2.判断是否不相等 ifneq
ifneq 条件语句
条件成立时要做的事情
endif
或者
ifneq 条件语句
条件成立时要做的事情
else
条件不成立时要做的事情
endif
条件语句中也可以make函数,例如使用“strip”函数来去掉变量中的字符,然后再判断是否返回空:
ifeq ($(strip $(foo)),)
#TODO
endif
看下面例子:
v1 = 5
v2 = 6
ifeq ($(v1),$(v2))# ifeq 和条件语句之间的空格必须存在!!
var3 = 1
else
var3 = 0
endif
all:
@$(list)
condition:
#ifeq($(v1),$(v2))
# echo "var1 is equal var2"
#else
# echo "var1 is not equal var2"#if语句不能写在命令行的位置
#endif
@echo $(var3)
3. 判断

本文详细介绍了Makefile中的条件语句,包括ifeq、ifneq的用法,以及如何利用条件判断控制变量赋值和执行流程。重点讲解了ifdef和ifeq的区别,以及在实际项目中的应用场景。
最低0.47元/天 解锁文章
700

被折叠的 条评论
为什么被折叠?



