makefile--条件判断语句
条件判断语句
1. makefile中⽀持条件判断语句
可以根据条件的值来决定make的执⾏
可以⽐较两个不同变量或者变量和常量值
ifxxx (arg1,arg2)
#do true
else
#do false
#endif
注意事项:
条件判断语句只能⽤于控制make实际执⾏的语句;但是,不能控制规则中命令的执⾏过程。
2. 条件判断语句的语法说明:
常⽤形式
ifxxx (arg1,arg2)
其它合法形式
ifxxx “arg1” “arg2”
ifxxx ‘arg1’ ‘arg2’
ifxxx “arg1” ‘arg2’
ifxxx ‘arg1’ “arg2”
3. 条件判断关键字
关键字功能
ifeq判断参数是否相等,相等为true,否则为false
ifneq判断参数是否不相等,不相等为true,否则为false ifdef判断参数是否有值,有值为true,否则为false
ifneq判断参数是否没有值,没有值为true,否则为false 关键字功能
.PHONY : test
var1 := A
var2 := $(var1)
var3 :=
test :
ifeq ($(var1),$(var2))
@echo "var1 == var2"
else
@echo "var1 != var2"
endif
ifneq ($(var3), )
@echo "var3 is not empty"
else
@echo "var3 is empty"
endif
ifdef var1
@echo "var1 is not empty"
else
@echo "var1 is empty"
endif
ifndef var3
@echo "var3 is empty"
makefile phonyelse
@echo "var3 is not empty"
endif
4.⼀些⼯程经验
条件判断语句之前可以有空格,但不能有Tab字符(’\t’)在条件语句中不要使⽤⾃动变量(^,$<)⼀条完整的条件语句必须位于同⼀个makefile中
条件判断类似C语⾔中的宏,预处理阶段有效,执⾏阶段⽆效make在加载makefile时⾸先计算表达式的值(赋值⽅式不同,计算⽅式不同)根据判断语句的表达式决定执⾏的内容⼩结:条件判断根据条件的值决定make的执⾏条件判断可以⽐较两个不同变量或者变量和常量值条件判断在预处理阶段有效,执⾏阶段⽆效
条件判断不能控制规则中命令的执⾏过程@,

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。