makefile--if条件判断语句的语法与使用

3,849 阅读1分钟

条件判断语句


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. 条件判断关键字

关键字功能

.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"
    else
    @echo "var3 is not empty"
    endif


4.一些工程经验

  • 条件判断语句之前可以有空格,但不能有Tab字符(’\t’)
  • 在条件语句中不要使用自动变量(@,@,^,$<)
  • 一条完整的条件语句必须位于同一个makefile中
  • 条件判断类似C语言中的宏,预处理阶段有效,执行阶段无效
  • make在加载makefile时
    首先计算表达式的值(赋值方式不同,计算方式不同)
    根据判断语句的表达式决定执行的内容

小结:

  • 条件判断根据条件的值决定make的执行
  • 条件判断可以比较两个不同变量或者变量和常量值
  • 条件判断在预处理阶段有效,执行阶段无效
  • 条件判断不能控制规则中命令的执行过程