makefile笔记
来源:互联网 发布:国外电视台直播软件ios 编辑:程序博客网 时间:2024/06/05 22:41
(摘自陈皓的《跟我一起写makefile》)
定义伪目标: .PHONY:clean
makefile中的变量展开时会按照会按照变量的内容一模一样的展开,包括变量后面的空格什么的,编写makefile时要注意这一点。
自动变量
Makefile 中很多时候通过自动变量来简化书写, 各个自动变量的含义如下:
makefile常用函数
语法$(<function> <arguments>)
字符串函数
字符串替换函数: $(subst <from>,<to>,<text>)
功能: 把字符串<text>
中的 <from>
替换为<to>
返回: 替换过的字符串
all: @echo $(subst t,e,maktfilt) <-- 将t替换为e
模式字符串替换函数:$(patsubst <pattern>,<replacement>,<text>)
功能: 查找<text>
中的单词(单词以”空格”, “tab”, “换行”来分割) 是否符合 <pattern>,
符合的话, 用<replacement>
替代.
返回: 替换过的字符串
all: @echo $(patsubst %.c,%.o,programA.c programB.c)
去空格函数:$(strip <string>)
功能: 去掉 <string>
字符串中开头和结尾的空字符
返回: 被去掉空格的字符串值
VAL := " aa bb cc "all: @echo "去除空格前: " $(VAL) @echo "去除空格后: " $(strip $(VAL))
去除空格前: aa bb cc
去除空格后: aa bb cc
查找字符串函数: $(findstring <find>,<in>)
功能: 在字符串 <in>
中查找 <find>
字符串
返回: 如果找到, 返回 <find>
字符串, 否则返回空字符串
VAL := " aa bb cc "all: @echo $(findstring aa,$(VAL)) @echo $(findstring ab,$(VAL))
aa
过滤函数: $(filter <pattern...>,<text>)
功能: 以 <pattern>
模式过滤字符串 <text>
, 保留 符合模式 <pattern>
的单词, 可以有多个模式
返回: 符合模式 <pattern>
的字符串
all: @echo $(filter %.o %.a,program.c program.o program.a)
program.o program.a
反过滤函数: $(filter-out <pattern...>,<text>)
功能: 以 <pattern>
模式过滤字符串 <text>
, 去除 符合模式 <pattern>
的单词, 可以有多个模式
返回: 不符合模式 <pattern>
的字符串
all: @echo $(filter-out %.o %.a,program.c program.o program.a)
program.c
排序函数: $(sort <list>)
功能: 给字符串 <list>
中的单词排序 (升序)
返回: 排序后的字符串
all: @echo $(sort bac abc acb cab)
abc acb bac cab
取单词函数: $(word <n>,<text>)
功能: 取字符串 <text>
中的 第<n>
个单词 (n从1开始)
返回:<text>
中的第<n>
个单词, 如果<n>
比 <text>
中单词个数要大, 则返回空字符串
all: @echo $(word 1,aa bb cc dd) @echo $(word 5,aa bb cc dd) @echo $(word 4,aa bb cc dd)
aa
dd
取单词串函数: $(wordlist <s>,<e>,<text>)
功能: 从字符串<text>
中取从<s>
开始到<e>
的单词串. <s>
和<e>
是一个数字.
返回: 从<s>
到<e>
的字符串
all: @echo $(wordlist 1,3,aa bb cc dd) @echo $(word 5,6,aa bb cc dd) @echo $(word 2,5,aa bb cc dd)
aa bb cc
bb
单词个数统计函数: $(words <text>)
功能: 统计字符串 <text>
中单词的个数
返回: 单词个数
all: @echo $(words aa bb cc dd) @echo $(words aabbccdd) @echo $(words )
4
1
0
首单词函数: $(firstword <text>)
功能: 取字符串 <text>
中的第一个单词
返回: 字符串<text>
中的第一个单词
all: @echo $(firstword aa bb cc dd) @echo $(firstword aabbccdd) @echo $(firstword )
aa
aabbccdd
3.4.2 文件名函数
取目录函数:$(dir <names...>)
功能: 从文件名序列<names>
中取出目录部分
返回: 文件名序列<names>
中的目录部分
all: @echo $(dir /home/a.c ./bb.c ../c.c d.c)
/home/ ./ ../ ./
取文件函数: $(notdir <names...>)
功能: 从文件名序列 <names>
中取出非目录部分
返回: 文件名序列 <names>
中的非目录部分
all: @echo $(notdir /home/a.c ./bb.c ../c.c d.c)
a.c bb.c c.c d.c
取后缀函数: $(suffix <names...>)
功能: 从文件名序列 <names>
中取出各个文件名的后缀
返回: 文件名序列 <names>
中各个文件名的后缀, 没有后缀则返回空字符串
all: @echo $(suffix /home/a.c ./b.o ../c.a d)
.c .o .a
取前缀函数: $(basename <names...>)
功能: 从文件名序列<names>
中取出各个文件名的前缀
返回: 文件名序列 <names>
中各个文件名的前缀, 没有前缀则返回空字符串
all: @echo $(basename /home/a.c ./b.o ../c.a /home/.d .e)
/home/a ./b ../c /home/
加后缀函数: $(addsuffix <suffix>,<names...>)
功能: 把后缀 <suffix>
加到<names>
中的每个单词后面
返回: 加过后缀的文件名序列
all: @echo $(addsuffix .c,/home/a b ./c.o ../d.c)
/home/a.c b.c ./c.o.c ../d.c.c
加前缀函数:$(addprefix <prefix>,<names...>)
功能: 把前缀 <prefix>
加到 <names>
中的每个单词前面
返回: 加过前缀的文件名序列
all: @echo $(addprefix test_,/home/a.c b.c ./d.c)
test_/home/a.c test_b.c test_./d.c
连接函数: $(join <list1>,<list2>)
功能: <list2>
中对应的单词加到 <list1>
后面
返回: 连接后的字符串
all: @echo $(join a b c d,1 2 3 4) @echo $(join a b c d,1 2 3 4 5) @echo $(join a b c d e,1 2 3 4)
a1 b2 c3 d4
a1 b2 c3 d4 5
a1 b2 c3 d4 e
foreach
语法:
$(foreach <var>,<list>,<text>)
这个函数的意思是,把参数list;中的单词逐一取出放到参数var;所指定的变量中,然后再执行text;所包含的表达式。每一次text;会返回一个字符串,循环过程中,text;的所返回的每个字符串会以空格分隔,最后当整个循环结束时,text;所返回的每个字符串所组成的整个字符串(以空格分隔)将会是foreach函数的返回值。
所以,var;最好是一个变量名,list;可以是一个表达式,而text;中一般会使用var;这个参数来依次枚举list;中的单词。
targets := a b c dobjects := $(foreach i,$(targets),$(i).o)all: @echo $(targets) @echo $(objects)
a b c d
a.o b.o c.o d.o
if
这里的if是个函数, 和前面的条件判断不一样, 前面的条件判断属于Makefile的关键字
语法:
$(if <condition>,<then-part>)
$(if <condition>,<then-part>,<else-part>)
val := aobjects := $(if $(val),$(val).o,nothing)no-objects := $(if $(no-val),$(val).o,nothing)all: @echo $(objects) @echo $(no-objects)
a.o
nothing
call - 创建新的参数化函数
语法:
$(call <expression>,<parm1>,<parm2>,<parm3>...)
log = "====debug====" $(1) "====end===="all: @echo $(call log,"正在 Make")
====debug==== 正在 Make ====end====
origin - 判断变量的来源
语法:
$(origin <variable>)
返回值有如下类型:
val-in-file := test-fileoverride val-override := test-overrideall: @echo $(origin not-define) # not-define 没有定义 @echo $(origin CC) # CC 是Makefile默认定义的变量 @echo $(origin PATH) # PATH 是 bash 环境变量 @echo $(origin val-in-file) # 此Makefile中定义的变量 @echo $(origin val-in-cmd) # 这个变量会加在 make 的参数中 @echo $(origin val-override) # 此Makefile中定义的override变量 @echo $(origin @) # 自动变量, 具体前面的介绍
undefined
default
environment
file
command line
override
automatic
shell
语法:
$(shell <shell command>)
它的作用就是执行一个shell命令, 并将shell命令的结果作为函数的返回.
作用和 <shell command>
一样, ` 是反引号
make 控制函数
产生一个致命错误: $(error <text ...>)
功能: 输出错误信息, 停止Makefile的运行
all: $(error there is an error!) @echo "这里不会执行!"
Makefile:2: * there is an error!. Stop.
输出警告: $(warning <text ...>)
功能: 输出警告信息, Makefile继续运行
all: $(warning there is an warning!) @echo "这里会执行!"
Makefile:2: there is an warning!
这里会执行!
- Makefile笔记
- makefile 笔记
- makefile 笔记
- Makefile笔记
- 笔记:makefile
- Makefile 笔记
- makefile笔记
- makefile笔记
- makefile笔记
- makefile笔记
- Makefile 笔记
- Makefile 笔记
- makefile 笔记
- Makefile笔记
- Makefile笔记
- makefile笔记
- Makefile笔记
- Makefile笔记
- Keras实现卷积神经网络
- 远程桌面按键失效变成快捷键问题
- Linux系统监控sar命令详细解析
- php开启错误提示适用于没有修改php.ini的权限
- Python:Pygame的图形接口
- makefile笔记
- 网络流
- 使用springmvc实现文件下载
- fiddler的安装与使用
- 奶牛浴场---悬线法之算法1
- 5、debian搭建tftp服务器
- 你要知道的C与C++的区别
- 二叉树及二叉树的基本操作(基础面试题型)
- 分布式本地缓存的一种实现