#define a multiline variable
#在此makefile文件的同级目录下有a.c b.c文件
#以及sub文件夹,文件夹下面有sa.c sb.c文件
define target
@echo $@ $(1) $(0) $(2)
endef
src = $(wildcard *.c ./sub/*.c)
dir = $(notdir $(src) )
obj = $(patsubst ./%,%, $(src) )
all:
@echo $(src)
@echo $(dir)
@echo $(obj)
@echo "end"
$(call target, all123)
输出结果如下:
a.c b.c ./sub/sa.c ./sub/sb.c
src
a.c b.c sa.c sb.c
dir 去除目录
a.c b.c sub/sa.c sub/sb.c
obj
./%,%, $(src)
字符串替换, ./% 替换成%,也就是去掉前面的"./"符号
end
all all123 target
调用函数的输出
all $@ $(1) $(0) $(2)
all123 $(1)函数调用的第1个参数
target $(0)函数调用的第0个参数,即函数名
$(2) 没有这么多参数