Updated for 2.1b2 distribution.
[python/dscho.git] / Include / cobject.h
blobf710d4af77248eaf3c93eae8efaed1b4a3852ba7
2 /* C objects to be exported from one extension module to another.
4 C objects are used for communication between extension modules.
5 They provide a way for an extension module to export a C interface
6 to other extension modules, so that extension modules can use the
7 Python import mechanism to link to one another.
9 */
11 #ifndef Py_COBJECT_H
12 #define Py_COBJECT_H
13 #ifdef __cplusplus
14 extern "C" {
15 #endif
17 extern DL_IMPORT(PyTypeObject) PyCObject_Type;
19 #define PyCObject_Check(op) ((op)->ob_type == &PyCObject_Type)
21 /* Create a PyCObject from a pointer to a C object and an optional
22 destructor function. If the second argument is non-null, then it
23 will be called with the first argument if and when the PyCObject is
24 destroyed.
27 extern DL_IMPORT(PyObject *)
28 PyCObject_FromVoidPtr(void *cobj, void (*destruct)(void*));
31 /* Create a PyCObject from a pointer to a C object, a description object,
32 and an optional destructor function. If the third argument is non-null,
33 then it will be called with the first and second arguments if and when
34 the PyCObject is destroyed.
36 extern DL_IMPORT(PyObject *)
37 PyCObject_FromVoidPtrAndDesc(void *cobj, void *desc,
38 void (*destruct)(void*,void*));
40 /* Retrieve a pointer to a C object from a PyCObject. */
41 extern DL_IMPORT(void *)
42 PyCObject_AsVoidPtr(PyObject *);
44 /* Retrieve a pointer to a description object from a PyCObject. */
45 extern DL_IMPORT(void *)
46 PyCObject_GetDesc(PyObject *);
48 /* Import a pointer to a C object from a module using a PyCObject. */
49 extern DL_IMPORT(void *)
50 PyCObject_Import(char *module_name, char *cobject_name);
52 #ifdef __cplusplus
54 #endif
55 #endif /* !Py_COBJECT_H */