当前位置: 首页 > news >正文

Makefile 阅读笔记


author: hjjdebug
date: 2025年 02月 18日 星期二 18:00:52 CST
description: Makefile 阅读笔记


文章目录

    • 1. vpath 指令
    • 2. 变量替换
    • 3. 变量模式替换
    • 4. define 指令
      • 4.1 定义一个多行字符串. resume
      • 4.2 定义一个函数 greet
      • 4.3:实战
    • 5. 介绍几个内置函数.
      • 1. wildcard
      • 2. foreach
      • 3. eval
      • 4. call

看makefile 倍难阅读, 写几个难点帮助理解.

1. vpath 指令

指定某一类文件的搜索路径.
格式: vpath PATTERN DIRECTORY
例:
vpath %.c $(SRC_PATH)
vpath %.cpp $(SRC_PATH)
vpath %.h $(SRC_PATH)
vpath %.inc $(SRC_PATH)
vpath %.S $(SRC_PATH)
vpath %.asm $(SRC_PATH)


2. 变量替换


$(CHECKASMOBJS:.o=.d)

CHECKASMOBJS:是一个Makefile变量,它包含了一系列的文件名或者路径。
.o 是后缀为.o的文件
‘=’ 赋值操作符,用于将匹配到的字符串按照右边的后缀进行替换。
.d 后缀为.d的文件
它会将变量CHECKASMOBJS中的每个.o文件扩展名替换为.d。
举例,如果CHECKASMOBJS的值为
foo.o bar.o
那么$(CHECKASMOBJS:.o=.d)的结果将是
foo.d bar.d

.d文件通常是依赖文件,包含了编译过程中生成的对象文件(.o文件)所依赖的头文件信息。
Makefile通过包含这些.d文件,可以自动获取到编译依赖关系,
从而在编译时能够正确地处理头文件的变更,避免重复编译不必要的源文件。


3. 变量模式替换


$(CHECKASMOBJS:%=tests/checkasm/%)

这是一种使用Make的模式替换功能(Pattern Substitution)的表达式
CHECKASMOBJS:这是一个Make变量,它包含了一系列的文件名或者路径。
%=tests/checkasm/%:这是一个模式替换规则。
‘%’ 是模式,它代表匹配任意字符串的通配符。
‘=’ 赋值操作符,用于将匹配到的字符串按照右边的模式进行替换。
tests/checkasm/%:这是替换后的模式,其中%会被CHECKASMOBJS中每个元素匹配到的字符串所替换。

举例: 如果CHECKASMOBJS的值为
foo.o bar.o
那么$(CHECKASMOBJS:%=tests/checkasm/%)的结果将会是
tests/checkasm/foo.o tests/checkasm/bar.o

这种模式替换功能在Makefile中非常有用,特别是当你需要对一系列文件名或路径进行批量修改时。
它可以让你以非常简洁的方式实现复杂的字符串替换操作。

练习:
TESTTOOLS = audiogen videogen base64 audiomatch
HOSTPROGS := $(TESTTOOLS:%=tests/%)
答案,就是把文件都添加了一个路径


4. define 指令


define 指令用来定义多行变量或函数

4.1 定义一个多行字符串. resume

但你只能在一行中写,换行用\n隔开
因为后续的行,首个token都会认为是命令

define resume
"my name is hjj.\nI like computer.\nI graduated in xxxx."
endef
all:
	@echo $(resume)

执行
$ make
my name is hjj.
I like computer.
I graduated in xxxx.

4.2 定义一个函数 greet

define 被展开每行按命令执行,后续是命令参数

define greet
hello $1!
@echo hello define
@echo hello function
endef
all:
	$(call greet, hjj)

注意call 调用,函数名与参数,参数与参数用,分割而不是空格分割,向c靠拢而不向bash靠拢

4.3:实战

define RESET
$(1) :=
$(1)-yes :=
endef

RESET 函数是把传来的参数复位的意思

