分类: LINUX
2011-01-22 17:17:51
<一>. 变量高级用法
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 变量追加值
<二>。 目标变量
示例:
prog : CFLAGS = -g
prog : prog.o foo.o bar.o
$(CC) $(CFLAGS) prog.o foo.o bar.o
不管全局的CFLAGS是什么值,在prog目标以及其所引发的所有规则中,$(CFLAGS)值都是-g
override是针对于系统环境传入的变量,或是make命令行指定的变量.
<三>. 模式变量
%.o : CFLAGS = -O
<四>. 使用条件判断
else
endif
a. ifeq (
ifeq '
ifeq "
比较参数arg1,arg2的值是否相同
b. ifneq (
ifneq '
ifneq "
c. ifdef
变量variable-name的值非空,表达式为真,否则为假。
示例:
bar =
foo = $(bar)
ifdef foo
frob = yes
else
frob = no
endif
d. ifndef
<五>. 使用函数
$(
a. 字符串处理函数
$(subst
名称: 字符串替换函数--subst
功能: 把字串
示例:
$(subst ee,EE,feet on the street)
结果:fEEt on the strEEt
$(patsubst
名称: 模式字符串替换函数--patsubst
功能: 查找
示例:
$(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
名称: 去空格函数--strip
功能: 去掉
示例:
$(strip a b c ) --> "a b c"
$(findstring
名称: 查找字符串函数--findstring
功能: 在字串
示例:
$(findstring a,a b c) --> "a"
$(findstring a,b c) --> ""
$(filter
名称: 过滤函数--filter
功能: 以
示例:
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
名称: 反过滤函数--filter-out
功能: 以
示例:
objects = main1.o foo.o main2.o bar.o
mains = main1.o main2.o
$(filter-out $(mains),$(objects)) --> foo.o bar.o
$(sort )
名称: 排序函数--sort
功能:给字符串中的单词排序(升序),返回排序后的字符串
示例:
$(sort foo bar lose) --> bar foo lose
sort函数会去掉中相同的单词
$(word
名称: 取单词函数--word
功能: 取字符串
示例:
$(word 2, foo bar bza) --> bar
$(wordlist ,
名称: 取单词串函数--wordlist
功能: 从字符串开始到,
示例:
$(wordlist 2,3,foo bar gza) --> bar gza
$(words
名称: 单词个数统计函数--words
功能: 统计
示例:
$(words, foo bar gaz) --> 3
$(firstword
名称: 首单词函数--firstword
功能: 取字符串
示例:
$(firstword foo bar) --> foo
b. 文件名操作函数
c. foreach函数
$(foreach ,,
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
<六> 自动化变量
$@ 表示规则中的目标文件集
$< 依赖目标中的第一个目标名字
$^ 所有的依赖目标集合
$? 所有比目标新的依赖目标的集合
$+ 所有依赖目标集合,不去除重复的依赖目标