0

我正在开发一个项目,我正在创建一个 .so 对象作为我的输出,其中包含几个用于另一个程序的运算符。我得到了一个运行良好的 Makefile,但它总是在我运行 make 时重新编译每个文件。最初这不是问题,但现在库中有超过 5 个或更多运算符,运行 make 非常慢。麻烦的是,对于我的生活,我无法弄清楚如何将这个 Makefile 更改为一个符合我想要的方式的文件,因为我以前从未处理过这种格式的 Makefile:

BOOST_LOCATION=/usr/local/boost_1_54_0

CFLAGS=-pedantic -W -Wextra -Wall -Wno-strict-aliasing -Wno-long-long -Wno-unused-parameter -fPIC -D__STDC_FORMAT_MACROS -Wno-system-headers -isystem -O2 -g -DNDEBUG -ggdb3  -D__STDC_LIMIT_MACROS
INC=-I. -DPROJECT_ROOT="\"$(IN_SOURCE_DIR)\"" -I"$(IN_SOURCE_DIR)/include" -I"$(BOOST_LOCATION)"
LIBS=-L"$(IN_SOURCE_DIR)/lib" -shared -Wl,-soname,libname.so -L. -lm

all:
    @if test ! -d "$(IN_SOURCE_DIR)"; then echo  "Error. Try:\n\nmake IN_SOURCE_DIR=<PATH TO SOURCE TRUNK>"; exit 1; fi 
    $(CXX) $(CFLAGS) $(INC) -o plugin.cpp.o -c plugin.cpp

    $(CXX) $(CFLAGS) $(INC) -o LogicalFile1.cpp.o -c File1/LogicalFile1.cpp
    $(CXX) $(CFLAGS) $(INC) -o PhysicalFile1.cpp.o -c File1/PhysicalFile1.cpp

    $(CXX) $(CFLAGS) $(INC) -o LogicalFile2.cpp.o -c File2/LogicalFile2.cpp
    $(CXX) $(CFLAGS) $(INC) -o PhysicalFile2.cpp.o -c File2/PhysicalFile2.cpp

    ### etc.

    $(CXX) $(CFLAGS) $(INC) -o libname.so \
                               plugin.cpp.o \
                               LogicalFile1.cpp.o \
                               PhysicalFile1.cpp.o \
                               LogicalFile2.cpp.o \
                               PhysicalFile2.cpp.o \
                               ### etc \
                               $(LIBS)

clean:
    rm -f *.o *.so

我遇到的最大问题是只有一个规则(全部),我找不到执行此操作的 Makefile 示例或如何将其拆分为多个规则。

4

2 回答 2

1

在这种情况下,它实际上非常简单。现在,您只有一个all正在完成所有构建的目标。您需要分解编译器调用并将步骤链接到它们自己的规则中,并且您应该参加比赛:

BOOST_LOCATION=/usr/local/boost_1_54_0

CFLAGS=-pedantic -W -Wextra -Wall -Wno-strict-aliasing -Wno-long-long -Wno-unused-parameter -fPIC -D__STDC_FORMAT_MACROS -Wno-system-headers -isystem -O2 -g -DNDEBUG -ggdb3  -D__STDC_LIMIT_MACROS
INC=-I. -DPROJECT_ROOT="\"$(IN_SOURCE_DIR)\"" -I"$(IN_SOURCE_DIR)/include" -I"$(BOOST_LOCATION)"
LIBS=-L"$(IN_SOURCE_DIR)/lib" -shared -Wl,-soname,libname.so -L. -lm

all: plugin.cpp.o LogicalFile1.cpp.o PhysicalFile1.cpp.o LogicalFile2.cpp.o PhysicalFile2.cpp.o
    $(CXX) $(CFLAGS) $(INC) -o libname.so \
                               plugin.cpp.o \
                               LogicalFile1.cpp.o \
                               PhysicalFile1.cpp.o \
                               LogicalFile2.cpp.o \
                               PhysicalFile2.cpp.o \
                               ### etc \
                               $(LIBS)

plugin.cpp.o: plugin.cpp | test
    $(CXX) $(CFLAGS) $(INC) -o plugin.cpp.o -c plugin.cpp

LogicalFile1.cpp.o: File1/LogicalFile1.cpp | test
    $(CXX) $(CFLAGS) $(INC) -o LogicalFile1.cpp.o -c File1/LogicalFile1.cpp

PhysicalFile1.cpp.o: File1/PhysicalFile1.cpp | test
    $(CXX) $(CFLAGS) $(INC) -o PhysicalFile1.cpp.o -c File1/PhysicalFile1.cpp

LogicalFile2.cpp.o: File2/LogicalFile2.cpp | test
    $(CXX) $(CFLAGS) $(INC) -o LogicalFile2.cpp.o -c File2/LogicalFile2.cpp

PhysicalFile2.cpp.o: File2/PhysicalFile2.cpp | test
    $(CXX) $(CFLAGS) $(INC) -o PhysicalFile2.cpp.o -c File2/PhysicalFile2.cpp

test:
    @if test ! -d "$(IN_SOURCE_DIR)"; then echo  "Error. Try:\n\nmake IN_SOURCE_DIR=<PATH TO SOURCE TRUNK>"; exit 1; fi 

clean:
    rm -f *.o *.so

.PHONY:全清测试

从这一点出发,您也可以进一步简化。例如,您可以将所有编译行合并到一个模式规则中。

于 2013-09-26T15:23:07.543 回答
1

如果您愿意为 make 使用标准格式和内置规则,您可以像这样轻松地编写整个 makefile:

ifeq (,$(wildcard $(IN_SOURCE_DIR)/.))
    $(error Try: make IN_SOURCE_DIR=<PATH TO SOURCE TRUNK>)
endif

OBJECTS = plugin.o LogicalFile1.o PhysicalFile1.o LogicalFile2.o PhysicalFile2.o  ### etc
BOOST_LOCATION = /usr/local/boost_1_54_0

CPPFLAGS = -DNDEBUG -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS -I. -DPROJECT_ROOT="\"$(IN_SOURCE_DIR)\"" -I"$(IN_SOURCE_DIR)/include" -I"$(BOOST_LOCATION)"
CXXFLAGS = -pedantic -W -Wextra -Wall -Wno-strict-aliasing -Wno-long-long -Wno-unused-parameter -fPIC -Wno-system-headers -isystem -O2 -g -ggdb3
LDFLAGS = -L"$(IN_SOURCE_DIR)/lib" -L.
LDLIBS = -shared -Wl,-soname,libname.so -lm

all: libname.so

libname.so: $(OBJECTS)
        $(LINK.cc) $^ $(LDLIBS) -o $@

clean:
        rm -f *.o *.so

.PHONY: all clean
于 2013-09-26T15:28:45.933 回答