Python Language Estensione C con c ++ e Boost


Esempio

Questo è un esempio di base di un'estensione C che utilizza C ++ e Boost .

Codice C ++

Codice C ++ messo in hello.cpp:

#include <boost/python/module.hpp>
#include <boost/python/list.hpp>
#include <boost/python/class.hpp>
#include <boost/python/def.hpp>

// Return a hello world string.
std::string get_hello_function()
{
   return "Hello world!";
}

// hello class that can return a list of count hello world strings.
class hello_class
{
public:

   // Taking the greeting message in the constructor.
   hello_class(std::string message) : _message(message) {}

   // Returns the message count times in a python list.
   boost::python::list as_list(int count)
   {
      boost::python::list res;
      for (int i = 0; i < count; ++i) {
         res.append(_message);
      }
      return res;
   }
   
private:
   std::string _message;
};


// Defining a python module naming it to "hello".
BOOST_PYTHON_MODULE(hello)
{
   // Here you declare what functions and classes that should be exposed on the module.

   // The get_hello_function exposed to python as a function.
   boost::python::def("get_hello", get_hello_function);

   // The hello_class exposed to python as a class.
   boost::python::class_<hello_class>("Hello", boost::python::init<std::string>())
      .def("as_list", &hello_class::as_list)
      ;   
}

Per compilarlo in un modulo python occorrono le intestazioni python e le librerie boost. Questo esempio è stato realizzato su Ubuntu 12.04 usando python 3.4 e gcc. Boost è supportato su molte piattaforme. Nel caso di Ubuntu i pacchetti necessari sono stati installati usando:

sudo apt-get install gcc libboost-dev libpython3.4-dev

Compilare il file sorgente in un file .so che può essere successivamente importato come modulo purché si trovi sul percorso python:

gcc -shared -o hello.so -fPIC -I/usr/include/python3.4 hello.cpp -lboost_python-py34 -lboost_system -l:libpython3.4m.so

Il codice python nel file example.py:

import hello

print(hello.get_hello())

h = hello.Hello("World hello!")
print(h.as_list(3))

Quindi python3 example.py darà il seguente risultato:

Hello world!
['World hello!', 'World hello!', 'World hello!']