makefile 多源文件一步编译规则

makefile multiple source file compilation rule in one step

我的目录结构如下: 生成文件 来源/ file1.cpp file2.cpp 公司/ file1.h file2.h 现在我想编写一个 make 规则来创建一个 'objs' 目录并将我所有的对象(.o 文件)放在 'objs' 中,然后从中构建一个库。我想一次完成,而不是为每个 .cpp 文件编写一条规则。 这是我试过的:

SRC_DIR:= src/
INC_DIR:=inc/

SRC_PATH:=$(foreach var, $(SRC_DIR), $(wildcard $(var)*.cpp))
OBJ_PATH:=$(patsubst %.cpp,%.o,$(SRC_PATH))
OBJ_PATH:=$(notdir $(OBJ_PATH))
OBJ_DIR:=./objs
OBJ_PATH:=$(addprefix $(OBJ_DIR)/,$(OBJ_PATH))

TARGET:=libcommon.a

all:$(TARGET)

$(TARGET): $(OBJ_PATH)
    ar -rcs $(TARGET) $(OBJ_PATH)
$(OBJ_PATH): $(SRC_PATH)    
    mkdir -p $(OBJ_DIR)
    $(CXX) -o $(OBJ_PATH) -c $(SRC_PATH) -I$(INC_DIR)

但是我收到这个错误:

[root@localhost common]# make
mkdir -p ./objs
g++   -o ./objs/file1.o ./objs/file2.o -c  src/file1.cpp src/file2.cpp -Iinc/
g++: ./objs/file1.o: No such file or directory
g++: cannot specify -o with -c or -S with multiple files

我在这个话题上做了很多搜索。没有得到任何帮助。请指出我正在做的错误。

您的代码错误:您使用列表代替 $@

我喜欢在子目录中自动搜索 src 和 header 的解决方案。

OBJ_DIR:=./objs

SOURCES:=$(wildcard */*.cpp *.cpp)
OBJECTS:= $(notdir $(SOURCES:.cpp=.o))
OBJECTS_LOCAL:=$(SOURCES:.cpp=.o)
LOCAL_PATHS_HEADERS:=$(sort $(dir $(wildcard *.h */*.h)))

OBJ_PATH:=$(addprefix $(OBJ_DIR)/, $(OBJECTS))

TARGET:=libcommon.a

all:$(TARGET)

$(TARGET): $(OBJECTS_LOCAL)
        ar -rcs $@ $(OBJ_PATH)

$(OBJECTS_LOCAL):
        mkdir -p $(OBJ_DIR)
        $(CC) -c $(@:.o=.cpp) -o $(OBJ_DIR)/$(notdir $@) $(addprefix -I,$(LOCAL_PATHS_HEADERS))

--添加

解决方案没有重新编译,但需要手动控制SRC_DIR

OBJ_DIR:=obj
SRC_DIR:=src

SOURCES:=$(wildcard $(SRC_DIR)/*.cpp)
OBJECTS_PATH:=$(addprefix $(OBJ_DIR)/, $(notdir $(SOURCES:.cpp=.o)))
LOCAL_PATHS_HEADERS:=$(sort $(dir $(wildcard *.h */*.h)))

TARGET:=libcommon.a

all:$(TARGET)

$(TARGET): $(OBJECTS_PATH)
        ar -rcs $@ $^

$(OBJECTS_PATH): $(OBJ_DIR)/%.o : $(SRC_DIR)/%.cpp
        mkdir -p $(OBJ_DIR)
        $(CC) -o  $@ -c $< $(addprefix -I,$(LOCAL_PATHS_HEADERS))