Makefile中的字符串替换,做下验证和总结。
案例:Makefile Tutotial中一段代码
Makefile Tutotial最后给出了一段makefile,里面OBJS有字符串通配、替换的过程:
Makefile
SRC_DIRS := ./src
BUILD_DIR := ./build
SRCS := $(shell find $(SRC_DIRS) -name '*.cpp' -or -name '*.c' -or -name '*.s')
OBJS := $(SRCS:%=$(BUILD_DIR)/%.o)
@echo SRCS : $(SRCS)
@echo OBJS : $(OBJS)
执行
touch aa123zz.c
touch aa332dzz.cpp
touch aa44325drzz.cpp
make
输出
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
SRCS := ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS := $(SRCS:.cpp=.cxx)
@echo SRCS : $(SRCS)
@echo OBJS : $(OBJS)
输出
make
SRCS : ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS : ./aa123zz.c ./aa44325drzz.cxx ./aa332dzz.cxx
规则:注意字符串中的空格起到分隔作用,分隔的每一个字符串都会应用下面规则
$(变量名:旧值=新值)
场景二:通配符替换
Makefile
SRCS := ./aa123zz.c ./aa44325drzz.cpp ./aa332dzz.cpp
OBJS := $(SRCS:./aa%zz.cpp=./AA%%ZZ.cxx)