CObjects
********

Warning:

  The CObject API is deprecated as of Python 2.7.  Please switch to
  the new Capsules API.

PyCObject

   This subtype of "PyObject" represents an opaque value, useful for C
   extension modules who need to pass an opaque value (as a "void*"
   pointer) through Python code to other C code.  It is often used to
   make a C function pointer defined in one module available to other
   modules, so the regular import mechanism can be used to access C
   APIs defined in dynamically loaded modules.

int PyCObject_Check(PyObject *p)

   Return true if its argument is a "PyCObject".

PyObject* PyCObject_FromVoidPtr(void* cobj, void (*destr)(void *))
    *Return value: New reference.*

   Create a "PyCObject" from the "void *" *cobj*.  The *destr*
   function will be called when the object is reclaimed, unless it is
   *NULL*.

PyObject* PyCObject_FromVoidPtrAndDesc(void* cobj, void* desc, void (*destr)(void *, void *))
    *Return value: New reference.*

   Create a "PyCObject" from the "void *" *cobj*.  The *destr*
   function will be called when the object is reclaimed. The *desc*
   argument can be used to pass extra callback data for the destructor
   function.

void* PyCObject_AsVoidPtr(PyObject* self)

   Return the object "void *" that the "PyCObject" *self* was created
   with.

void* PyCObject_GetDesc(PyObject* self)

   Return the description "void *" that the "PyCObject" *self* was
   created with.

int PyCObject_SetVoidPtr(PyObject* self, void* cobj)

   Set the void pointer inside *self* to *cobj*. The "PyCObject" must
   not have an associated destructor. Return true on success, false on
   failure.
