123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- diff --git a/gtk/gtkmodule.c b/gtk/gtkmodule.c
- index c0e1493..aa8cf10 100644
- --- a/gtk/gtkmodule.c
- +++ b/gtk/gtkmodule.c
- @@ -227,8 +227,12 @@ init_gtk(void)
- pygtk_add_stock_items(d);
-
- /* extension API */
- - PyDict_SetItemString(d, "_PyGtk_API",
- - o=PyCObject_FromVoidPtr(&functions, NULL));
- +#if PY_VERSION_HEX >= 0x02070000
- + o = PyCapsule_New(&functions, "gtk._gtk._PyGtk_API", NULL);
- +#else
- + o = PyCObject_FromVoidPtr(&functions, NULL);
- +#endif
- + PyDict_SetItemString(d, "_PyGtk_API", o);
- Py_DECREF(o);
-
- PyGtkDeprecationWarning = PyErr_NewException("gtk.GtkDeprecationWarning",
- diff --git a/gtk/pygtk.h b/gtk/pygtk.h
- index 573c3b9..e4c680f 100644
- --- a/gtk/pygtk.h
- +++ b/gtk/pygtk.h
- @@ -60,6 +60,18 @@ struct _PyGtk_FunctionStruct *_PyGtk_API;
-
-
- /* a function to initialise the pygtk functions */
- +
- +/* Python 2.7 introduced the PyCapsule API and deprecated the CObject API */
- +#if PY_VERSION_HEX >= 0x02070000
- +#define init_pygtk() G_STMT_START { \
- + void *capsule = PyCapsule_Import("gtk._gtk._PyGtk_API", 0); \
- + if (!capsule) { \
- + return; \
- + } \
- + _PyGtk_API = (struct _PyGtk_FunctionStruct*)capsule; \
- +} G_STMT_END
- +#else /* PY_VERSION_HEX */
- +/* Python 2.6 and earlier use the CObject API */
- #define init_pygtk() G_STMT_START { \
- PyObject *pygtk = PyImport_ImportModule("gtk"); \
- if (pygtk != NULL) { \
- @@ -79,6 +91,7 @@ struct _PyGtk_FunctionStruct *_PyGtk_API;
- return; \
- } \
- } G_STMT_END
- +#endif /* PY_VERSION_HEX */
-
- #endif
-
|