首页 > 其他分享 >【make】makefile 函数全解

【make】makefile 函数全解

时间:2025-01-19 16:29:40浏览次数:3  
标签:函数 show res make makefile echo 单词 字符串 全解

目录

在这里插入图片描述

makefile简介

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

函数全解介绍

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

相关链接

makefile变量全解

字符串处理函数

subst 函数—字符串替换

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

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

patsubst 函数 — 模式字符串替换

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

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

strip 函数 — 去空格

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

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

findstring 函数 — 查找字符串

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

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

#输出
foo

filter 函数 — 过滤器

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

#$(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>的单词。可以有多个模式。

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

sort 函数 — 排序

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

#$(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>个单词。(从一开始)

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

wordlist函数 — 取一串字符串

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

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

words 函数 — 计算单词数

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

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

firstword 函数 — 返回第一个单词

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

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

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

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

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

文件名操作函数

dir 函数 — 取文件夹部分

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

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

notdir 函数 — 取非文件夹部分

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

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

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

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

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

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

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

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

addsuffix 函数 — 添加后缀

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

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

addprefix 函数 — 添加前缀

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

#$(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>中。

#$(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>的变量将不在作用。

#$(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

#$(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 函数的返回值。

#$(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>是一个命令运行中的自动化变量

#$(origin <variable>)

shell 函数 — 执行shell命令

用于执行shell 命令

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

日志输出函数

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

$(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
在这里插入图片描述

标签:函数,show,res,make,makefile,echo,单词,字符串,全解
From: https://blog.csdn.net/qq_44653106/article/details/145136932

相关文章

  • Windows环境下xmake安装配置,创建编译运行项目
     Windows环境下xmake安装配置,创建编译运行项目视频地址:https://www.bilibili.com/video/BV1NHwqe3Ewn/?spm_id_from=333.1387.homepage.video_card.click&vd_source=7c7ae5cc1dbb2453e1eb43950a4264a31、访问xmake网站,根据安装环境选择对应安装方法(1)访问网站:https://xmake.i......
  • Makefile快速入门教程
    Makefile快速入门教程本教程旨在帮助读者全面深入地掌握Makefile的编写与使用。Makefile是一种用于自动化编译和构建程序的文件,通过定义一系列规则和命令,能够高效地管理项目的编译过程,尤其在大型项目中,其优势尤为明显。本教程从基础概念入手,逐步深入到高级特性,涵盖了M......
  • 完全解读布隆过滤器
    布隆过滤器(BloomFilter)是1970年由布隆提出的,是一种非常节省空间的概率数据结构,运行速度快,占用内存小。它实际上是一个很长的二进制向量和一系列随机映射函数。布隆过滤器可以用于检索一个元素是否在一个集合中。主要用于判断一个元素是否在一个集合中。主要是解决大规模......
  • 【3DGS (1) 】3D Gaussian Splatting全解 (原理+代码+公式) - 笔记
    文章目录1-什么是splatting?2-Splatting的流程3-为什么3dgaussian:是椭球?4-各向异性和各向同性是什么意思?5-`协方差矩阵`怎么就能控制椭球形状呢?6-协方差矩阵怎么就能用旋转和缩放矩阵表达?7-仿射变换本文为B站3DGS讲解视频-【1】捏雪球的文字笔记,以及个......
  • 创建一个CMake项目
    本文将演示如何使用CMake管理一个中等复杂度的项目,从创建项目到编译和运行的整个过程,涵盖了从基本配置到高级特性的实际应用。实战内容如下:创建CMakeLists.txt文件:定义项目、库、可执行文件和测试。编写源代码和测试:编写代码和测试文件。创建构建目录:保持源代码目录整......
  • 【日志分析】从手动解析到智能检测:日志异常模式挖掘全解
    网罗开发(小红书、快手、视频号同名)  大家好,我是展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、HarmonyOS、Java、Python等方向。在移动端开发、鸿蒙开发、物联网、嵌入式、云原生、开源......
  • linux m、mm、mmm函数和make的区别
    在Linux内核开发和Android开发中,构建系统通常使用 make 命令来编译和构建项目。而在Android开发环境中,还有 m、mm 和 mmm 等命令,这些命令是Android构建系统的一部分,提供了更高效和便捷的构建方式。以下将详细介绍这些命令的功能、使用场景和区别。一、make 命令......
  • Linux驱动开发:一文掌握 块设备VS字符设备开发流程全解!
    Linux驱动开发是嵌入式系统开发中的一个重要组成部分,它直接关系到硬件设备的功能实现和性能优化。在Linux系统中,驱动开发主要分为字符设备驱动、块设备驱动和网络设备驱动三大类。本文将重点介绍字符设备和块设备的基础知识,以及它们在驱动开发中的差异和开发流程。一、字符设......
  • 消息队列实战指南:三大MQ 与 Kafka 适用场景全解析
    前言:在当今数字化时代,分布式系统和大数据处理变得愈发普遍,消息队列作为其中的关键组件,承担着系统解耦、异步通信、流量削峰等重要职责。ActiveMQ、RabbitMQ、RocketMQ和Kafka作为市场上极具代表性的消息队列产品,各自拥有独特的功能特性与适用场景。本博客旨在深入剖析这四种消......
  • 矩阵碰一碰发视频源码技术开发全解析,支持OEM
    在当今数字化内容传播迅速发展的时代,矩阵碰一碰发视频功能以其便捷、高效的特点,为用户分享视频提供了全新的体验。本文将深入探讨矩阵碰一碰发视频源码的技术开发过程,从原理到实现,为开发者提供全面的技术指引。一、技术原理矩阵碰一碰发视频功能主要基于近场通信技术,如NFC(N......