参考:http://blog.csdn.net/liang13664759/article/details/1771246/安全
使用条件判断,可让make根据运行时的不一样状况选择不一样的执行分支。条件表达式可使比较变量的值,或是比较变量和常量的值。函数
1、示例测试
判断$(CC)变量是否“GCC”,若是是的话,则用GNU函数编译目标。.net
libs_for_gcc=lgnuorm
normal_libs=blog
foo:$(objects)ip
ifeq($(CC),gcc)get
$(CC) -o foo $(objects) $(libs_for_gcc)it
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)
2、语法
条件表达式语法:
<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不容许把整个条件语句分红两部分放在不一样的文件中。