makefile自动src文件检测和依赖关系生成

时间:2012-05-04 16:16:20

标签: c++ makefile

我的c ++项目有以下设置:

在src文件夹中,有* .cpp和相应的* .h文件和 在obj文件夹中我想要我的.o文件。

到目前为止,编译和链接不是问题。但是现在我有太多.cpp和.h文件手动将它们放入Makefile中。所以我决定在makefile中写这个小指令:

collect_sources:
@echo "collecting source files";
@echo "SRCS = \\" > sources;
@for file in ./src/*.cpp; \
do \
    echo "$$file \\" >> sources; \
done

我也做

-include sources

在makefile的开头

生成的文件sources看起来很好,尽管在最后一行中有一个我不喜欢的反斜杠。但是afaik也应该是有害的。

我现在还需要自动构建依赖项。在我上一个版本中,我直接在Makefile中将* .cpp文件定义为SRCS,以下代码很好:

$(SRCDIR)/%.cpp:
  @$(CXX) $(DEPFLAGS) -MT \
  "$(subst $(SRCDIR),$(OBJDIR),$(subst $(EXT_SRC),$(EXT_OBJ),$$file))" \
  $(addprefix ,$$file) >> $(DEP);
clear_dependencies:
    echo "" > $(DEP);

depend: clear_dependencies $(SRCS)

但是包含sources - 文件后,它永远不会到达上面的代码块。

以下是Makefile顶部定义的常量:

CXX = g++
CXXFLAGS = -Wall \
       -Wextra \
       -Wuninitialized \
       -Wmissing-declarations \
       -pedantic \
       -O3 \
       -p -g -pg
LDFLAGS =  -p -g -pg
DEPFLAGS = -MM

SRCDIR  = ./src
OBJDIR  = ./obj

TARGET = ./bin/my_funky_function_which_is_not_the_real_name

-include sources

OBJSTMP =   $(SRCS:.cpp=.o)
OBJS        =   $(OBJSTMP:$(SRCDIR)=$(OBJDIR))
DEP = depend.main
EXT_SRC =   .cpp
EXT_OBJ =   .o

我错过了什么?我的方法是否有效/可行?

1 个答案:

答案 0 :(得分:7)

好的,你问过它。

1:你的collect_sources:... include sources是光荣的Rube Goldberg的hackery。就这样做:

SRCS = $(wildcard ./src/*.cpp)

如果您想通过眼睛确认,可以这样做:

$(info $(SRCS))

2:

clear_dependencies:
    echo "" > $(DEP);

为了美学,让我们解决这个问题。

clear_dependencies:
    $(RM) $(DEP);

3:

$(SRCDIR)/%.cpp:
    @$(CXX) $(DEPFLAGS) -MT \
  "$(subst $(SRCDIR),$(OBJDIR),$(subst $(EXT_SRC),$(EXT_OBJ),$$file))" \
  $(addprefix ,$$file) >> $(DEP);

这需要一些工作。首先是当前问题:目标是存在的真实文件,规则没有先决条件。因此规则将不会运行(我不知道为什么它在以前的版本中对你有用,也许其他东西是不同的)。作为临时修复,我建议我们切换到静态模式规则和PHONY目标:

.PHONY:$(SRCS)
$(SRCS) : $(SRCDIR)/%.cpp:
    @$(CXX) $(DEPFLAGS) -MT \
   ...

看看是否一切正常,那么我们就可以解决这些问题。