我的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
我错过了什么?我的方法是否有效/可行?
答案 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 \
...
看看是否一切正常,那么我们就可以解决这些问题。