仅用于编译已更改文件的共享库的Makefile?

时间:2013-09-26 15:14:12

标签: c++ makefile shared-libraries

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

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示例或者如何将其拆分成多个规则。

2 个答案:

答案 0 :(得分: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:所有干净的测试

从这一点来看,您也可以进一步简化。例如,您可以将所有编译行合并为单个模式规则。

答案 1 :(得分: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