繁体   English   中英

Makefile每次都会构建所有内容

[英]Makefile builds everything each time

我有以下Makefile(减少为忽略无关的内容):

BUILD_DIR=./build
OBJS = \
  $(BUILD_DIR)/main.o \
  $(BUILD_DIR)/common.o \
  ...

roo: $(OBJS)
    $(CXX) -o $@ $(OBJS) $(LFLAGS)

.PHONY: $(BUILD_DIR)
$(BUILD_DIR):
    mkdir -p $(BUILD_DIR)/passes

$(BUILD_DIR)/%.o: src/%.cpp $(BUILD_DIR)
    $(CXX) -o $@ -c $< $(CFLAGS)

但是,每次都会重新编译每个目标文件,甚至以为我遵循的规则是在每个非语音目标中直接使用$@

我不认为这是一个重复的这个 ,因为我申请的子目录中的规则,而不是在食谱,但我可能是错了吗? 如何获得Make来正确跟踪构建目录中的依赖关系?

您已经说过$(BUILD_DIR)/%.o取决于$(BUILD_DIR) ,但是每次将文件添加到该目录时都会触摸该目录(例如,此规则本身)。 也就是说, $(BUILD_DIR)始终比其目标新。

您似乎要自动创建构建目录。 我认为最好的方法是

$(BUILD_DIR)/%.o: src/%.cpp
    mkdir -p $(BUILD_DIR)/passes
    $(CXX) -o $@ -c $< $(CFLAGS)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM