把object放到同一个目录的Makefile写法,目标文件同一目录

时间:2022-07-02 12:48:05

相信很多同学都在思考这个问题:

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呢?请各位思考下 :-)