Makefile文件(六)_使用条件判断
参考:http://blog.csdn.net/liang13664759/article/details/1771246/
使用条件判断,可以让make根据运行时的不同情况选择不同的执行分支。条件表达式可以使比较变量的值,或是比较变量和常量的值。
一、示例
判断$(CC)变量是否“GCC”,如果是的话,则用GNU函数编译目标。
libs_for_gcc=lgnu
normal_libs=
foo:$(objects)
ifeq($(CC),gcc)
$(CC) -o foo $(objects) $(libs_for_gcc)
else
$(CC) -o foo $(objects) $(normal_libs)
endif
上面的示例中,目标“foo”可以根据变量“$(CC)”值来选取不同的函数库来编译程序
关键字:ifeq、else和endif。ifeq表示条件语句的开始,并指定一个条件表达式,表达式含有两个参数以逗号隔开,表达式以圆括号括起。else表示条件表达式位假的情况。endif表示一个条件语句的结束,任何一个条件表达式都应该以endif结束。
上例还可以写成:
libs_for_gcc = -lgnu
normal_libs=
ifeq($(CC),gcc)
libs = $(libs_for_gcc)
else
libs=$(normal_libs)
endif
foo: $(objects)
$(CC) -o foo $(objects) $(libs)
二、语法
条件表达式语法:
<conditional-directive>
<text-if-true>
endif
以及:
<conditional-directive>
<text-if-true>
else
<text-if-false>
endif
其中,<conditional-directive>表示条件关键字,如“ifeq”,这个关键字有四个
①、ifeq(<arg1>,<arg2>) / ifeq'<arg1>' '<arg2>' / ifeq"<arg1>" "<.arg2>" / ifeq "<arg1>" '<agr2>' / ifeq '<arg1>' "<arg2>"
表示比较参数“arg1”和“arg2”的值是否相同,当然参数中还可以使用make的函数,如:
ifeq ($(strip $(foo)),)
<text-if-empty>
endif
实例中使用了“strip”函数,如果函数返回空,那么<text-if-empty>生效
②ifneq(<arg1>, <arg2>) / ……
比较参数“argu1”和“arg2”是否相同,如果不同则为真。
③、ifdef <variable-name>
如果变量<variable-name>的值非空,那表达式为真,否则表达式为假。当然,<variable-name>同样可以使一个函数的返回值。ifdef只是测试一个变量是否有值,并不会把变量扩展到当前位置。例子:
bar =
foo = $(bar)
ifdef foo
frobozz = yes
else
frobozz = no
endif
上例中,"$(frobozz)"的值位“yes”
另一个例子:
foo =
ifdef foo
frobozz = yes
else
frobozz = no
endif
这个例子中的$(frobozz)的值为“no”。
④、ifndef:
ifndef <variable-name>
说明:在<conditional-directive>这一行上,可以有多余的空格,但是不能以Tab键开始(不然被认为是命令)。注释符“#”同样也是安全的。“else”和“endif”也一样,只要不是Tab键开始就行。
注:make在读取Makefile时就计算条件表达式的值,并根据条件表达式的值来选择语句,所以最好不要把自动化变量(如"$@"等)放入条件表达式中,因为自动化变量是在运行时才有的。且避免混乱,make不允许把整个条件语句分成两部分放在不同的文件中。