我正在编写一个Makefile来编译一个非常长的项目。 基本上,我已经定义了我需要的所有对象。 当我需要生成依赖项时,问题就出现了。 我正在做这样的事情:
a.o: $( $(CXX) -MM $(INCLUDE) A/a.cpp | sed 's/a.o: //')
$(CXX) $(CXXFLAGS) $(INCLUDES) A/a.cpp
b.o: $( $(CXX) -MM $(INCLUDE) A/b.cpp | sed 's/b.o: //')
$(CXX) $(CXXFLAGS) $(INCLUDES) A/b.cpp
libab.a: a.o b.o
$(LXX) $(LXXFLAGS) libab.a a.o b.o
“$(CXX)-MM $(INCLUDE)A / a.cpp | sed's / ao://'”的输出列出了a.cpp需要编译的所有依赖项,所以我试图
当我声明对象时,将此命令的输出与依赖关系放在一起。你知道怎么做吗?
感谢。
答案 0 :(得分:1)
为什么要尝试删除目标前缀,这正是您手动输入的内容?
而只是包含整个依赖项文件。
-include $(ALL_CPP_FILES:%.cpp=%.d)
我自动生成.d
(依赖)文件的常用标志是:
CPPFLAGS+=-MMD # automatic .d dependency file generation
这就像-MD
,除了它只提到用户头文件,而不是系统头文件。
样品:
# BUILD=RELEASE
PRJNAME=demo
#
TARGETS+=bin/test
build: \
$(TARGETS) \
tags
all: build
clean:
rm -rf bin/* $(ALL_OBJ_FILES)
rm -rf $(ALL_CPP_FILES:%.cpp=%.d)
##############################
# definition
CC=gcc
CXX=g++
CPPFLAGS+=-MMD # automatic .d dependency file generation
CPPFLAGS+=-std=c++11
ifeq ($(BUILD),RELEASE)
CPPFLAGS+=-g -O3
CPPFLAGS+=-march=native
else
CPPFLAGS+=-g -O0
CPPFLAGS+=-DDEBUG -D_DEBUG
CPPFLAGS+=-DUNIT_TESTS
endif
CPPFLAGS+=-Wall -Wextra -pedantic
#CPPFLAGS+=-Werror
LDFLAGS+=-lpthread
ALL_CPP_FILES=A/a.cpp A/b.cpp
ALL_OBJ_FILES=$(patsubst %.cpp,%.o,$(ALL_CPP_FILES))
##############################
tags: $(ALL_CPP_FILES)
ctags -R A/
%.o: %.cpp
$(CXX) -c $(CPPFLAGS) $< -o $@
##############################
# tool targets
bin/test: $(ALL_OBJ_FILES)
mkdir -pv $(@D)
$(CXX) $^ $(LDFLAGS) -o $@
.PRECIOUS: S(ALL_OBJ_FILES)
.PHONY: clean all build
-include $(ALL_CPP_FILES:%.cpp=%.d)