makefile常用指令和常见变量。

引用文章A:http://blog.csdn.net/liang13664759/article/details/1771246

文章介绍:非常详细的文章,讲解上都是比较基础的知识。

本文可能会持续更新部分引用文章。但博文本身更新内容并不会太多。主要因为个人写作水平问题,并不适合讲解专业性质的知识,容易误人子弟。

文章中会记录一些比较常用的指令和函数,方便快速查找。

一,基本使用。

makefile基本依赖规则:默认情况下,会找到第一个目标指令,然后检测其对应依赖,然后进行初步的索引和指令执行(通常为编译指令)。在依赖上,我们可以使用模式规则(%.o : %c)的方式来动态识别依赖。

上述方式能够满足大部分基本情况。再复杂的情景,则不是本文需要完成的内容里。

一个例子:

%.o : %c

  gcc -c %(<) -o $(@)

dest : main.o

  gcc main.o -o dest

这个例子中,main.o会通过上述模式规则自动被生成main.o(需要已存在main.c)。

二,常用操作和变量。

1,伪目标:.PHONY: 用来指定目标为 伪目标。常见的伪目标为:clean。此指令通常省略。

2,常用make参数:

  *:  -n,--just-print,--dry-run,--recon。不执行参数,这些参数只是打印命令,不管目标是否更新,把规则和连带规则下的命令打印出来,但不执行,这些参数对于我们调试makefile很有用处。

  *:  -t,--touch。  这个参数的意思就是把目标文件的时间更新,但不更改目标文件。也就是说,make假装编译目标,但不是真正的编译目标,只是把目标变成已编译过的状态。

  *:-W <file>,--what-if=<file>,--assume-new=<file>,--new-file=<file>。  这个参数需要指定一个文件。一般是是源文件(或依赖文件),Make会根据规则推导来运行依赖于这个文件的命令,一般来说,可以和“-n”参数一同使用,来查看这个依赖文件所发生的规则命令。

  *:-q,--question。  这个参数的行为是找目标的意思,也就是说,如果目标存在,那么其什么也不会输出,当然也不会执行编译,如果目标不存在,其会打印出一条出错信息。

  *:-d,相当于“--debug=a”。

  *:-e,--environment-overrides。  指明环境变量的值覆盖makefile中定义的变量的值。

  *:-f=<file>,--file=<file>,--makefile=<file>。  指定需要执行的makefile。

  *:-I <dir>,--include-dir=<dir>。  指定一个被包含makefile的搜索目标。可以使用多个“-I”参数来指定多个目录。

  *:-p,--print-data-base。  输出makefile中的所有数据,包括所有的规则和变量。这个参数会让一个简单的makefile都会输出一堆信息。如果你只是想输出信息而不想执行makefile,你可以使用“make -qp”命令。如果你想查看执行makefile前的预设变量和规则,你可以使用“make –p –f /dev/null”。这个参数输出信息会包含着你的makefile文件的文件名和行号,所以,用这个参数来调试你的makefile会是很有用的,特别是当你的环境变量很复杂的时候。

  *:-q,--question。  不运行命令,也不输出。仅仅是检查所指定的目标是否需要更新。如果是0则说明要更新,如果是2则说明有错误发生。

  *:-r,--no-builtin-rules。  禁止make使用任何隐含规则。

  *:-R,--no-builtin-variabes。  禁止make使用任何作用于变量上的隐含规则。

3,自动化变量:

  *:[email protected]  表示规则中的目标文件集。在模式规则中,如果有多个目标,那么,"[email protected]"就是匹配于目标中模式定义的集合。

  *:$%  仅当目标是函数库文件中,表示规则中的目标成员名。例如,如果一个目标是"foo.a(bar.o)",那么,"$%"就是"bar.o","[email protected]"就是"foo.a"。如果目标不是函数库文件(Unix下是[.a],Windows下是[.lib]),那么,其值为空。 

  *:$<  依赖目标中的第一个目标名字。如果依赖目标是以模式(即"%")定义的,那么"$<"将是符合模式的一系列的文件集。注意,其是一个一个取出来的。

  *:$?  所有比目标新的依赖目标的集合。以空格分隔。

  *:$^  所有的依赖目标的集合。以空格分隔。如果在依赖目标中有多个重复的,那个这个变量会去除重复的依赖目标,只保留一份。

  *:$+  这个变量很像"$^",也是所有依赖目标的集合。只是它不去除重复的依赖目标。

  *:$* 这个变量表示目标模式中"%"及其之前的部分。

