一:概述
使用条件判断,可以让 make 根据运行时的不同情况选择不同的执行分支。条件表达式可以是比较变量的值,或是比较变量和常量的值。编写代码的时候,我们也会多次使用if else等条件判断,下面让我们一起来看一下Makefile中是如何使用判断语句的吧。
二:语法介绍
首先我们先看一下相关的语法,了解一下使用方法。if的判断语法总共有四种,下面我们一起来看一下吧。
条件表达式的语法为:
<conditional-directive>
<text-if-true>
endif
以及:
<conditional-directive>
<text-if-true>
else
<text-if-false>
endif
其中<conditional-directive>表示条件关键字,如“ifeq”。这个关键字有四个。
第一个是我们是“ifeq” 相当于C语言中的if,比较参数“arg1”和“arg2”的值是否相同。当然,参数中我们还可以使用 make 的函数。
ifeq (<arg1>, <arg2>)
ifeq '<arg1>' '<arg2>'
ifeq "<arg1>" "<arg2>"
ifeq "<arg1>" '<arg2>'
ifeq '<arg1>' "<arg2>"
第二个条件关键字是“ifneq”。顾名思义与ifeq相反,其比较参数“arg1”和“arg2”的值是否相同,如果不同,则为真。和“ifeq”类似。语法是:
ifneq (<arg1>, <arg2>)
ifneq '<arg1>' '<arg2>'
ifneq "<arg1>" "<arg2>"
ifneq "<arg1>" '<arg2>'
ifneq '<arg1>' "<arg2>"
第三个条件关键字是“ifdef”。相当于C语言中的#ifdef 语法是:
ifdef <variable-name>
如果变量 <variable-name>的值非空,那到表达式为真。否则,表达式为假。当然,
<variable-name>同样可以是一个函数的返回值。注意,ifdef 只是测试一个变量是否有值,
其并不会把变量扩展到当前位置
第四个条件关键字是“ifndef”。与ifdef相反 其语法是:
ifndef <variable-name>
总的来说,makefile中的判断语句与C中的基本类似,大家可以做个比较,这样更容易理解些
三:示例介绍
了解了语法之后,我们来编写一个简单的实例
#objects = add.o sub.o cal.o
#target = $(objects)
define target
add.o sub.o cal.o
endef
make_if = 0;
ifeq ($(make_if),1)
$(error "here add the debug info make_if = 1")
else
$(warning "here add the debug info make_if = 0")
endif
cal : $(target)
gcc -o cal $(target)
add.o : add.c
gcc -c add.c
sub.o : sub.c
gcc -c sub.c
cal.o : cal.c
gcc -c cal.c
clean :
rm *.o cal
从上面的实例我们可以看出首先定义了一个变量make_if ,然后判断这个变量的值运行不同的分支,这里面我们使用了些打印函数,便于我们调试用,这些打印函数我们在后面会介绍,很容易理解,ifeq ($(make_if),1)判断make_if是否等于1,不等于1走else分支,等于1走ifeq分支。其他的几个判断函数我这里就不一一列举,大家可以自己动手试一下,看一下实际的效果。
make_if = 0;
ifeq ($(make_if),1)
$(error "here add the debug info make_if = 1")
else
$(warning "here add the debug info make_if = 0")
endif
四:打印函数介绍
上面主要用了两个打印函数error 和warning,其实还有另外一种打印函数 info。首先看一下他们的用法。
方法1: $(info "here add the debug info")
方法2: $(warning "here add the debug info")
方法3: $(error "error: this will stop the compile")
这3中打印方式中error会产生致命错误,组织Makefile的运行,warning产生警告,info打印编译信息,这两种打印不会造成致命错误,不会组织Makefile的运行