Makefile函数大全:文本处理、文件名处理、控制函数等

需积分: 10 6 下载量 192 浏览量 更新于2024-07-16 收藏 804KB PDF 举报
Makefile 函数整理 Makefile 函数是编写 Makefile 的基础,掌握这些函数可以帮助开发者更好地编写 Makefile,提高编译效率和代码质量。本文将对 Makefile 函数进行归纳整理,包括文本处理函数、文件名处理函数、foreach 函数、if 函数、call 函数、value 函数、eval 函数、origin 函数、shell 函数、make 的控制函数等。 **文本处理函数** 文本处理函数是 Makefile 中最基本的函数,用于处理文本字符串。常用的文本处理函数有: 1. substr 函数:字符串替换函数,用于将字符串中的一部分替换为另一个字符串。 格式:$(subst FROM, TO, TEXT) 功能:把字串“TEXT”中的“FROM”字符替换为“TO” 返回值:替换后的新字符串 示例:$(subst ee, EE, feetonthestreet) 将“feetonthestreet”中的“ee”替换为“EE”,结果得到字符串“fEEtonthestrEEt”。 2. patsubst 函数:模式替换函数,用于将字符串中符合模式的部分替换为另一个字符串。 格式:$(patsubst PATTERN, REPLACEMENT, TEXT) 功能:搜索“TEXT”中以空格分开的单词,将否符合模式“PATTERN”替换为“REPLACEMENT”。 示例:$(patsubst %.c, %.o, $(wildcard *.c)) 将所有以“.c”结尾的文件名替换为以“.o”结尾的文件名。 3. strip 函数:字符串去空格函数,用于将字符串中的空格去除。 格式:$(strip TEXT) 功能:将字符串“TEXT”中的空格去除 返回值:去除空格后的字符串 4. findstring 函数:字符串查找函数,用于查找字符串中是否包含某个子字符串。 格式:$(findstring FIND, TEXT) 功能:查找字符串“TEXT”中是否包含“FIND” 返回值:如果包含则返回“FIND”,否则返回空串 5. filter 函数:字符串过滤函数,用于过滤字符串中符合某个模式的部分。 格式:$(filter PATTERN, TEXT) 功能:过滤字符串“TEXT”中符合模式“PATTERN”的部分 返回值:符合模式的字符串 6. filter-out 函数:字符串排除函数,用于排除字符串中符合某个模式的部分。 格式:$(filter-out PATTERN, TEXT) 功能:排除字符串“TEXT”中符合模式“PATTERN”的部分 返回值:不符合模式的字符串 7. sort 函数:字符串排序函数,用于将字符串按字母顺序排序。 格式:$(sort TEXT) 功能:将字符串“TEXT”按字母顺序排序 返回值:排序后的字符串 8. word 函数:单词函数,用于将字符串分割为单词。 格式:$(word N, TEXT) 功能:将字符串“TEXT”分割为单词,取第 N 个单词 返回值:第 N 个单词 9. wordlist 函数:单词列表函数,用于将字符串分割为单词列表。 格式:$(wordlist N, TEXT) 功能:将字符串“TEXT”分割为单词列表,取第 N 个单词 返回值:第 N 个单词 10. words 函数:单词数量函数,用于统计字符串中的单词数量。 格式:$(words TEXT) 功能:统计字符串“TEXT”中的单词数量 返回值:单词数量 11. firstword 函数:第一个单词函数,用于取得字符串中的第一个单词。 格式:$(firstword TEXT) 功能:取得字符串“TEXT”中的第一个单词 返回值:第一个单词 **文件名处理函数** 文件名处理函数是 Makefile 中用于处理文件名的函数。常用的文件名处理函数有: 1. dir 函数:目录函数,用于取得文件的目录部分。 格式:$(dir FILENAME) 功能:取得文件“FILENAME”的目录部分 返回值:目录部分 2. notdir 函数:非目录函数,用于取得文件的非目录部分。 格式:$(notdir FILENAME) 功能:取得文件“FILENAME”的非目录部分 返回值:非目录部分 3. suffix 函数:文件后缀函数,用于取得文件的后缀。 格式:$(suffix FILENAME) 功能:取得文件“FILENAME”的后缀 返回值:后缀 4. basename 函数:文件名函数,用于取得文件的基本名称。 格式:$(basename FILENAME) 功能:取得文件“FILENAME”的基本名称 返回值:基本名称 5. addsuffix 函数:添加后缀函数,用于将后缀添加到文件名中。 格式:$(addsuffix SUFFIX, FILENAME) 功能:将后缀“SUFFIX”添加到文件“FILENAME”中 返回值:添加后缀后的文件名 6. addprefix 函数:添加前缀函数,用于将前缀添加到文件名中。 格式:$(addprefix PREFIX, FILENAME) 功能:将前缀“PREFIX”添加到文件“FILENAME”中 返回值:添加前缀后的文件名 7. join 函数:连接函数,用于连接多个文件名。 格式:$(join PREFIX, FILENAME) 功能:连接文件“FILENAME”和前缀“PREFIX” 返回值:连接后的文件名 8. wildcard 函数:通配符函数,用于查找符合某个模式的文件。 格式:$(wildcard PATTERN) 功能:查找符合模式“PATTERN”的文件 返回值:符合模式的文件列表 **foreach 函数** foreach 函数是 Makefile 中用于遍历列表的函数。格式:$(foreach VAR, LIST, BODY) 功能:遍历列表“LIST”,将每个元素赋值给变量“VAR”,执行 BODY 中的语句。 **if 函数** if 函数是 Makefile 中用于条件判断的函数。格式:$(if CONDITION, THEN, ELSE) 功能:如果条件“CONDITION”为真,则执行 THEN 中的语句,否则执行 ELSE 中的语句。 **call 函数** call 函数是 Makefile 中用于调用函数的函数。格式:$(call FUNC, ARGS) 功能:调用函数“FUNC”并传递参数“ARGS”。 **value 函数** value 函数是 Makefile 中用于取得变量的值的函数。格式:$(value VAR) 功能:取得变量“VAR”的值。 **eval 函数** eval 函数是 Makefile 中用于执行字符串的函数。格式:$(eval STRING) 功能:执行字符串“STRING”。 **origin 函数** origin 函数是 Makefile 中用于取得变量的来源的函数。格式:$(origin VAR) 功能:取得变量“VAR”的来源。 **shell 函数** shell 函数是 Makefile 中用于执行 shell 命令的函数。格式:$(shell COMMAND) 功能:执行 shell 命令“COMMAND”。 **make 的控制函数** make 的控制函数是 Makefile 中用于控制 make 过程的函数。常用的控制函数有: 1. error 函数:错误函数,用于抛出错误信息。 格式:$(error MESSAGE) 功能:抛出错误信息“MESSAGE”。 2. warning 函数:警告函数,用于抛出警告信息。 格式:$(warning MESSAGE) 功能:抛出警告信息“MESSAGE”。