生成gcc的依赖项

时间:2014-01-29 13:42:03

标签: gcc makefile dependencies

我正在编写一个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需要编译的所有依赖项,所以我试图

当我声明对象时,将此命令的输出与依赖关系放在一起。

你知道怎么做吗?

感谢。

1 个答案:

答案 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)