前言
Makefile自动生成头文件依赖是很常用的功能,本文的目的是想尽量详细说明其中的原理和过程。
Makefile模板
首先给出一个本人在小项目中常用的Makefile模板,支持自动生成头文件依赖。
CC = gcc
CFLAGS = -Wall -O
INCLUDEFLAGS =
LDFLAGS =
OBJS = seq.o
TARGETS = test_seq
.PHONY:all
all : $(TARGETS)
test_seq:test_seq.o $(OBJS)
$(CC) -o $@ $^ $(LDFLAGS)
%.o:%.c
$(CC) -o $@ -c $< $(CFLAGS) $(INCLUDEFLAGS)
%.d:%.c
@set -e; rm -f $@; $(CC) -MM $< $(INCLUDEFLAGS) > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
-include $(OBJS:.o=.d)
.PHONY:clean
clean:
rm -f $(TARGETS) *.o *.d *.d.*
基础知识
在进行下一步之前,首先需要了解make的执行步骤:
- 读入Makefile
- 读入被include的其它Makefile
- 初始化Makefile中的变量
- 推导隐晦规则,并分析所有规则
- 为所有目标创建依赖关系链
- 根据依赖关系,决定哪些目标需要重新生成
- 执行生成命令