【make】makefile 函数全解

embedded/2025/1/15 7:20:17/

目录

  • makefile简介
  • 函数全解介绍
  • 相关链接
  • 字符串处理函数
    • subst 函数—字符串替换
    • patsubst 函数 — 模式字符串替换
    • strip 函数 — 去空格
    • findstring 函数 — 查找字符串
    • filter 函数 — 过滤器
    • filter-out 函数 — 过滤器
    • sort 函数 — 排序
    • word 函数 — 取单词
    • wordlist函数 — 取一串字符串
    • words 函数 — 计算单词数
    • firstword 函数 — 返回第一个单词
    • lastword 函数 — 返回最后一个单词
  • 文件名操作函数
    • dir 函数 — 取文件夹部分
    • notdir 函数 — 取非文件夹部分
    • suffix 函数 — 取出各个文件名的后缀
    • basename 函数 — 取出各个文件名的前缀部
    • addsuffix 函数 — 添加后缀
    • addprefix 函数 — 添加前缀
    • join 函数 — 各个单词进行连接
  • foreach 函数 — 依次处理字符串
  • if 函数 — 分支判断
  • call 函数 — 调用其他变量
  • origin 函数 — 变量来源
  • shell 函数 — 执行shell命令
  • 日志输出函数
  • 总结
  • 参考链接

在这里插入图片描述

makefile_4">makefile简介

  makefile 是一种类似shell的脚本文件,需要make工具进行解释 makefile 内的语句,然后执行内部语句。Makefile的作用是去管理工程项目,比如一个项目有很多c文件,需要利用Makefile去统一进行编译或者其他操作。[1]

函数全解介绍

以下脚本内容可有效作用于 make版本: GNU Make 4.2.1

相关链接

makefile变量全解

字符串处理函数

subst 函数—字符串替换

把字符串<text>中所有的<from>字符串替换成<to>

makefile">#$(subst <from>,<to>,<text>)
res = $(subst oo,OO,good food)
show:@echo $(res)   
#输出
gOOd fOOd

patsubst 函数 — 模式字符串替换

查找<text>中的单词末尾是否符合模式<pattern>,如果匹配的话,则以<replacement>替换。

makefile">#$(patsubst <pattern>,<replacement>,<text>)
res = $(patsubst %ood,%OOd,good food)
show:@echo $(res)    
#输出
gOOd fOOd

strip 函数 — 去空格

去掉<string>字串中开头和结尾的空字符

makefile">#$(strip <string>)
res = $(strip good food  time    show  get set)
show:@echo $(res)
#输出
good food time show get set

findstring 函数 — 查找字符串

在字串<in>中查找<find>字串,如果找到就返回字符串,没找到就返回空

makefile">#$(findstring <find>,<in>)
res = $(findstring foo,good food)
show:@echo $(res)#输出
foo

filter 函数 — 过滤器

<pattern>模式过滤<text>字符串中的单词,保留符合模式<pattern>的单词。可以有多个模式,用空格分隔。

makefile">#$(filter <pattern...>,<text>) 
res = $(filter %d %c %ab,good food bab come luc)
show:@echo $(res)
#输出
good food bab luc

filter-out 函数 — 过滤器

功能和上面相反,去除符合匹配pattern的。以<pattern>模式过滤<text>字符串中的单词,去除符合模式<pattern>的单词。可以有多个模式。

makefile">#$(filter-out <pattern...>,<text>)
res = $(filter-out %d %c %ab,good food bab come luc)
show:@echo $(res)
#输出
come

sort 函数 — 排序

给字符串<list>中的单词排序(升序)。

makefile">#$(sort <list>)
res = $(sort a c z d w y b e)
show:@echo $(res)
#输出
a b c d e w y z

word 函数 — 取单词

取字符串<text>中第<n>个单词。(从一开始)

makefile">#$(word <n>,<text>)
res = $(word 2,good food time)
show:@echo $(res)
#输出
food

wordlist函数 — 取一串字符串

从字符串<text>中取从<s>开始到<e>的单词串。<s><e>是一个数字。

makefile">#$(wordlist <s>,<e>,<text>)
res = $(wordlist 2,3,good food time)
show:@echo $(res)   
#输出
food time

words 函数 — 计算单词数

统计<text>中字符串中的单词个数

makefile">#$(words <text>) 
res = $(words good food time)
show:@echo $(res)    
#输出
3

firstword 函数 — 返回第一个单词

