Makefile 不完全指南

 

变量

$^    表示规则的所有先决条件,包括它们所处目录的名称

$<    表示规则中的第一个先决条件

$@    表示所有目标对象的集合,就像一个数组

定义变量 x = $(y) 此时x可以使用后面定义的变量y,该方式可能会导致无限循环

      但 x := $(y) 此时x只能使用前面定义的变量y

?= 未定义则赋值

+= 追加

 

条件表达式

    特别注意的是,make 是在读取Makefile 时就计算条件表达式的值,并根据条件表达式的值来选择语句,所以,你最好不要把自动化变量(如“$@”等)放入条件表达式中,因为自动化变量是在运行时才有的。而且,为了避免混乱,make 不允许把整个条件语句分成两部分放在不同的文件中。

    ifeq(<arg1>,<arg2>)

    ifeq '<arg1>' '<arg2>'

    ifeq "<arg1>" "<arg2>"

    ifeq "<arg1>" '<arg2>'

    ifeq '<arg1>' "<arg2>"

 

    ifneq(<arg1>,<arg2>)

    ifneq '<arg1>' '<arg2>'

    ifneq "<arg1>" "<arg2>"

    ifneq "<arg1>" '<arg2>'

    ifneq '<arg1>' "<arg2>"

 

    ifdef <variable-name>

        示例一:

            bar=

            foo=$(bar)

            ifdef foo

            fobozz=yes

            else

            fobozz=no

            endif

            该示例的$(fobozz)的值是"yes"

        示例二:

            foo=

            ifdef foo

            fobozz=yes

            else

            fobozz=no

            endif

            该示例的$(fobozz)的值是"no"

 

    ifndef <variable-name>

 

函数

$(<function> <arg1,arg2,...>)

或是

${<function> <arg1,arg2,...>}

 

    $(subst <from>,<to>,<text>)

    把字串<text>中的<from>字符串替换成<to>

 

    $(patsubst <pattern>,<replacement>,<text>)

    查找<text>中的单词(单词以“空格”、“Tab”或“回车”“换行”分隔)是否符合模式<pattern>,如果匹配的话,则以<replacement>替换。这里,<pattern>可以包括通配符“%”,表示任意长度的字串。如果<replacement>中也包含“%”,那么,<replacement>中的这个“%”将是<pattern>中的那个“%”所代表的字串。(可以用“\”来转义,以“\%”来表示真实含义的“%”字符)

 

    $(strip <string>)

    去掉<string>字串中开头和结尾的空字符

 

    $(findstring <find>,<in>)

    在字串<in>中查找<find>字串,如果找到,那么返回<find>,否则返回空字符串

 

    $(filter <pattern...>,<text>)

    以<pattern>模式过滤<text>字符串中的单词,保留符合模式<pattern>的单词。可以有多个模式

 

    $(filter-out <pattern...>,<text>)

    以<pattern>模式过滤<text>字符串中的单词,去除符合模式<pattern>的单词。可以有多个模式

 

    $(sort <list>)

    给字符串<list>中的单词排序(升序),sort 函数会去掉<list>中相同的单词

 

    $(word <n>,<text>)

    取字符串<text>中第<n>个单词。(从一开始)

 

    $(wordlist <s>,<e>,<text>)

    从字符串<text>中取从<s>开始到<e>的单词串。<s>和<e>是一个数字

 

    $(words <text>)

    统计<text>中字符串中的单词个数

 

    $(firstword <text>)

    取字符串<text>中的第一个单词

 

文件名操作函数

    $(dir <names...>)

    从文件名序列<names>中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”    $(dir src/foo.c hacks)返回值是“src/ ./”

 

    $(notdir <names...>)

    从文件名序列<names>中取出非目录部分。非目录部分是指最后一个反斜杠(“/”)之后的部分    $(notdir src/foo.c hacks)返回值是“foo.c hacks”

 

    $(suffix <names...>)

    返回文件名序列<names>的后缀序列,如果文件没有后缀,则返回空字串    $(suffix src/foo.c src-1.0/bar.c hacks)返回值是“.c .c”

 

    $(basename <names...>)

    返回文件名序列<names>的前缀序列,如果文件没有前缀,则返回空字串    $(basename src/foo.c src-1.0/bar.c hacks)返回值是“src/foo src-1.0/bar hacks”

 

    $(addsuffix <suffix>,<names...>)

    把后缀<suffix>加到<names>中的每个单词后面    $(addsuffix .c,foo bar)返回值是“foo.c bar.c”

 

    $(addprefix <prefix>,<names...>)

    把前缀<prefix>加到<names>中的每个单词后面    $(addprefix src/,foo bar)返回值是“src/foo src/bar”

 

    $(join <list1>,<list2>)

    把<list2>中的单词对应地加到<list1>的单词后面。如果<list1>的单词个数要比<list2>的多,那么,<list1>中的多出来的单词将保持原样。如果<list2>的单词个数要比<list1>多,那么,<list2>多出来的单词将被复制到<list2>中    $(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”

 

foreach 函数

    $(foreach <var>,<list>,<text>)

    这个函数的意思是,把参数<list>中的单词逐一取出放到参数<var>所指定的变量中,然后再执行<text>所包含的表达式。每一次<text>会返回一个字符串,循环过程中,<text>的所返回的每个字符串会以空格分隔,最后当整个循环结束时,<text>所返回的每个字符串所组成的整个字符串(以空格分隔)将会是foreach函数的返回值

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值