makefile 文法小结

2 篇文章 0 订阅
1 篇文章 0 订阅

<一>. 变量高级用法

a. 替换变量中的共有部分,格式: $(var:a=b) 或是 ${var:a=b}
   意思是把变量var中所有以a字串结尾的a替换成b字串.
示例:
    foo := a.o b.o c.o
    bar := $(foo:.o=.c)
    $(bar)展开的值就是a.c b.c c.c

   类似的替换为“静态模式"
    bar := $(foo:%.o=%.c)      展开后跟上例一个效果。

b. 变量赋值
    obj = a.o b.o      一般赋值,可以引用前后面的变量
    obj := a.o b.o       赋值,只可以引用前面的变量
    obj ?= a.o b.o     如果之前有定义过obj,则此次赋值无效,若没有,则有效
    obj += a.o b.o     变量追加值


<二>。 目标变量
    <target ...> : <variable-assignment>
    <target ...> : overide <variable-assignment>
示例:
    prog : CFLAGS = -g
    prog : prog.o foo.o bar.o
        $(CC) $(CFLAGS) prog.o foo.o bar.o
不管全局的CFLAGS是什么值,在prog目标以及其所引发的所有规则中,$(CFLAGS)值都是-g
override是针对于系统环境传入的变量,或是make命令行指定的变量.

<三>. 模式变量
    <pattern ...> : <variable-assignment>
    <pattern ...> : override <variable-assignment>

    %.o : CFLAGS = -O

<四>. 使用条件判断
    <conditional-derective>
    <text-if-true>
    else
    <text-if-false>
    endif
<conditional-directive>表示条件关键字,如ifeq,一共有四种
a.     ifeq (<arg1>, <arg2>)
    ifeq '<arg1>' '<arg2>'
    ifeq "<arg1>" "<arg2>"
比较参数arg1,arg2的值是否相同

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

c.     ifdef <variable-name>
变量variable-name的值非空,表达式为真,否则为假。
示例:
    bar =
    foo = $(bar)
    ifdef foo
    frob = yes
    else
    frob = no
    endif

d.     ifndef <variable-name>

<五>. 使用函数
$(<function> <arguments>)  或是  ${<function> <arguments>}

a. 字符串处理函数
$(subst <from>,<to>,<text>)
名称: 字符串替换函数--subst
功能: 把字串<text>中的<from>字符串替换成<to>
示例:
 $(subst ee,EE,feet on the street)
 结果:fEEt on the strEEt

$(patsubst <pattern>,<replacement>,<text>)
名称: 模式字符串替换函数--patsubst
功能: 查找<text>中的单词是否符合模式<pattern>,匹配的话,则以<replacement>替换。<pattern>可以包括通配符%,表示任意长度的字串。
示例:
 $(patsubst %.c,%.o,x.c.c bar.c)
返回结果:x.c.o bar.o
备注:
 objects = foo.o bar.o
 $(objects:.o=.c) 和 $(patsubst %.o,%.c,$(objects)) 一样结果

$(strip <string>)
名称: 去空格函数--strip
功能: 去掉<string>字符串开头和结尾的空字符。
示例:
 $(strip a b c ) --> "a b c"

$(findstring <find>,<in>)
名称: 查找字符串函数--findstring
功能: 在字串<in>中查找<find>字串
示例:
 $(findstring a,a b c)  --> "a"
 $(findstring a,b c)    --> ""

$(filter <pattern...>,<text>)
名称: 过滤函数--filter
功能: 以<pattern>模式过滤<text>字符串中的单词,保留符合模式<pattern>的单词,可以有多个模式。
示例:
 sources : foo.c bar.c baz.s ugh.h
 foo: $(sources)
  cc $(filter %.c %.s,$(sources)) -o foo
过滤后返回foo.c bar.c baz.s

$(filter-out <pattern...>,<text>)
名称: 反过滤函数--filter-out
功能: 以<pattern>模式过滤<text>字符串中的单词,去除符合模式<pattern>的单词。
示例:
 objects = main1.o foo.o main2.o bar.o
 mains = main1.o main2.o
 $(filter-out $(mains),$(objects)) --> foo.o bar.o

$(sort <list>)
名称: 排序函数--sort
功能:给字符串<list>中的单词排序(升序),返回排序后的字符串
示例:
 $(sort foo bar lose)  --> bar foo lose
sort函数会去掉<list>中相同的单词

$(word <n>,<text>)
名称: 取单词函数--word
功能: 取字符串<text>中第<n>个单词
示例:
 $(word 2, foo bar bza)  --> bar

$(wordlist <s>,<e>,<text>)
名称: 取单词串函数--wordlist
功能: 从字符串<text>中取从<s>开始到<e>的单词串。<s>,<e>是一个数字
示例:
 $(wordlist 2,3,foo bar gza) --> bar gza

$(words <text>)
名称: 单词个数统计函数--words
功能: 统计<text>中字符串中的单词个数。
示例:
 $(words, foo bar gaz) --> 3

$(firstword <text>)
名称: 首单词函数--firstword
功能: 取字符串<text>中的第一个单词
示例:
 $(firstword foo bar) --> foo

b. 文件名操作函数

c. foreach函数
$(foreach <var>,<list>,<text>)
var依次等于list中的变量,执行text中的表达式
示例:
 names := f1 f2 f3 f4
 files := $(foreach n,$(names),$(n).o)
$(files) --> f1.o f2.o f3.o f4.o

d. if 函数
$(if <condition>,<then-part>) 或是 $(if <condition>,<then-part>,<else-part>)

<六> 自动化变量
$@  表示规则中的目标文件集
$<   依赖目标中的第一个目标名字
$^ 所有的依赖目标集合
$? 所有比目标新的依赖目标的集合
$+ 所有依赖目标集合,不去除重复的依赖目标

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值