取字符串<text>中的第一个单词。

makefile">#$(firstword <text>)
res = $(firstword good food time)
show:@echo $(res)   
#输出
good

lastword 函数 — 返回最后一个单词

返回字符串<text>的第一个单词

makefile">#$(lastword <text>)
res = $(lastword good food time)
show:@echo $(res)   
#输出
time

文件名操作函数

dir 函数 — 取文件夹部分

从文件名序列<names>中取出目录部分。目录部分是指最后一个反斜杠(“/”)之前的部分。如果没有反斜杠,那么返回“./”。

makefile">#$(dir <names...>)
res = $(dir main.c subdir/subfile.c)
show:@echo $(res)   
#输出
./ subdir/

notdir 函数 — 取非文件夹部分

从文件名序列<names>中取出非目录部分。非目录部分是指最后一个反斜杠(“ /”)之后的部分。

makefile">#$(notdir <names...>)
res = $(dir main.c subdir/subfile.c)
show:@echo $(res)   
#输出
main.c subfile.c

suffix 函数 — 取出各个文件名的后缀

从文件名序列<names>中取出各个文件名的后缀

makefile">#$(suffix <names...>) 
res = $(suffix main.c subdir/subfile.c)
show:@echo $(res)   
#输出
.c .c

basename 函数 — 取出各个文件名的前缀部

从文件名序列<names>中取出各个文件名的前缀部分。

makefile">#$(basename <names...>)
res = $(basename main.c subdir/subfile.c)
show:@echo $(res)   
#输出
main subdir/subfile

addsuffix 函数 — 添加后缀

把后缀<suffix>加到<names>中的每个单词后面

makefile">#$(addsuffix <suffix>,<names...>) 
res = $(addsuffix .c,main subdir/subfile)
show:@echo $(res)   
#输出
main.c subdir/subfile.c

addprefix 函数 — 添加前缀

把前缀<prefix>加到<names>中的每个单词前面。

makefile">#$(addprefix <prefix>,<names...>) 
res = $(addprefix  ./,main.c subdir/subfile.c)
show:@echo $(res)   
#输出
./main.c ./subdir/subfile.c

join 函数 — 各个单词进行连接

<list2> 中的单词对应地加到<list1>的单词后面。如果<list1>的单词个数要比的多,那么,中的多出来的单词将保持原样。如果<list2>的单词个数要比<list1>多,那么,<list2>多出来的单词将被复制到<list2>中。

makefile">#$(join <list1>,<list2>)
res = $(join good food time,show look find read get put)
show:@echo $(res)  
#输出
goodshow foodlook timefind read get put

foreach 函数 — 依次处理字符串

把参数<list>中的单词逐一取出放到参数<var>所指定的变量中,然后再执行<text>所包含的表达式。每一次<text>会返回一个字符串,循环过程中,<text>的所返回的每个字符串会以空格分隔,最后当整个循环结束时,<text>所返回的每个字符串所组成的整个字符串(以空格分隔)将会是 foreach 函数的返回值。

所以,<var>最好是一个变量名,<list>可以是一个表达式,而<text>中一般会使用<var>这个参数来依次枚举<list>中的单词。<var>参数是一个临时的局部变量,foreach 函数执行完后,参数<var>的变量将不在作用。

makefile">#$(foreach <var>,<list>,<text>)
names := a b c d  
files := $(foreach n,$(names),$(n).o) 
show:@echo $(files)   
#输出
a.o b.o c.o d.o

if 函数 — 分支判断

类似于关键字 ifeq

makefile">#$(if <condition>,<then-part>) 或则 $(if <condition>,<then-part>,<else-part>)
num=4
res := $(if num<5,smaller,bigger)
show:@echo $(res) #输出
smaller

call 函数 — 调用其他变量

<expression>参数中的变量,如$(1)$(2)$(3)等,会被参数<parm1><parm2><parm3>依次取代。而<expression>的返回值就是 call 函数的返回值。

makefile">#$(call <expression>,<parm1>,<parm2>,<parm3>...)
first = Donald
last = Trump
Donald_Trump = "I'M BACK!"
func = $(1)_$(2)
fullname = $(call func,$(first),$(last))
res := $($(call func,$(first),$(last)))
show:@echo $(fullname)@echo $(res)      
#输出
Donald_Trump
I'M BACK!

origin 函数 — 变量来源

