`

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函数的返回值

 

分享到:
评论

相关推荐

    Makefile完全笔记

    Makefile完全笔记是关于构建自动化工具Makefile的详尽指南,它帮助开发者高效地管理和编译项目。Makefile定义了一系列的规则,告诉make程序如何构建、编译和链接源代码,形成可执行文件。以下是对Makefile核心概念的...

    nginx使用指南.pdf

    Nginx 使用指南 一. Nginx 基础知识 Nginx 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。Nginx 的主要特性包括处理静态文件、索引文件和自动索引、无缓存的反向代理加速、简单的...

    GNU make中文完全手册

    《GNU make中文完全手册》是一本详尽的指南,旨在帮助读者全面理解并掌握GNU make这一在构建系统中广泛使用的工具。以下是从该手册中提取的关键知识点,涵盖makefile的基础概念、规则、命令、变量以及高级特性。 ##...

    Makefile-Tutorial-zh-CN:Makefile 教程

    学习 Makefiles内附可口示例 :chestnut:我之所以编写这份指南,是因为我绝不可能完全掌握 Makefiles。 它们似乎充斥着各种隐藏规则和晦涩难懂的符号,还有就是简单的问题复杂化。为此,我静坐数周,尽我所能地阅读了...

    linux内核完全注释.pdf

    - 包括但不限于概述、文件功能介绍、代码注释、难点解析及参考资料等。 - **后续研究指导**:最后一章提供进一步学习Linux系统的方法和着手点。 #### 三、书籍详细内容分析 - **序言**:介绍本书的目的、适合读者...

    嵌入式Linux应用开发完全手册韦东山完整版

    《嵌入式Linux应用开发完全手册》是韦东山撰写的一本权威指南,全面涵盖了嵌入式Linux领域的关键技术和实践。这本书旨在帮助开发者理解和掌握如何在嵌入式系统上运用Linux进行应用程序开发,以及如何进行Linux内核...

    完全手册Linux系统下C程序开发详解 pdf

    《Linux系统下C程序开发详解》不只是一本入门指南,它也是一本帮助开发者提升技能的实用手册。从基础的开发环境搭建到高级的系统级编程,从理论到实践,作者用通俗易懂的语言和丰富的实例,为读者提供了一条清晰的...

    vxworks bsp 开发指南

    - **详细的启动序列**:详细描述了从上电到操作系统完全运行的整个过程。 #### 6. 结论 通过学习《VxWorks BSP 开发指南》,开发者能够更加深入地理解如何为特定硬件平台开发出高效且稳定的 BSP。这份文档不仅涵盖...

    GNU make指南

    ### GNU make指南知识点详解 #### 一、引言 GNU Make 是一款强大的自动化构建工具,广泛应用于 Unix 和 Linux 系统中的软件项目管理。通过利用 Makefile 文件定义的规则,GNU Make 能够自动化地执行复杂的编译和...

    Qt程序开发完全手册 .pdf

    ### Qt程序开发完全手册知识点概览 #### 第一章:LINUX图形用户界面GUI介绍 **1.1 常用GUI介绍** 1. **XWindow** - XWindow是Linux及其他类UNIX系统的标准GUI环境。 - 特点:采用客户端/服务器架构,具有良好的...

    [嵌入式Linux应用开发完全手册].完整版

    ### 嵌入式Linux应用开发完全手册知识点总结 #### 一、嵌入式Linux系统概览 - **定义与特点**:嵌入式Linux是一种适用于嵌入式系统的开源操作系统,具备灵活性高、稳定性强等特点。 - **应用场景**:广泛应用于智能...

    MinGW完全包-01

    总的来说,"MinGW完全包-01"是一个非常实用的开发工具集合,对于在Windows上进行C和C++编程的开发者来说是必不可少的。通过这个包,用户可以获得一套完整的编译环境,包括编译器、链接器以及自动化构建工具,从而...

    水木代码安装指南.docx

    - **系统背景**:FireBird BBS系统是一款基于Linux/Unix环境下的Telnet BBS系统,具有超过十年的发展历史,功能强大且稳定,是高校网络环境中不可或缺的一部分。例如著名的清华大学“水木清华”及上海交通大学的...

    《嵌入式Linux应用开发完全手册》完整版电子书.pdf

    总的来说,《嵌入式Linux应用开发完全手册》是一本全方位的指南,旨在帮助读者掌握从硬件接口到软件开发的全套技能,对于想要在嵌入式Linux领域深造的人来说,是一本不可或缺的参考书。通过阅读和实践书中的内容,...

    嵌入式Linux应用开发完全手册-完整版

    本书《嵌入式Linux应用开发完全手册-完整版》旨在为读者提供一套全面且深入的嵌入式Linux系统开发指南。它覆盖了从底层硬件支持到上层图形用户界面(GUI)应用开发的所有关键方面,特别适合于初学者、大学生、研究生...

Global site tag (gtag.js) - Google Analytics