相信很多同学都在思考这个问题:
Makefile里面怎么把object文件放到一个指定目录,而不是跟c文件在一起?
今天来分享下这个makefile的写法:
情形1:Makefile与源码在同一个目录或者位于父目录下,我们要把中间文件放到obj目录,例如:
src
--src2
inc
obj
Makefile
则makefile内容可以为:
source = $(wildcard *.c) $(wildcard src2/*.c)
objs = $(source:%.c=%.o)
all: $(objs)
gcc -o $@ $^
@echo done
$(objs): %.o : %.c
gcc -c $< -o $@
这是个通用的makefile,object文件仍然与C文件放在一起,我们改一下:
OBJDIR = obj
vpath %.c src2
source = $(wildcard *.c) $(notdir $(wildcard src2/*.c))
objs = $(source:%.c=$(OBJDIR)/%.o)
all: $(objs)
gcc -o $@ $^
@echo done
$(objs): $(OBJDIR)/%.o : %.c
@mkdir -p $(OBJDIR)
gcc -c $< -o $@
不同的是,加了一个vpath,意思是告诉makefile去src2再找c文件。
这种情况下还好,因为如果要在obj建立跟之前c文件对应目录的话,很好建,例如obj/src2/xxx.o,还有种情况可能就不行了:
情形2:Makefile与源码在同一个目录,但要调用同目录的C文件,例如:
common
project
-src
--src2
-inc
-obj
-Makefile
则makefile内容可以为:
OBJDIR = obj
vpath %.c src2
source = $(wildcard *.c) $(notdir $(wildcard src2/*.c)) $(notdir $(wildcard ../common/*.c))
objs = $(source:%.c=$(OBJDIR)/%.o)
all: $(objs)
gcc -o $@ $^
@echo done
$(objs): $(OBJDIR)/%.o : %.c
@mkdir -p $(OBJDIR)
gcc -c $< -o $@
这种情况下object仍然是放到同一个目录的,但如果要在obj目录建立相应的文件夹就不行了,例如:obj/../common/xxx.o,文件系统报错,因为../不是一个有效的目录名称。
如何在obj目录建立obj/common/xxx.o呢?请各位思考下 :-)