1、Makefile中调用shell脚本
- Makefile中可以通过使用$(shell 指令)的方式调用shell脚本
- a指令:输出当前文件夹下的所有文件
- b指令:输出当前路径
- c指令:如果当前目录下不存在abc文件那么创建一个abc的文件
a=$(shell ls ./)
b=$(shell pwd)
filename=abc# 如果不存在abc文件则创建一个abc文件
c:=$(shell if [ ! -f $(filename) ];then touch $(filename);fi;)show:@echo $(a)@echo $(b)@echo $(c)clean:${RM} abc# make show 输出
Makefile
/home/xxx/xxxx/05-shell
2、Makefile中嵌套调用的多项目同时编译
准备一个如下所示的文件夹:
- 文件夹1:4个.cpp文件,1个Makefile
- 文件夹2:3个.c文件,1个Makefile
- Makefile-head文件:1和2下的Makefile通过include 包含这个头文件(包含的本质是将代码拷贝过来),只不过Makefile-head是1和2都能用到的共同部分
- 主要目标是通过最外面的Makefile调用1和2下的Makefile
2.1 .1/Makefile、.2/Makefile、Makefile-head
- ./1/Makefile
tar=d
include ../Makefile-head
- ./2/Makefile
tar=z
include ../Makefile-head
- ./Makefile-head
src=$(wildcard ./*.cpp ./*.c)
obj =$(patsubst ./%.cpp,./%.o,$(src))
obj:=$(patsubst ./%.c,./%.o,$(obj))$(tar):$(obj)${CXX} $^ -o $@clean:${RM} $(tar) *.o.PHONY: clean $(tar)
2.2、./Makefile
- make和$(MAKE)是同一个东西,不过是一个使用的系统常量
- 每个目标下的两条指令是相同的含义,只不过执行的路径不一样
a:make -C ./1 -f Makefile$(MAKE) -C ./2clean:make -C ./1 -f Makefile clean$(MAKE) -C ./2 clean
2.3、改进
- 首先声明DIR指定需要执行的文件夹
- .PHONY是为了防止伪目标
- ALL: 表示需要生成的所有目标,依赖$(DIR)
- 然后$(DIR)需要通过嵌套调用的指令执行
- clean的过程是一个调用shell指令循环的过程
DIR=./1 ./2
.PHONY: 1 2
ALL: $(DIR)$(DIR):make -C $@ -f Makefileclean:@echo $(shell for dir in $(DIR); do make -C $$dir clean;done)