自动生成依赖关系的Makefile实例

最近研究Makefile,以下列出两个利用编译器自动生成文件依赖关系的Makefile例子:

一个例子

#最终要生成的可执行文件名称
TARGET = test
#目标文件的集合及存储的位置
OBJNAME = main.o dlist.o
OBjdiR = ./obj
DEPENDDIR = ./depend
#C编译器及编译参数
CC = gcc
CFLAGS = -Wall -g
#C连接器及连接参数
LD = gcc
LDFLAGS =

.PHONY:all clean
all: $(TARGET)

#认启动调试模式
$(TARGET):$(OBJNAME)
$(LD) $(LDFLAGS) -o $@ $^
clean:
rm -f $(TARGET) $(OBJNAME) ./*.d
include $(OBJNAME:.o=.d)
%.d: %.c
set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ :,g' < $@.$$$$ > $@; \
rm -f $@.$$$$


第二个例子

#最终要生成的可执行文件名称
TARGET = test
#目标文件的集合及存储的位置
OBJS = dir/main.o dir/dlist.o
OBjdiR = obj
DEPENDDIR = depend
#C编译器及编译参数
CC = gcc
CFLAGS = -Wall -g
#C连接器及连接参数
LD = gcc
LDFLAGS =

.PHONY:all clean
all: $(TARGET)

#认启动调试模式
$(TARGET):$(subst dir,$(OBjdiR),$(OBJS))
$(LD) $(LDFLAGS) -o $@ $^
clean:
rm -f $(TARGET) $(subst dir,$(OBJS)) $(DEPENDDIR)/*.d
include $(subst .o,.d,$(subst dir,$(DEPENDDIR),$(OBJS)))
$(DEPENDDIR)/%.d: %.c
@set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,$(OBjdiR)/\1.o $@ :,g' < $@.$$$$ > $@; \
rm -f $@.$$$$ $(OBjdiR)/%.o:%.c $(COMPILE.c) $(OUTPUT_OPTION) $<

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...