Makefile中的字符串替换

2023-10-13 10:28:19 浏览数 (2)

Makefile中的字符串替换,做下验证和总结。

案例:Makefile Tutotial中一段代码

Makefile Tutotial最后给出了一段makefile,里面OBJS有字符串通配、替换的过程:

Makefile

代码语言:javascript复制
SRC_DIRS := ./src
BUILD_DIR := ./build

SRCS := $(shell find $(SRC_DIRS) -name '*.cpp' -or -name '*.c' -or -name '*.s')
OBJS := $(SRCS:%=$(BUILD_DIR)/%.o)

TAR:
    @echo SRCS : $(SRCS)
    @echo OBJS : $(OBJS)

执行

代码语言:javascript复制
touch aa123zz.c
touch aa332dzz.cpp
touch aa44325drzz.cpp
make

输出

代码语言:javascript复制
SRCS : ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS : ./build/./aa123zz.c.o ./build/./aa44325drzz.cpp.o ./build/./aa332dzz.cpp.o

(SRCS:%=(BUILD_DIR)/%.o)如何匹配的还是比较困惑,下面做一些实验和总结。

Makefile字符串替换规则

场景一:整体匹配替换

Makefile

代码语言:javascript复制
SRCS := ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS := $(SRCS:.cpp=.cxx)

TAR:
    @echo SRCS : $(SRCS)
    @echo OBJS : $(OBJS)

输出

代码语言:javascript复制
make
SRCS : ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS : ./aa123zz.c ./aa44325drzz.cxx ./aa332dzz.cxx

规则:注意字符串中的空格起到分隔作用,分隔的每一个字符串都会应用下面规则

代码语言:javascript复制
$(变量名:旧值=新值)

场景二:通配符替换

Makefile

代码语言:javascript复制
SRCS := ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS := $(SRCS:./aa%zz.cpp=./AA%%ZZ.cxx)

TAR:
	@echo SRCS : $(SRCS)
	@echo OBJS : $(OBJS)

输出

代码语言:javascript复制
make
SRCS : ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS : ./aa123zz.c ./AA44325dr%ZZ.cxx ./AA332d%ZZ.cxx

规则:注意带通配符的话,旧值必须整体匹配,匹配一部分不行。

代码语言:javascript复制
$(变量名:旧值带通配符)=新值带不带通配符都行通配符代表旧值中匹配的字符)

0 人点赞