获取变量来源,<variable> 是变量名,不需要加 $

  • undefined :如果<variable>从来没有定义过,origin 函数返回这个值“undefined”

  • default : 如果<variable>是一个默认的定义,比如“CC”这个变量

  • file : 如果<variable>这个变量被定义在 Makefile 中

  • command line : 如果<variable>这个变量是被命令行定义的

  • override : 如果<variable>是被 override 指示符重新定义的

  • automatic : 如果<variable>是一个命令运行中的自动化变量

makefile">#$(origin <variable>)

shell 函数 — 执行shell命令

用于执行shell 命令

makefile">#$(shell <shell command>)
num = 10
res = $(shell echo $(num))
show:@echo $(res)   
# 输出
10

日志输出函数

用于控制日志输出,以及make执行

makefile">$(info 'here is info.')
$(warning 'here is warning.')
$(error 'here is error.')
#输出
'here is info.'
Makefile:3: 'here is warning.'
Makefile:4: *** 'here is error.'.  Stop.

总结

其他函数可参考帮助文档。

参考链接

makefile变量全解
gnu make 帮助手册
百度百科— make
在这里插入图片描述


http://www.ppmy.cn/embedded/154054.html

相关文章

《解锁鸿蒙Next系统人工智能语音助手开发的关键步骤》

在当今数字化时代&#xff0c;鸿蒙Next系统与人工智能的融合为开发者带来了前所未有的机遇&#xff0c;开发一款人工智能语音助手应用更是备受关注。以下是在鸿蒙Next系统上开发人工智能语音助手应用的关键步骤&#xff1a; 环境搭建与权限申请 安装开发工具&#xff1a;首先需…

Java线程详解

一、线程的基本概念 1. 什么是线程&#xff1f; 线程是程序执行的一个单元&#xff0c;它是进程中的一个实体&#xff0c;是被系统独立调度和分派的基本单位。一个进程可以包含多个线程&#xff0c;这些线程共享进程的资源&#xff0c;如内存空间和文件句柄&#xff0c;但每个…

【2025最新】机器学习类计算机毕设选题80套,适合大数据,人工智能

【2025最新】机器学习类型计算机毕设选题 1-10套 基于Spring Boot的物流管理系统的设计与实现 基于机器学习的虚假招聘信息的分析与预测 基于机器学习的影响数据科学家职业变动因素的分析与预测 基于Spring Boot的历史文物交流平台的设计与实现 基于机器学习的肥胖影响因素的分…

c++ 中的容器 vector、deque 和 list 的区别

表格汇总&#xff1a; 容器存储结构随机访问性能中间插入/删除性能两端插入/删除性能内存管理特点迭代器类型适用场景vector连续存储的动态数组 O ( 1 ) O(1) O(1) O ( n ) O(n) O(n)&#xff08;需要移动元素&#xff09;末尾&#xff1a; O ( 1 ) O(1) O(1)&#xff0c;头部…

如何在C#中使用COM接口

在C中&#xff0c;可以使用CoCreateInstance函数来创建COM接口的实例。 以下教程可以帮助你方便的在C#中实现同样的功能。 方法一、手动生成&#xff08;适用于所有.NET版本&#xff09; 1、确定要使用的COM接口 Windows中很多功能都是通过COM实现的&#xff0c;有时候我们想…

LabVIEW光流跟踪算法

1. 光流跟踪算法的概述 光流&#xff08;Optical Flow&#xff09;是一种图像处理技术&#xff0c;用于估算图像中像素点的运动。通过比较连续帧图像&#xff0c;光流算法可以分析图像中的运动信息&#xff0c;广泛用于目标跟踪、运动检测和视频处理等场景。该示例使用了NI Vi…

Kafka消费者如何优雅下线

一、背景 我们在Kafka消费程序中&#xff0c;可能会调用dubbo接口&#xff0c;也可能会使用线程池&#xff0c;连接池等&#xff0c;但是在服务下线的时候&#xff0c;kafka的消费总是会报错。比如dubbo接口就会抛出异常RpcException: The channel is closed. 这说明kafka还在…

django基于Python的校园个人闲置物品换购平台

Django 基于 Python 的校园个人闲置物品换购平台 一、平台概述 Django 基于 Python 的校园个人闲置物品换购平台是专为校园师生打造的一个便捷、环保且充满活力的线上交易场所。它借助 Django 这一强大的 Python Web 开发框架&#xff0c;整合了校园内丰富的闲置物品资源&…