【发布时间】:2017-12-12 23:17:34
【问题描述】:
我有一个看起来像这样的简单项目
.
├── build
│ ├── file1.o
│ └── one
│ ├── file1.o
│ └── file2.o
├── .depend
├── Makefile
└── src
├── file1.cpp
└── one
├── file1.cpp
└── file2.cpp
Makefile 是这样的:
# Get all of the source files
SRC = $(shell find src/ -name "*.cpp")
# Get all of the object files
OBJ = $(subst src,build,$(SRC:.cpp=.o))
$(OBJ):
@mkdir -p $(shell dirname $@)
g++ -g -c $(subst build,src,$(subst .o,.cpp,$@)) -o $@
all: depend build
build: $(OBJ)
gcc -o project $^
depend:
g++ -MM $(SRC) > .depend
sed -i 's/.\/src/.\/build\//g' .depend
sinclude .depend
我正在尝试通过运行 g++ -MM src/file1.cpp src/one/file1.cpp src/one/file2.cpp > .depend 来生成 makefile 依赖项,它会生成以下指令:
file1.o: src/file1.cpp <other headers>
file1.o: src/one/file1.cpp <other headers>
file2.o: src/one/file2.cpp <other headers>
问题在于build/file1.o 与file1.o 不匹配,因此,更改src/file1.cpp 或它所依赖的任何标头都不会导致目标文件被重建。起初我认为这可能是在生成 .depend 文件之前运行sinclude .depend 的问题,但即使我运行make depend 后跟make build,问题仍然存在。从我读过的所有内容来看,没有g++ 参数或选项可以保留名称的路径。
是否可以通过这种方式生成依赖文件,或者这是构建项目的根本错误方法?
我查看了这个问题被标记为可能重复的问题的答案,但似乎问题是询问如何为项目创建完整的 makefile,而我的问题不在于创建Makefile,而是gcc -MM 依赖生成的问题。这个问题的答案并没有解决我的问题。
【问题讨论】:
-
我在latedev.wordpress.com/2014/11/08/… 有几篇关于此的博客文章可能会有所帮助
-
您希望目标是什么样的?你不能再做一个
sed替换来按照你想要的方式修复它吗? -
感谢您的链接,但我在那里找不到我的问题的答案。我仍然不知道如何让
g++ -MM包含完整路径,或者如何让%.o: %.cpp匹配build/file1.o。 -
据我所知,在这种情况下我无法使用
sed替换,因为这种情况涉及完全丢失的信息。sed将允许我删除与模式匹配的路径信息,但我遇到的问题是路径信息从不存在。 -
有一种方法可以做到这一点,但是您确定要拥有一个大的依赖文件 (
.depend),而不是每个目标文件都有一个吗?后一种方法有一些优势,但这是您的决定。