7

我有几个 C 和 C++ 项目都遵循我已经使用了一段时间的基本结构。我的源文件在 中src/*.c,中间文件在 中obj/*.[do],而实际的可执行文件在顶层目录中。

我的 makefile 大致遵循这个模板:

# The final executable
TARGET := something
# Source files (without src/)
INPUTS := foo.c bar.c baz.c

# OBJECTS will contain: obj/foo.o obj/bar.o obj/baz.o
OBJECTS := $(INPUTS:%.cpp=obj/%.o)
# DEPFILES will contain: obj/foo.d obj/bar.d obj/baz.d
DEPFILES := $(OBJECTS:%.o=%.d)

all: $(TARGET)

obj/%.o: src/%.cpp
    $(CC) $(CFLAGS) -c -o $@ $<

obj/%.d: src/%.cpp
    $(CC) $(CFLAGS) -M -MF $@ -MT $(@:%.d=%.o) $<

$(TARGET): $(OBJECTS)
    $(LD) $(LDFLAGS) -o $@ $(OBJECTS)

.PHONY: clean
clean:
    -rm -f $(OBJECTS) $(DEPFILES) $(RPOFILES) $(TARGET)

-include $(DEPFILES)

现在我正在为 Debian 系统打包它。我正在使用debuild构建 Debian 源代码包和pbuilder构建二进制包。该debuild步骤只需要执行clean目标,但即使这样也会导致生成和包含依赖文件。

简而言之,我的问题是:当我只想运行clean目标时,我能以某种方式阻止 make 生成依赖项吗?

4

1 回答 1

9

解决方法很简单,不要-include在clean下生成文件:

ifneq ($(MAKECMDGOALS),clean)
    -include $(DEPFILES)
endif
于 2010-05-05T12:43:27.687 回答