三,常用函数。

函数调用,很像变量的使用,也是以“$”来标识的,其语法如下:$(<function> <arguments> )

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

  名称:字符串替换函数——subst。
  功能:把字串<text>中的<from>字符串替换成<to>。
  返回:函数返回被替换过后的字符串。
$(patsubst <pattern>,<replacement>,<text> ) 
  名称:模式字符串替换函数——patsubst。
  功能:查找<text>中的单词(单词以“空格”、“Tab”或“回车”“换行”分隔)是否符合模式<pattern>,如果匹配的话,则以<replacement>替换。这里,<pattern>可以包括通配符“%”,表示任意长度的字串。如果<replacement>中也包含“%”,那么,<replacement>中的这个“%”将是<pattern>中的那  个“%”所代表的字串。(可以用“/”来转义,以“/%”来表示真实含义的“%”字符)
  返回:函数返回被替换过后的字符串。
$(strip <string> )
  名称:去空格函数——strip。
  功能:去掉<string>字串中开头和结尾的空字符。
  返回:返回被去掉空格的字符串值。
$(findstring <find>,<in> )
  名称:查找字符串函数——findstring。
  功能:在字串<in>中查找<find>字串。
  返回:如果找到,那么返回<find>,否则返回空字符串。
$(filter <pattern...>,<text> )
  名称:过滤函数——filter。
  功能:以<pattern>模式过滤<text>字符串中的单词,保留符合模式<pattern>的单词。可以有多个模式。
  返回:返回符合模式<pattern>的字串。
$(filter-out <pattern...>,<text> )
  名称:反过滤函数——filter-out。
  功能:以<pattern>模式过滤<text>字符串中的单词,去除符合模式<pattern>的单词。可以有多个模式。
  返回:返回不符合模式<pattern>的字串。
$(sort <list> )
  名称:排序函数——sort。
  功能:给字符串<list>中的单词排序(升序)。
  返回:返回排序后的字符串。
$(word <n>,<text> )
  名称:取单词函数——word。
  功能:取字符串<text>中第<n>个单词。(从一开始)
  返回:返回字符串<text>中第<n>个单词。如果<n>比<text>中的单词数要大,那么返回空字符串。
$(wordlist <s>,<e>,<text> ) 
  名称:取单词串函数——wordlist。
  功能:从字符串<text>中取从<s>开始到<e>的单词串。<s>和<e>是一个数字。
  返回:返回字符串<text>中从<s>到<e>的单词字串。如果<s>比<text>中的单词数要大,那么返回空字符串。如果<e>大于<text>的单词数,那么返回从<s>开始,到<text>结束的单词串。
$(words <text> )
  名称:单词个数统计函数——words。
  功能:统计<text>中字符串中的单词个数。
  返回:返回<text>中的单词数。
$(firstword <text> )
  名称:首单词函数——firstword。
  功能:取字符串<text>中的第一个单词。
  返回:返回字符串<text>的第一个单词。
$(dir <names...> ) 
  名称:取目录函数——dir。
  功能:从文件名序列<names>中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”。
  返回:返回文件名序列<names>的目录部分。
$(notdir <names...> ) 
  名称:取文件函数——notdir。
  功能:从文件名序列<names>中取出非目录部分。非目录部分是指最后一个反斜杠(“/”)之后的部分。
  返回:返回文件名序列<names>的非目录部分。
  示例: $(notdir src/foo.c hacks)返回值是“foo.c hacks”。
$(suffix <names...> ) 
  名称:取后缀函数——suffix。
  功能:从文件名序列<names>中取出各个文件名的后缀。
  返回:返回文件名序列<names>的后缀序列,如果文件没有后缀,则返回空字串。
  示例:$(suffix src/foo.c src-1.0/bar.c hacks)返回值是“.c .c”。
$(basename <names...> )
  名称:取前缀函数——basename。
  功能:从文件名序列<names>中取出各个文件名的前缀部分。
  返回:返回文件名序列<names>的前缀序列,如果文件没有前缀,则返回空字串。
  示例:$(basename src/foo.c src-1.0/bar.c hacks)返回值是“src/foo src-1.0/bar hacks”。
