一:概述
使用条件判断,可以让 make 根据运行时的不同情况选择不同的执行分支。
条件表达式可以是比较变量的值,或是比较变量和常量的值。
编写代码的时候,我们也会多次使用if else等条件判断,下面让我们一起来看一下Makefile中是如何使用判断语句的吧。
二:语法介绍
首先我们先看一下相关的语法,了解一下使用方法。if的判断语法总共有四种,下面我们一起来看一下吧。
条件表达式的语法为:
?
?
endif?
以及:
?
?
else?
?
endif?
其中
第一个是我们是“ifeq” 相当于C语言中的if,比较参数“arg1”和“arg2”的值是否相同。当然,参数中我们还可以使用 make 的函数。
ifeq (, )?
ifeq '' ''?
ifeq "" ""?
ifeq "" ''?
ifeq '' ""?
第二个条件关键字是“ifneq”。顾名思义与ifeq相反,其比较参数“arg1”和“arg2”的值是否相同,如果不同,则为真。和“ifeq”类似。语法是:
ifneq (, )?
ifneq '' ''?
ifneq "" ""?
ifneq "" ''?
ifneq '' ""?
第三个条件关键字是“ifdef”。相当于C语言中的#ifdef 语法是:
ifdef ?
如果变量
的值非空,那到表达式为真。否则,表达式为假。当然,
同样可以是一个函数的返回值。注意,ifdef 只是测试一个变量是否有值, 其并不会把变量扩展到当前位置
第四个条件关键字是“ifndef”。与ifdef相反 其语法是:
ifndef ?
总的来说,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的运行