自动生成依赖关系的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, $(OBJDIR), $(OBJS)) $(DEPENDDIR)/*.d
include $(subst .o,.d, $(subst dir, $(DEPENDDIR), $(OBJS)))
$(DEPENDDIR)/%.d: %.c
      @set -e; rm -f $@; \
      $(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
      sed 's,\($*\)\.o[ :]*,$(OBJDIR)/\1.o $@ : ,g' < $@.$$$$ > $@; \
      rm -f $@.$$$$
$(OBJDIR)/%.o:%.c
      $(COMPILE.c) $(OUTPUT_OPTION) $<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值