$(addsuffix <suffix>,<names...> ) 
  名称:加后缀函数——addsuffix。
  功能:把后缀<suffix>加到<names>中的每个单词后面。
  返回:返回加过后缀的文件名序列。
  示例:$(addsuffix .c,foo bar)返回值是“foo.c bar.c”。
$(addprefix <prefix>,<names...> ) 
  名称:加前缀函数——addprefix。
  功能:把前缀<prefix>加到<names>中的每个单词后面。
  返回:返回加过前缀的文件名序列。
  示例:$(addprefix src/,foo bar)返回值是“src/foo src/bar”。
$(join <list1>,<list2> )
  名称:连接函数——join。
  功能:把<list2>中的单词对应地加到<list1>的单词后面。如果<list1>的单词个数要比<list2>的多,那么,<list1>中的多出来的单词将保持原样。如果<list2>的单词个数要比<list1>多,那么,<list2>多出来的单词将被复制到<list2>中。
  返回:返回连接过后的字符串。
  示例:$(join aaa bbb , 111 222 333)返回值是“aaa111 bbb222 333”。
$(foreach <var>,<list>,<text> )
  这个函数的意思是,把参数<list>中的单词逐一取出放到参数<var>所指定的变量中,然后再执行<text>所包含的表达式。每一次<text>会返回一个字符串,循环过程中,<text>的所返回的每个字符串会以空格分隔,最后当整个循环结束时,<text>所返回的每个字符串所组成的整个字符串(以空格分隔)将会是foreach函数的返回值。
  所以,<var>最好是一个变量名,<list>可以是一个表达式,而<text>中一般会使用<var>这个参数来依次枚举<list>中的单词。举个例子:
$(if <condition>,<then-part> ) 
$(if <condition>,<then-part>,<else-part> )
  可见,if函数可以包含“else”部分,或是不含。即if函数的参数可以是两个,也可以是三个。<condition>参数是if的表达式,如果其返回的为非空字符串,那么这个表达式就相当于返回真,于是,<then-part>会被计算,否则<else-part>会被计算。、
  而if函数的返回值是,如果<condition>为真(非空字符串),那个<then-part>会是整个函数的返回值,如果<condition>为假(空字符串),那么<else-part>会是整个函数的返回值,此时如果<else-part>没有被定义,那么,整个函数返回空字串。
$(call <expression>,<parm1>,<parm2>,<parm3>...)
  当make执行这个函数时,<expression>参数中的变量,如$(1),$(2),$(3)等,会被参数<parm1>,<parm2>,<parm3>依次取代。而<expression>的返回值就是call函数的返回值。例如:

