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复制$(变量名:旧值带通配符)=新值带不带通配符都行通配符代表旧值中匹配的字符)