• 跟我学Makefile(三)


    紧接着跟我学Makefile(二)继续学习:变量高级用法

    (1)变量值的替换 :替换变量中的共有的部分,其格式是“$(var:a=b)”或是“${var:a=b}”,把变量“var”中所有以“a”字串“结尾”的“a”替换成“b”字串。这里的“结尾”意思是“空格”或是“结束符”。

    foo := a.o b.o c.o
    bar := $(foo:.o=.c)

    第二行:把“$(foo)”中所有以“.o”字串“结尾”全部替换成“.c”,所以我们的“$(bar)”的值就是“a.c b.c c.c”。

    (2)把变量的值再当成变量

    x = y
    y = z
    a := $($(x))

    $(x)的值是“y”,所以$($(x))就是$(y),于是$(a)的值就是“z”。(注意,是“x=y”,而不是“x=$(y)”) 。

    x = variable1
    variable2 := Hello
    y = $(subst 1,2,$(x))
    z = y
    a := $($($(z)))

    $(x)的值是“variable1”, subst 函数把“variable1”中的所有“1”字串替换成“2”字串,于是,“variable1”变成“variable2”,再取其值。

    追加变量的值:+=”操作符给变量追加值

    objects = main.o foo.o bar.o utils.o
    objects += another.o

    如果变量之前没有定义过,那么,“+=”会自动变成“=”,如果前面有变量定义,那么“+=”会继承于前次操作的赋值符。如果前一次的是“:=”,那么“+=”会以“:=”作为其赋值符。

    make 嵌套调用时(参见前面的“嵌套调用”章节),上层 Makefile 中定义的变量会以系统环境变量的方式传递到下层的 Makefile 中。当然,默认情况下,只有通过命令行设置的变量会被传递。而定义在文件中的变量,如果要向下层 Makefile 传递,则需要使用
    exprot 关键字来声明。

     

    条件判断语句:

    <conditional-directive>
    <text-if-true>
    endif

    <conditional-directive>
    <text-if-true>
    else
    <text-if-false>
    endif

    其中<conditional-directive>表示条件关键字,如“ifeq”。

    ifeq ($(strip $(foo)),)
    <text-if-empty>
    endif

    这 个 示 例 中 使 用 了 “strip ” 函 数 , 如 果 这 个 函 数 的 返 回 值 是 空 (Empty ), 那 么<text-if-empty>就生效。

    1关键字:“ifeq”:参数“arg1”和“arg2”的值是否相同,如果相同,则为真。 

    ifeq (<arg1>, <arg2>)
    ifeq '<arg1>' '<arg2>'
    ifeq "<arg1>" "<arg2>"
    ifeq "<arg1>" '<arg2>'
    ifeq '<arg1>' "<arg2>"

    如果参数两个参数相同就执行后续指令。

    2关键字:ifneq ,参数“arg1”和“arg2”的值是否相同,如果不同,则为真。 

    ifneq (<arg1>, <arg2>)
    ifneq '<arg1>' '<arg2>'
    ifneq "<arg1>" "<arg2>"
    ifneq "<arg1>" '<arg2>'
    ifneq '<arg1>' "<arg2>"

    3关键字:ifdef

    ifdef <variable-name>

    变量<variable-name>的值非空,那到表达式为真。否则,表达式为假。当然,<variable-name>同样可以是一个函数的返回值。注意, ifdef 只是测试一个变量是否有值,其并不会把变量扩展到当前位置

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

    例子1:

    bar =
    foo = $(bar)
    ifdef foo
    frobozz = yes
    else
    frobozz = no
    endif

    例子2:

    foo =
    ifdef foo
    frobozz = yes
    else
    frobozz = no
    endif

    结果:第一个例子中,“$(frobozz)”值是“yes”,第二个则是“no”。

  • 相关阅读:
    前端周刊第一期
    Java CAS 原理详解
    【转载】Linux系统调用SYSCALL_DEFINE详解
    简述伪共享和缓存一致性MESI
    exchange发邮件
    Flutter屏幕适配(自适应)方案
    dart类初始化 future方案
    windows下postgresql自启动
    How can I call an async method in StatelessWidget.build method?
    实战分层架构
  • 原文地址:https://www.cnblogs.com/Caden-liu8888/p/8371748.html
Copyright © 2020-2023  润新知