多个目录编译的makefile的编写

时间:2021-12-09 12:21:14
all :  
    cd dir1;make all; 
    cd dir3;make all; 
    cd dir2;make all; 
clean :  
    cd dir1;make clean; 
    cd dir3;make clean; 

    cd dir2;make clean;



当然,我们也可以用makefile自身的特性,即 make all/clean -C dir1来进行编译,但是实际上两种写法都避免不了3个问题: 
1.当新加入一个模块的时候,要写入两句代码,一句是all,一句是clean,很容易漏掉。 
2.没有办法进行并行编译。因为很可能这些模块之间是不互相依赖的,而并行编译可以极大的提高速度(如果你受得了make那蜗牛般的速度的话,可以无视掉这一条) 
3.依赖关系不明显(可以看出是dir2依赖与dir3,但是没有明确的指出)

那么解决方法是怎样呢?有这样一个makefile



dirs = dir1 \ 
       dir2 \ 
       dir3 
.PHONY: all clean $(dirs) 
all: $(dirs) 
clean: $(dirs) 
$(dirs): 
    $(MAKE) -j2 -C $@ $(MAKECMDGOALS) 
dir2:dir3



在这个makefile的同级目录有3个目录,分别为dir1,dir2,dir3,其中每个目录的makefile就不说了,大家看图应该能明白,执行make后,结果如下:

多个目录编译的makefile的编写