makefile编译所有文件而不是最后编辑的文件

时间:2016-10-03 16:53:16

标签: c++ makefile

请注意,SO上也有类似的问题,但我认为我的情况有所不同,而且我的Makefile非常简单直接。我是Makefile的新手。

假设我需要编译一个看起来像这样的项目 -

.
├── [4.0K]  bin
├── [ 517]  Makefile
├── [4.0K]  obj
└── [4.0K]  src
    ├── [ 117]  func1.cpp
    ├── [  76]  func2.cpp
    ├── [ 137]  global.h
    └── [  97]  main1.cpp

我的Makefile看起来像这样 -

CC          := g++
CFLAGS      := -g -Wall -std=c++0x
LDFLAGS     := -lm

NAMES   := func1.cpp func2.cpp main1.cpp
SRC     := $(addprefix src/,$(NAMES))
OBJ     := $(addprefix obj/,$(NAMES:.cpp=.o))
DEPS    := $(OBJ:.o=.d)

.PHONY: clean all debug

all: prog

debug:
    $(info $$SRC: ${SRC})
    $(info $$OBJ: ${OBJ})
    $(info $$DEPS: ${DEPS})

prog: bin/prog

bin/prog: $(OBJ)
    $(CC) $^ -o $@

$(OBJ): $(SRC)
    $(CC) $(CFLAGS) -I/src/global.h -c $(addprefix src/,$(notdir $(@:.o=.cpp))) -o $@

-include $(DEPS)

clean:
    rm -rf bin/*
    rm -rf obj/*

假设我打开了一个文件func1.cpp并进行了一些更改。当我调用make时,它会编译所有文件,但它应该只编译一个(func1.cpp)。

我该如何解决这个问题?

注意:我需要progbin/prog出于其他原因,我也不能做obj/%.o: src/%.c之类的食谱,因为我可能会有所不同从相同对象的子集中定位。

1 个答案:

答案 0 :(得分:5)

当您编写如下规则时:

$(OBJ): $(SRC)
    cmd

在你的情况下是

obj/func1.o obj/func2.o obj/main.o : src/func1.cpp src/func2.cpp src/main1.cpp
    cmd

先决条件不会被压缩。这为每个目标生成一个规则,包含所有先决条件。那就是:

obj/func1.o : src/func1.cpp src/func2.cpp src/main1.cpp
    cmd

obj/func2.o : src/func1.cpp src/func2.cpp src/main1.cpp
    cmd

obj/main.o : src/func1.cpp src/func2.cpp src/main1.cpp
    cmd

由于src/func1.cpp是所有目标文件的先决条件,因此它们都会被重新编译。

您想要的是使用static pattern rule

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

请注意,-I适用于包含目录,不包含文件。