summaryrefslogtreecommitdiff
path: root/plugins/pychrysalide/glibext/buffercache.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/pychrysalide/glibext/buffercache.c')
-rw-r--r--plugins/pychrysalide/glibext/buffercache.c22
1 files changed, 15 insertions, 7 deletions
diff --git a/plugins/pychrysalide/glibext/buffercache.c b/plugins/pychrysalide/glibext/buffercache.c
index f61d34f..b01b68c 100644
--- a/plugins/pychrysalide/glibext/buffercache.c
+++ b/plugins/pychrysalide/glibext/buffercache.c
@@ -31,8 +31,9 @@
#include <glibext/gbuffercache.h>
-#include "../arch/vmpa.h"
+#include "../access.h"
#include "../helpers.h"
+#include "../arch/vmpa.h"
@@ -148,17 +149,24 @@ PyTypeObject *get_python_buffer_cache_type(void)
* *
******************************************************************************/
-bool register_python_buffer_cache(PyObject *module)
+bool ensure_python_buffer_cache_is_registered(void)
{
- PyTypeObject *py_buffer_cache_type; /* Type Python 'BufferCache' */
+ PyTypeObject *type; /* Type Python 'BufferCache' */
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- py_buffer_cache_type = get_python_buffer_cache_type();
+ type = get_python_buffer_cache_type();
+
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ module = get_access_to_python_module("pychrysalide.glibext");
+
+ dict = PyModule_GetDict(module);
- dict = PyModule_GetDict(module);
+ if (!register_class_for_pygobject(dict, G_TYPE_BUFFER_CACHE, type, &PyGObject_Type))
+ return false;
- if (!register_class_for_pygobject(dict, G_TYPE_BUFFER_CACHE, py_buffer_cache_type, &PyGObject_Type))
- return false;
+ }
return true;