Makefile条件判断 ——————————【Badboy】

使用条件判断,可以让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结束。

  当我们的变量$(CC)值是"gcc"时,目标foo的规则是:

  foo: $(objects)

  $(CC) -o foo $(objects) $(libs_for_gcc)

  而当我们的变量$(CC)值不是"gcc"时(比如"cc"),目标foo的规则是:

  foo: $(objects)

  $(CC) -o foo $(objects) $(normal_libs)

  当然,我们还可以把上面的那个例子写得更简洁一些:

  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)

  二、语法

  条件表达式的语法为:

  endif

  以及:

  else

  endif

  其中表示条件关键字,如"ifeq".这个关键字有四个。

  第一个是我们前面所见过的"ifeq"

  ifeq (, )

  ifeq‘‘ ‘‘

  ifeq"" ""

  ifeq"" ‘‘

  ifeq‘‘ ""

  比较参数"arg1"和"arg2"的值是否相同。当然,参数中我们还可以使用make的函数。如:

  ifeq ($(strip $(foo)),)

  endif

  这个示例中使用了"strip"函数,如果这个函数的返回值是空(Empty),那么就生效。

第二个条件关键字是"ifneq".语法是:

  ifneq (, )

  ifneq‘‘ ‘‘

  ifneq"" ""

  ifneq"" ‘‘

  ifneq‘‘ ""

  其比较参数"arg1"和"arg2"的值是否相同,如果不同,则为真。和"ifeq"类似。

  第三个条件关键字是"ifdef".语法是:

  ifdef

  如果变量的值非空,那到表达式为真。否则,表达式为假。当然,同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子:

  示例一:

  bar =

  foo =$(bar)

  ifdeffoo

  frobozz =yes

  else

  frobozz =no

  endif

  示例二:

  foo =

  ifdeffoo

  frobozz =yes

  else

  frobozz =no

  endif

  第一个例子中,"$(frobozz)"值是"yes",第二个则是"no".

  第四个条件关键字是"ifndef".其语法是:

  ifndef

  这个我就不多说了,和"ifdef"是相反的意思。

  在这一行上,多余的空格是被允许的,但是不能以[Tab]键做为开始(不然就被认为是命令)。而注释符"#"同样也是安全的。"else"和"endif"也一样,只要不是以[Tab]键开始就行了。

  特别注意的是,make是在读取Makefile时就计算条件表达式的值,并根据条件表达式的值来选择语句,所以,你最好不要把自动化变量(如"[email protected]"等)放入条件表达式中,因为自动化变量是在运行时才有的。

  而且,为了避免混乱,make不允许把整个条件语句分成两部分放在不同的文件中。

Makefile条件判断 ——————————【Badboy】

时间: 2024-12-29 01:58:05

Makefile条件判断 ——————————【Badboy】的相关文章

从头开始写项目Makefile(六):参数传递、条件判断、include

[版权声明:转载请保留出处:blog.csdn.net/gentleliu.Mail:shallnew at 163 dot com] 在多个Makefile嵌套调用时,有时我们需要传递一些参数给下一层Makefile.比如我们在顶层Makefile里面定义的打开调试信息变量DEBUG_SYMBOLS,我们希望在进入子目录执行子Makefile时该变量仍然有效,这是需要将该变量传递给子Makefile,那怎么传递呢?这里有两种方法: 1.     在上层Makefile中使用"export&qu

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 $(o

Linux makefile教程之条件判断六[转]

使用条件判断 —————— 使用条件判断,可以让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

makefile中的条件判断ifeq、ifneq、ifdef

使用条件判断,可以让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

makefile中条件判断与函数

1. 条件判断 1.1 语法 条件表达式的语法为: <conditional-directive> <text-if-true> endif 以及: <conditional-directive> <text-if-true> else <text-if-false> endif 其中<conditional-directive>表示条件关键字,如"ifeq".这个关键字有四个. (1)第一个是我们前面所见过的&q

makefile(03)_条件判断

8.条件判断语句 8.1.语法规则 Makefile中支持条件判断语句,可以直接比较两个不同变量的值和常量值.注意:条件判断语句只能用于控制make实际执行的语句,不能控制规则中命令的执行过程.条件判读语法说明:条件判断关键字:示例: .PHONY : test var1 := A var2 := $(var1) var3 := test: ifeq ($(var1),$(var2)) @echo "var1 == var2" else @echo "var1 != var2

条件判断语句(七)

我们之前说过 makefile 是一种脚本语言程序,那么程序便会有相应的语法.在 makefile 中支持条件判断语句,可以根据条件的值来决定 make 的执行,也可以比较两个不同变量或者变量和常量值.需要注意的是:条件判断语句只能用于控制 make 实际执行的语句:但是,不能控制规则中命令的执行过程.格式如下 条件判断语句的语法如下 那么在 makefile 中都有哪些的条件判断关键呢? 关键字 功能 ifeq 判断参数是否相等,相等为 true,否则为 false ifneq 判断参数是否不

make--变量 条件判断 函数定义及调用

一.变量的高级主题 A.变量值的替换1.使用指定字符(串)替换变量中的后缀字符(串)2.语法格式:$(var:a=b) (将a替换成b)a.替换表达式中不能有任何的空格b.make中支持使用${}对变量进行取值示例 src:=a.cc b.cc c.cc obj:=$(src:cc=o) test: @echo "obj=>$(obj)" 输出结果由上图可以看出变量值的替换B.变量的模式替换1.使用%保留变量值中的指定字符,替换其它字符2.语法格式:$(var:a%b=x%y)a

PHP和JS在循环、条件判断中的不同之处

一.条件判断: php中算  false 的情况 1. boolean:false 2. 整形:0 3.浮点型:0 4.字符串:"" "0"(其他都对) 5.空数组 6.空对象为真(只在php4算false,其他版本都算true) 7.null和尚未定义的变量 8.所有资源都算对,除php4,所有对象也算对 JS中if()中的表达式 1. Boolean: true 真 false 假 2. String:非空字符串为真 空字符串为假 3. Null/NaN/Und