GNU makefile使用详解

5星 · 超过95%的资源 需积分: 10 4 下载量 140 浏览量 更新于2024-07-23 收藏 1.94MB PDF 举报
"GNU+makefile中文手册" GNU Makefile 是一种用于自动化编译、链接和其他构建过程的工具,它是GNU Build System的核心组成部分。这个中文手册详细介绍了如何编写和使用Makefile来管理大型项目工程。 在第一章中,概述了Makefile的基本概念和作用,强调其在软件开发中的重要性,特别是对于管理和维护复杂项目时的效率提升。准备知识部分可能涵盖了对基本编程环境和命令行操作的理解。 第二章深入介绍了GNU make,包括Makefile的结构和规则。Makefile由一系列规则组成,每个规则定义了一个或多个目标(通常是程序或库文件),这些目标依赖于其他文件,并且有相应的构建命令。2.1节简单介绍了Makefile的组成,2.2节则讲解了规则的格式,包括目标、依赖项和命令。2.3节通过一个实际示例展示了如何创建一个基本的Makefile。2.4节解释了make是如何根据依赖关系决定哪些文件需要重新构建。2.5节介绍了如何定义和使用变量,使得Makefile更易读和可复用。2.6节涉及自动规则,即make可以自动推断一些常见操作,如编译C源文件。2.7节探讨了不同风格的Makefile写法,以适应不同的项目需求。2.8节讲解了如何清理工作目录中的临时文件,保持项目整洁。 第三章是Makefile的总览,3.1节阐述了Makefile的内容,包括目标、依赖和命令等元素。3.2节提到了Makefile文件的命名规范,通常为“Makefile”或“makefile”。3.3节讨论了如何通过包含其他Makefile来组织大型项目。3.4节至3.6节介绍了几个特殊的变量,如MAKEFILES和MAKEFILE_LIST,它们在Makefile处理过程中起着关键作用。3.7节简要说明了如何自动生成Makefile,3.8节展示了如何加载另一个Makefile,3.9节详细解析了make解析Makefile的过程,包括变量取值、条件语句和规则定义。 第四章重点讲解Makefile的规则。4.1节提供了一个规则的例子,4.2节详细解析了规则的语法。4.3节和4.4节探讨了不同类型的依赖和通配符的使用,包括如何使用wildcard函数处理文件名。4.5节介绍了目录搜索机制,包括VPATH变量和vpath关键字。4.6节至4.13节进一步细化了规则的各个方面,如伪目标、强制目标、空目标、特殊目标、多目标、多规则目标以及静态模式规则,这些都是编写高效Makefile的关键知识点。 这个GNU Makefile中文手册全面地覆盖了从基础到高级的Makefile编写技巧,对于任何希望掌握构建自动化技术的开发者来说,都是一个宝贵的参考资料。通过学习和应用这些知识,开发者能够更好地管理和构建他们的项目,提高工作效率。
2010-04-13 上传
GNU MAKE的详细中文手册,目录如下: 目 录 第一章:概述 1.1 概述 1.2 准备知识 第二章:GNU make 介绍 2.1 Makefile简介 2.2 Makefile规则介绍 2.3 简单的示例 2.4 make如何工作 2.5 指定变量 2.6 自动推导规则 2.7 另类风格的makefile 2.8 清除工作目录过程文件 第三章:Makefile 总述 3.1 Makefile的内容 3.2 makefile文件的命名 3.3 包含其它makefile文件 3.4 变量 MAKEFILES 3.5 变量 MAKEFILE_LIST 3.6 其他特殊变量 3.7 makefile文件的重建 3.8 重载另外一个makefile 3.9 make如何解析makefile文件 3.9.1 变量取值 3.9.2 条件语句 3.9.3 规则的定义 3.10 总结 第四章:Makefile的规则 4.1 一个例子 4.2 规则语法 4.3 依赖的类型 4.4 文件名使用通配符 4.4.1 统配符使用举例 4.4.2 通配符存在的缺陷 4.4.3 函数wildcard 4.5 目录搜寻 4.5.1 一般搜索(变量VPATH) 4.5.2 选择性搜索(关键字vpath) 4.5.3 目录搜索的机制 4.5.4 命令行和搜索目录 4.5.5 隐含规则和搜索目录 4.5.6 库文件和搜索目录 4.6 Makefile伪目标 4.7 强制目标(没有命令或依赖的规则) 4.8 空目标文件 4.9 Makefile的特殊目标 4.10 多目标 4.11 多规则目标 4.12 静态模式 4.12.1 静态模式规则的语法 4.12.2 静态模式和隐含规则 4.13 双冒号规则 4.14 自动产生依赖 第五章:规则的命令 5.1 命令回显 5.2 命令的执行 5.3 并发执行命令 5.4 命令执行的错误 5.5 中断make的执行 5.6 make的递归执行 5.6.1 变量MAKE 5.6.2 变量和递归 5.6.3 命令行选项和递归 5.6.4 -w选项 5.7 定义命令包 5.8 空命令 第六章:Makefile中的变量 6.1 变量的引用 6.2 两种变量定义(赋值 ) 6.2.1 递归展开式变量 6.2.2 直接展开式变量 6.2.3 如何定义一个空格 6.2.4 “?=”操作符 6.3 变量的高级用法 6.3.1 变量的替换引用 6.3.2 变量的套嵌引用 6.4 变量取值 6.5 如何设置变量 6.6 追加变量值 6.7 override 指示符 6.8 多行定义 6.9 系统环境变量 6.10 目标指定变量 6.11 模式指定变量 第七章:Makefile的条件执行 7.1 一个例子 7.2 条件判断的基本语法 7.2.1 关键字“ifeq” 7.2.2 关键字“ifneq” 7.2.3 关键字“ifdef” 7.2.4 关键字“ifndef” 7.3 标记测试的条件语句 第八章:make的内嵌函数 8.1 函数的调用语法 8.2 文本处理函数 8.2.1 $(subst FROM,TO,TEXT) 8.2.2 $(patsubst PATTERN,REPLACEMENT,TEXT) 8.2.3 $(strip STRINT) 8.2.4 $(findstring FIND,IN) 8.2.5 $(filter PATTERN…,TEXT) 8.2.6 $(filter-out PATTERN...,TEXT) 8.2.7 $(sort LIST) 8.2.8 $(word N,TEXT) 8.2.9 $(wordlist S,E,TEXT) 8.2.10 $(words TEXT) 8.2.11 $(firstword NAMES…) 8.3 文件名处理函数 8.3.1 $(dir NAMES…) 8.3.2 $(notdir NAMES…) 8.3.3 $(suffix NAMES…) 8.3.4 $(basename NAMES…) 8.3.5 $(addsuffix SUFFIX,NAMES…) 8.3.6 $(addprefix PREFIX,NAMES…) 8.3.7 $(join LIST1,LIST2) 8.3.8 $(wildcard PATTERN) 8.4 foreach 函数 8.5 if 函数 8.6 call函数 8.7 value函数 8.8 eval函数 8.9 origin函数 8.10 shell函数 8.11 make的控制函数 8.11.1 $(error TEXT…) 8.11.2 $(warning TEXT…) 第九章:执行make 9.1 指定makefile文件 9.2 指定终极目标 9.3 替代命令的执行 9.4 防止特定文件重建 9.5 替换变量定义 9.6 使用make进行编译测试 9.7 make的命令行选项 第十章:make的隐含规则 10.1 隐含规则的使用 10.2 make的隐含规则一览 10.3 隐含变量 10.3.1 代表命令的变量 10.3.2 命令参数的变量 10.4 make隐含规则链 10.5 模式规则 10.5.1 模式规则介绍 10.5.2 模式规则示例 10.5.3 自动化变量 10.5.4 模式的匹配 10.5.5 万用规则 10.5.6 重建内嵌隐含规则 10.6 缺省规则 10.7 后缀规则 10.8 隐含规则搜索算法 第十一章:使用make更新静态库文件 11.1 库成员作为目标 11.2 静态库的更新 11.2.1 更新静态库的符号索引表 11.3 make静态库的注意事项 11.4 静态库的后缀规则 第十二章 : GNU make的特点 12.1 源自System v的特点 12.2 源自其他版本的特点 12.3 GNU make自身的特点 第十三章 和其它版本的兼容 第十四章 Makefile的约定 14.1 基本的约定 14.2 规则命令行的约定 14.3 代表命令变量 14.4 安装目录变量 14.5 Makefile的标准目标名 14.6 安装命令分类 第十五章 make的常见错误信息   附录:关键字索引 1. GNU make可识别的指示 符 2. GNU make函数 3. GNU make的自动化变量 4. GNU make环境变量 后序