makefile 中的patsubst

1. wildcard:扩展通配符

2. notdir:去除路径

3. patsubst:替换通配符

若有一个makefile如下:

src=$(wildcard *.c ./sub/*.c)

dir=$(notdir $(src))

obj=$(patsubst %.c, %.o, $(dir)) 将$(dir)中的所有以.c结尾的替换成以.o结尾,或者使用obj=$(dir:%.c=%.o)

标准格式为:

$(var:a=b)或${var:a=b}  将变量中的每一个值结尾用b替换掉a

all:

  @echo $(src)

  @echo $(dir)

  @echo $(obj)

输出为:

a.c b.c ./sub/sa.c ./sub/sb.c

a.c b.c sa.c sb.c

a.o b.o sa.o sb.o

原文地址:https://www.cnblogs.com/sssblog/p/10938137.html