BoostPython и CMake - PullRequest
       44

BoostPython и CMake

0 голосов
/ 22 октября 2018

Я успешно следовал этому примеру, как соединить C ++ и python.Он отлично работает, когда я использую данный Makefile.Когда я пытаюсь использовать cmake вместо этого, он также не работает.

C ++ Код:

#include <boost/python.hpp>
#include <iostream>
extern "C"
char const* greet()
{
   return "hello, world";
}

BOOST_PYTHON_MODULE(hello_ext)
{
    using namespace boost::python;
    def("greet", greet);
}

int main(){
    std::cout<<greet()<<std::endl;
    return 0;
}

Makefile:

# location of the Python header files
PYTHON_VERSION = 27
PYTHON_DOT_VERSION = 2.7
PYTHON_INCLUDE = /usr/include/python$(PYTHON_DOT_VERSION)
# location of the Boost Python include files and library
BOOST_INC = /usr/include
BOOST_LIB = /usr/lib/x86_64-linux-gnu/
# compile mesh classes
TARGET = hello_ext
$(TARGET).so: $(TARGET).o
    g++ -shared -Wl,--export-dynamic $(TARGET).o -L$(BOOST_LIB) -lboost_python-py$(PYTHON_VERSION) -L/usr/lib/python$(PYTHON_DOT_VERSION)/config-x86_64-linux-gnu -lpython$(PYTHON_DOT_VERSION) -o $(TARGET).so
$(TARGET).o: $(TARGET).cpp
    g++ -I$(PYTHON_INCLUDE) -I$(BOOST_INC) -fPIC -c $(TARGET).cpp

Когда я компилирую этоЯ получаю файл .so, который можно включить в сценарий

import sys
sys.path.append('/home/myname/Code/Trunk/TestBoostPython/build/')
import libhello_ext_lib as hello_ext

print(hello_ext.greet())

Я действительно хочу использовать cmake вместо написанного вручную Makefile, поэтому я написал это:

cmake_minimum_required(VERSION 3.6)
PROJECT(hello_ext)

# Find Boost
find_package(Boost REQUIRED COMPONENTS python-py27)

set(PYTHON_DOT_VERSION 2.7)
set(PYTHON_INCLUDE /usr/include/python2.7)
set(PYTHON_LIBRARY /usr/lib/python2.7/config-x86_64-linux-gnu)

include_directories(${PYTHON_INCLUDE} ${Boost_INCLUDE_DIRS})

SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -lrt -O3")

SET(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/bin)
SET(LIBNAME hello_ext_lib)

add_library(${LIBNAME} SHARED src/hello_ext.cpp)
add_executable(${PROJECT_NAME} src/hello_ext.cpp)

TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${Boost_LIBRARIES} -lpython2.7 -fPIC)
TARGET_LINK_LIBRARIES(${LIBNAME} ${Boost_LIBRARIES} -lpython2.7 -fPIC -shared)

Здесь я в настоящее время набираю Python-paths от руки, но я также попытался безуспешно использовать fin_package(PythonLibs).

Программа прекрасно компилируется и запускается, когда я запускаю исполняемый файл в ../bin/.Однако, когда я запускаю скрипт на python, я всегда получаю:

ImportError: dynamic module does not define init function (initlibhello_ext_lib)

Я нашел this , который говорит, что это может произойти, если lib и executable имеют разные имена.Это действительно так, но как я могу получить .so с правильным именем?

Я также попытался не скомпилировать исполняемый файл, а только библиотеку.Это тоже не сработало.

1 Ответ

0 голосов
/ 22 октября 2018

BOOST_PYTHON_MODULE(hello_ext) создает функцию инициализации "inithello_ext", которая должна соответствовать модулю "hello_ext".Но вы пытаетесь импортировать «libhello_ext_lib».

Дайте модулю то же имя, что и имя файла.Например, BOOST_PYTHON_MODULE(libhello_ext_lib).

...