shell函数
  shell函数也不像其它的函数。顾名思义,它的参数应该就是操作系统Shell的命令。它和反引号“`”是相同的功能。这就是说,shell函数把执行操作系统命令后的输出作为函数返回。于是,我们可以用操作系统命令以及字符串处理命令awk,sed等等命令来生成一个变量,如:
  contents := $(shell cat foo)
  files := $(shell echo *.c)
  注意,这个函数会新生成一个Shell程序来执行命令,所以你要注意其运行性能,如果你的Makefile中有一些比较复杂的规则,并大量使用了这个函数,那么对于你的系统性能是有害的。特别是Makefile的隐晦的规则可能会让你的shell函数执行的次数比你想像的多得多。

时间: 2024-11-17 01:31:45

makefile常用指令和常见变量。的相关文章

Linux常用指令---$PATH (环境变量)

实例一:设置临时环境变量 在linux服务器上设置临时环境变量,当退出shell环境时,自动销毁 export JAVA_HOME=/usr/java/jdk1.6.0_32 export classpath=$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar export ANT_HOME=/usr/local/apache-ant-1.9.2 export PATH=$ANT_HOME/bin:$PATH env 查看系统当前所有环境变量 实例二.在PATH这个变

Dockerfile常用指令详解&镜像缓存特性

Dockerfile简介 Dockerfile 是Docker中用于定义镜像自动化构建流程的配置文件.在Dockerfile中,包含了构建镜像过程中需要执行的命令和其他操作.通过Dockerfile可以更加清晰,明确的给定Docker镜像的制作过程,由于仅是简单,小体积的文件,在网络等介质中传递的速度快,能够更快的实现容器迁移和集群部署.Dockerfile是一个文本文件,其内包含了一条条的指令,每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建. 相对于提交容器修改在进行镜像迁

Windows下常用的100个CMD指令以及常见的操作

Windows下常用的100个CMD指令以及常见的操作 常用的100个CMD指令 gpedit.msc-–组策略 2. sndrec32---录音机 3. Nslookup---IP地址侦测器 ,是一个 监测网络中 DNS 服务器是否能正确实现域名解析的命令行工具. 它在 Windows NT/2000/XP 中均可使用 , 但在 Windows 98 中却没有集成这一个工具. 4. explorer---打开资源管理器 5. logoff---注销命令 6. shutdown---60秒倒计时

Makefile 隐含规则,模式规则,常见变量

 隐含规则复杂的Makefile一般会使用隐含规则内的变量来简化编译处理.将隐含规则中使用的变量分成两种:一种是命令相关的,如“CC”:一种是参数相关的,如“CFLAGS”.这些变量都是大写表示. 常用的命令变量有:CC C语言编译程序.默认命令是“cc”CXX C++语言编译程序.默认命令是“g++”CPP C程序的预处理器(输出是标准输出设备).默认命令是“$(CC) –E”RM 删除文件命令.默认命令是“rm –f” 参数相关的变量:CFLAGS C语言编译器参数CXXFLAGS C++语

MySQL常用指令,java,php程序员,数据库工程师必备。程序员小冰常用资料整理

MySQL常用指令,java,php程序员,数据库工程师必备.程序员小冰常用资料整理 MySQL常用指令(备查) 最常用的显示命令: 1.显示数据库列表. show databases; 2.显示库中的数据表: use mysql; show tables; 3.显示数据表的结构: describe 表名; 4.建库: create database 库名; 5.建表: use 库名: create table 表名 (字段设定列表): 6.删库和删表: drop database 库名; dr

Angular JS从入门基础 mvc三层架构 常用指令

Angular JS从入门基础  mvc模型 常用指令 ★ 最近一直在复习AngularJS,它是一款优秀的前端JS框架,已经被用于Google的多款产品当中.AngularJS有着诸多特性,最为核心的是:MVC.模块化.自动化双向数据绑定.语义化标签.依赖注入等等. 1.常用指令 AngularJS 通过指令扩展了HTML,且通过表达式绑定数据到 HTML.下面我们看一下AngularJS中的常用指令. (1).基本概念 指令:AngularJS中,通过扩展HTML的属性提供功能.所以,ng-

Angular 2 模板语法与常用指令简介

一.模板语法简介 插值表达式 <div>Hello {{name}}</div> 等价于 <div [textContent]="interpolate(['Hello'], [name])"></div> 模板表达式 1.属性绑定 1.1输入属性的值为常量 <show-title title="Some Title"></show-title> 等价于 <show-title [titl

走进AngularJs(二) ng模板中常用指令的使用方式

通过使用模板,我们可以把model和controller中的数据组装起来呈现给浏览器,还可以通过数据绑定,实时更新视图,让我们的页面变成动态的.ng的模板真是让我爱不释手.学习ng道路还很漫长,从模板开始入手是个不错方式,因为这部分内容相对简单好理解,而且是视图层的东西,大家都喜欢可以立马看得见的东西嘛.本篇我将搜罗模板中的常用指令一一测试,了解其使用方法,有点像背单词的感觉,会比较枯燥.不过对于初学,这样的枯燥是必须要经历的,开始~ 一.模板中可使用的东西及表达式 模板中可以使用的东西包括以下

Markdown语法 与 Hexo常用指令

Markdown语法 与 Hexo常用指令 Markdown Hexo Markdown是一种超轻量级的标记语言,常用的标记符号不超过十个,相对于更为复杂的HTML标记语言来讲,Markdown实在简便多了,因此学习成本也不是很大.更多关于Markdown的认识,我们可以参考:认识与入门 Markdown Markdown工具 关于支持Markdown的书写工具网络上有很多推荐,这里不再一一列举,常用的有: Mou:外文世界对 MarkDown 的热衷在 Mac 上可见一斑,目前虽是免费的,但功