diff options
Diffstat (limited to 'plugins/pychrysalide/analysis/loaded.c')
-rw-r--r-- | plugins/pychrysalide/analysis/loaded.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/plugins/pychrysalide/analysis/loaded.c b/plugins/pychrysalide/analysis/loaded.c index 9b280a2..ac8176f 100644 --- a/plugins/pychrysalide/analysis/loaded.c +++ b/plugins/pychrysalide/analysis/loaded.c @@ -36,6 +36,9 @@ #include <analysis/loaded.h> +#include "../access.h" + + /* Lance l'analyse propre à l'élément chargé. */ static PyObject *py_loaded_content_analyze(PyObject *, PyObject *); @@ -251,7 +254,7 @@ PyTypeObject *get_python_loaded_content_type(void) /****************************************************************************** * * -* Paramètres : module = module dont la définition est à compléter. * +* Paramètres : - * * * * Description : Prend en charge l'objet 'pychrysalide.....LoadedContent'. * * * @@ -261,15 +264,22 @@ PyTypeObject *get_python_loaded_content_type(void) * * ******************************************************************************/ -bool register_python_loaded_content(PyObject *module) +bool ensure_python_loaded_content_is_registered(void) { - PyTypeObject *py_loaded_content_type; /* Type Python 'LoadedContent' */ + PyTypeObject *type; /* Type Python 'LoadedContent' */ + PyObject *module; /* Module à recompléter */ PyObject *dict; /* Dictionnaire du module */ - py_loaded_content_type = get_python_loaded_content_type(); + type = get_python_loaded_content_type(); - dict = PyModule_GetDict(module); - pyg_register_interface(dict, "LoadedContent", G_TYPE_LOADED_CONTENT, py_loaded_content_type); + if (!PyType_HasFeature(type, Py_TPFLAGS_READY)) + { + module = get_access_to_python_module("pychrysalide.analysis"); + + dict = PyModule_GetDict(module); + pyg_register_interface(dict, "LoadedContent", G_TYPE_LOADED_CONTENT, type); + + } return true; |