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不允许把整个条件语句分成两部分放在不同的文件中。

posted @ 2017-06-17 16:52  糯米米一粒  阅读(1523)  评论(0编辑  收藏  举报