跳过某些目标的makefile依赖项生成(例如`clean`)

时间:2010-05-05 12:39:36

标签: makefile dependencies debian gnu-make

我有几个C和C ++项目都遵循我已经使用了一段时间的基本结构。我的源文件位于src/*.cobj/*.[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生成依赖项?

1 个答案:

答案 0 :(得分:9)

解决方案很简单,不要在-include下生成干净的文件:

ifneq ($(MAKECMDGOALS),clean)
    -include $(DEPFILES)
endif