define DOSUBDIR
$(foreach V,$(SUBDIR_VARS),$(eval $(call RESET,$(V))))
include $(SRC_PATH)/$(1)/Makefile
endef

其中SUBDIR_VARS如下, 还可以定义更多变量

SUBDIR_VARS=CLEANFILES TOOLS MMX-OBJS X86ASM-OBJS

DOSUBDIR 函数是对定义的变量进行枚举,对定义的变量进行复位,初始化为空
然后包含上第一参数作为目录下的Makefile, 还可以继续追加其它动作

FFLIBS=avformat avcodec avutil
$(foreach D,$(FFLIBS),$(eval $(call DOSUBDIR,lib$(D))))

该调用会对指定目录进行DOSUBDIR操作,其返回字符串继续用作命令执行


5. 介绍几个内置函数.


1. wildcard

格式:

‘$(wildcard PATTERN)’

功能: 输出匹配 PATTERN 的文件名
举例:$(wildcard *.c)
输出目录向所有.c 文件, 类似ls *.c输出

2. foreach

函数调用格式:

$(foreach VAR,LIST,TEXT)

功能: 跟据列表LIST, 用枚举变量VAR, 来执行TEXT动作
举例:
展开指定目录下的所有文件
find_files = $(wildcard $(dir)/*) # 扩展为该目录下所有文件
dirs := a b c d
files := ( f o r e a c h d i r , (foreach dir, (foreachdir,(dirs),$(find_files)) # 指定目录下的所有文件

替换文件扩展名
FILES := file1.c file2.c file3.c
OBJS := $(foreach file, $(FILES), $(file:.c=.o))

复制库文件
LIBS := lib1 lib2 lib3
install: $(foreach lib, $(LIBS), cp ( l i b ) . s o / u s r / l o c a l / l i b / (lib).so /usr/local/lib/ (lib).so/usr/local/lib/(lib).so)

3. eval

eval指令可以将参数中的字符串作为Makefile的一部分进行解析和执行
$(eval )
把string 当命令来执行, 可以实现动态为变量赋值,为函数赋值,执行命令等

4. call

$(call VARIABLE,PARAM,PARAM,…)

 调用用户定义的函数VARIABLE并传递参数

相关文章:

  • 淘宝拍立淘按图搜索商品API接口概述及JSON数据示例返回
  • Flutter
  • 大语言模型内容安全的方式有哪些
  • Springboot使用Redis发布订阅自动更新缓存数据源
  • hive(hdfs)补数脚本
  • k8s环境中的rook-ceph的osd报Permission denied无法正常运行问题的处理方式
  • 【全栈】SprintBoot+vue3迷你商城-细节解析(2):分页
  • Unity中NavMesh的使用 及其 导出给java服务端进行寻路
  • 基于Spring Security 6的OAuth2 系列之十九 - 高级特性--OIDC1.0协议之二
  • 视点开场动画实现(九)
  • KubeSphere 产品生命周期管理政策公告正式发布!
  • ALV某个字段没有显示
  • kubeadm拉起的k8s集群证书过期的做法集群已奔溃也可以解决
  • 【核心算法篇七】《DeepSeek异常检测:孤立森林与AutoEncoder对比》
  • 用Chrome Recorder轻松完成自动化测试脚本录制
  • 计算机网络原理试题六
  • Flink SQL与Doris实时数仓Join实战教程(理论+实例保姆级教程)
  • wangEditor 编辑器 Vue 2.0 + Nodejs 配置
  • 性能测试(三)之环境搭建
  • RocketMQ - 常见问题
  • 4月金融数据前瞻:受去年低基数因素影响,社融增量有望同比大幅多增
  • 习近平出席俄罗斯纪念苏联伟大卫国战争胜利80周年庆典
  • 上海:企业招用高校毕业生可享受1500元/人一次性扩岗补助
  • 海南省三亚市委原常委、秘书长黄兴武被“双开”
  • 绿城房地产集团:近半年累计花费20.6亿元购买旗下债券
  • 印对巴军事打击后,巴外交部召见印度驻巴临时代办