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

前端之家收集整理的这篇文章主要介绍了自动生成依赖关系的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) $<

猜你在找的设计模式相关文章