最近系统学习了下Makefile,自己实现了一个包含文件搜索,并将生成的.o文件单独生成到固定目录下面的例子。
文件结构:
makefile
testmain.c
pub
basehead.h
print.c
print.h
command
command.c
command.h
makefile文件内容:
#变量的定义,用来将不同用途的文件归类
tmpfile = tmp dep obj
objfile = obj
MoudleH = print command pub
Moudle = print command .
#用来遍历产生.c和.h文件
srcfile = $(foreach moudle,$(Moudle),$(wildward $(moudel)/*.c))
Headfile = $(foreach moudle,$(MoudleH),$(wildward $(moudel)/*.h))
#用来生成目标的.o文件
objs = $(addprefix $(objfile)/,$(subst .c,.o,$(notdir $(srcfile))))
#设置文件搜索的相关路径
pathfile = -Icommand -Ipub -Iprint
vpath %.c print command
vpath %.h print command pub
#makefile的第一个目标作为入口开始
default: printmain TestMakeFile
#用来打印遍历产生的文件,以方便查看结果是否正确
printmain:
@echo $(Headfile)
@echo $(srcfile)
@echo $(objs)
#链接产生相应的执行文件
TestMakeFile:$(objs)
gcc $+ $(pathobj) -o TestMakeFile
#编译产生.o文件,并放到指定的obj目录中
$(objfile)/%.o: %.c
@echo ----begin---
gcc $(pathfile) -c $< -o $@
@echo ----end----
#用来创建临时文件
mkdirMain:
mkdir $(tmpfile)
#用来删除生成的文件
clean:
rm -rf TestMakeFile $(tmpfile)
运行结果:
能够通过目录搜索获取相应的.c和.h文件,并能将.o文件放到指定的obj文件中