makefile 函数调用理解与自定义函数



#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) 没有这么多参数



你可能感兴趣的:(makefile 函数调用理解与自定义函数)