summaryrefslogtreecommitdiff
path: root/plugins/pychrysalide/arch
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/pychrysalide/arch')
-rw-r--r--plugins/pychrysalide/arch/immediate.c32
-rw-r--r--plugins/pychrysalide/arch/immediate.h2
-rw-r--r--plugins/pychrysalide/arch/instriter.c27
-rw-r--r--plugins/pychrysalide/arch/instriter.h2
-rw-r--r--plugins/pychrysalide/arch/instruction.c28
-rw-r--r--plugins/pychrysalide/arch/instruction.h2
-rw-r--r--plugins/pychrysalide/arch/module.c65
-rw-r--r--plugins/pychrysalide/arch/module.h7
-rw-r--r--plugins/pychrysalide/arch/operand.c22
-rw-r--r--plugins/pychrysalide/arch/operand.h2
-rw-r--r--plugins/pychrysalide/arch/processor.c24
-rw-r--r--plugins/pychrysalide/arch/processor.h2
-rw-r--r--plugins/pychrysalide/arch/raw.c24
-rw-r--r--plugins/pychrysalide/arch/raw.h2
-rw-r--r--plugins/pychrysalide/arch/targetableop.c18
-rw-r--r--plugins/pychrysalide/arch/targetableop.h2
-rw-r--r--plugins/pychrysalide/arch/vmpa.c57
-rw-r--r--plugins/pychrysalide/arch/vmpa.h4
18 files changed, 206 insertions, 116 deletions
diff --git a/plugins/pychrysalide/arch/immediate.c b/plugins/pychrysalide/arch/immediate.c
index e3c5c34..5ee2d41 100644
--- a/plugins/pychrysalide/arch/immediate.c
+++ b/plugins/pychrysalide/arch/immediate.c
@@ -36,6 +36,8 @@
#include "operand.h"
+#include "targetableop.h"
+#include "../access.h"
#include "../helpers.h"
@@ -674,21 +676,33 @@ PyTypeObject *get_python_imm_operand_type(void)
* *
******************************************************************************/
-bool register_python_imm_operand(PyObject *module)
+bool ensure_python_imm_operand_is_registered(void)
{
- PyTypeObject *py_imm_operand_type; /* Type Python 'BinContent' */
+ PyTypeObject *type; /* Type Python 'ImmOperand' */
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- py_imm_operand_type = get_python_imm_operand_type();
+ type = get_python_imm_operand_type();
- dict = PyModule_GetDict(module);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ module = get_access_to_python_module("pychrysalide.arch");
+
+ dict = PyModule_GetDict(module);
+
+ if (!ensure_python_arch_operand_is_registered())
+ return false;
- if (!register_class_for_pygobject(dict, G_TYPE_IMM_OPERAND,
- py_imm_operand_type, get_python_arch_operand_type()))
- return false;
+ if (!ensure_python_targetable_operand_is_registered())
+ return false;
- if (!py_imm_operand_define_constants(py_imm_operand_type))
- return false;
+ if (!register_class_for_pygobject(dict, G_TYPE_IMM_OPERAND, type, get_python_arch_operand_type()))
+ return false;
+
+ if (!py_imm_operand_define_constants(type))
+ return false;
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/immediate.h b/plugins/pychrysalide/arch/immediate.h
index 3c99b19..fd456e4 100644
--- a/plugins/pychrysalide/arch/immediate.h
+++ b/plugins/pychrysalide/arch/immediate.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_imm_operand_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.ImmOperand'. */
-bool register_python_imm_operand(PyObject *);
+bool ensure_python_imm_operand_is_registered(void);
diff --git a/plugins/pychrysalide/arch/instriter.c b/plugins/pychrysalide/arch/instriter.c
index 244a825..f665cba 100644
--- a/plugins/pychrysalide/arch/instriter.c
+++ b/plugins/pychrysalide/arch/instriter.c
@@ -32,6 +32,7 @@
#include "processor.h"
+#include "../access.h"
@@ -258,19 +259,29 @@ PyTypeObject *get_python_instr_iterator_type(void)
* *
******************************************************************************/
-bool register_python_instr_iterator(PyObject *module)
+bool ensure_python_instr_iterator_is_registered(void)
{
- PyTypeObject *py_instr_iterator_type; /* Type Python 'BinContent' */
+ PyTypeObject *type; /* Type Python 'InstrIterator' */
+ PyObject *module; /* Module à recompléter */
int ret; /* Bilan d'un appel */
- py_instr_iterator_type = get_python_instr_iterator_type();
+ type = get_python_instr_iterator_type();
- if (PyType_Ready(py_instr_iterator_type) < 0)
- return false;
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ if (PyType_Ready(type) < 0)
+ return false;
+
+ module = get_access_to_python_module("pychrysalide.arch");
+
+ Py_INCREF(type);
+ ret = PyModule_AddObject(module, "InstrIterator", (PyObject *)type);
- Py_INCREF(py_instr_iterator_type);
- ret = PyModule_AddObject(module, "InstrIterator", (PyObject *)py_instr_iterator_type);
+ if (ret != 0)
+ return false;
+
+ }
- return (ret == 0);
+ return true;
}
diff --git a/plugins/pychrysalide/arch/instriter.h b/plugins/pychrysalide/arch/instriter.h
index 3cb0e38..543d988 100644
--- a/plugins/pychrysalide/arch/instriter.h
+++ b/plugins/pychrysalide/arch/instriter.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_instr_iterator_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.InstrIterator'. */
-bool register_python_instr_iterator(PyObject *);
+bool ensure_python_instr_iterator_is_registered(void);
diff --git a/plugins/pychrysalide/arch/instruction.c b/plugins/pychrysalide/arch/instruction.c
index d659c87..df5bc15 100644
--- a/plugins/pychrysalide/arch/instruction.c
+++ b/plugins/pychrysalide/arch/instruction.c
@@ -33,6 +33,7 @@
#include "vmpa.h"
+#include "../access.h"
#include "../helpers.h"
#include "../glibext/linegen.h"
@@ -498,23 +499,30 @@ PyTypeObject *get_python_arch_instruction_type(void)
* *
******************************************************************************/
-bool register_python_arch_instruction(PyObject *module)
+bool ensure_python_arch_instruction_is_registered(void)
{
- PyTypeObject *py_arch_instruction_type; /* Type Python 'ArchInstruc...'*/
+ PyTypeObject *type; /* Type Python 'ArchInstruc...'*/
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- PyTypeObject *py_line_generator_type; /* Type Python 'LineGenerator' */
- py_arch_instruction_type = get_python_arch_instruction_type();
+ type = get_python_arch_instruction_type();
- APPLY_ABSTRACT_FLAG(py_arch_instruction_type);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ APPLY_ABSTRACT_FLAG(type);
+
+ module = get_access_to_python_module("pychrysalide.arch");
- dict = PyModule_GetDict(module);
+ dict = PyModule_GetDict(module);
- py_line_generator_type = get_python_line_generator_type();
+ if (!ensure_python_line_generator_is_registered())
+ return false;
- if (!_register_class_for_pygobject(dict, G_TYPE_ARCH_INSTRUCTION, py_arch_instruction_type,
- &PyGObject_Type, py_line_generator_type, NULL))
- return false;
+ if (!_register_class_for_pygobject(dict, G_TYPE_ARCH_INSTRUCTION, type,
+ &PyGObject_Type, get_python_line_generator_type(), NULL))
+ return false;
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/instruction.h b/plugins/pychrysalide/arch/instruction.h
index ef1f598..5433222 100644
--- a/plugins/pychrysalide/arch/instruction.h
+++ b/plugins/pychrysalide/arch/instruction.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_arch_instruction_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.ArchInstruction'. */
-bool register_python_arch_instruction(PyObject *);
+bool ensure_python_arch_instruction_is_registered(void);
diff --git a/plugins/pychrysalide/arch/module.c b/plugins/pychrysalide/arch/module.c
index 406b78c..c81a762 100644
--- a/plugins/pychrysalide/arch/module.c
+++ b/plugins/pychrysalide/arch/module.c
@@ -39,7 +39,6 @@
#include "raw.h"
#include "targetableop.h"
#include "vmpa.h"
-#include "../access.h"
#include "../helpers.h"
@@ -94,21 +93,20 @@ static bool py_base_define_constants(PyTypeObject *obj_type)
/******************************************************************************
* *
-* Paramètres : module = module dont la définition est à compléter. *
+* Paramètres : super = module dont la définition est à compléter. *
* *
-* Description : Ajoute le module 'arch' au module Python. *
+* Description : Ajoute le module 'arch' à un module Python. *
* *
-* Retour : - *
+* Retour : Bilan de l'opération. *
* *
* Remarques : - *
* *
******************************************************************************/
-bool add_arch_module_to_python_module(PyObject *super)
+bool add_arch_module(PyObject *super)
{
bool result; /* Bilan à retourner */
PyObject *module; /* Sous-module mis en place */
- int ret; /* Bilan d'un appel */
static PyModuleDef py_chrysalide_arch_module = {
@@ -121,41 +119,44 @@ bool add_arch_module_to_python_module(PyObject *super)
};
- result = false;
+ module = build_python_module(super, &py_chrysalide_arch_module);
- module = PyModule_Create(&py_chrysalide_arch_module);
- if (module == NULL) return false;
+ result = (module != NULL);
- ret = PyState_AddModule(super, &py_chrysalide_arch_module);
- if (ret != 0) goto loading_failed;
+ if (result) result = py_base_define_constants(Py_TYPE(module));
- ret = _PyImport_FixupBuiltin(module, "pychrysalide.arch");
- if (ret != 0) goto loading_failed;
-
- Py_INCREF(module);
- ret = PyModule_AddObject(super, "arch", module);
- if (ret != 0) goto loading_failed;
-
- result = true;
+ return result;
- result &= py_base_define_constants(Py_TYPE(module));
+}
- result &= register_python_targetable_operand(module);
- result &= register_python_arch_instruction(module);
- result &= register_python_arch_operand(module);
- result &= register_python_arch_processor(module);
- result &= register_python_instr_iterator(module);
- result &= register_python_raw_instruction(module);
- result &= register_python_vmpa(module);
- result &= register_python_mrange(module);
+/******************************************************************************
+* *
+* Paramètres : - *
+* *
+* Description : Intègre les objets du module 'arch'. *
+* *
+* Retour : Bilan de l'opération. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
- result &= register_python_imm_operand(module);
+bool populate_arch_module(void)
+{
+ bool result; /* Bilan à retourner */
- if (result)
- register_access_to_python_module("pychrysalide.arch", module);
+ result = true;
- loading_failed:
+ if (result) result = ensure_python_imm_operand_is_registered();
+ if (result) result = ensure_python_instr_iterator_is_registered();
+ if (result) result = ensure_python_arch_instruction_is_registered();
+ if (result) result = ensure_python_arch_operand_is_registered();
+ if (result) result = ensure_python_arch_processor_is_registered();
+ if (result) result = ensure_python_raw_instruction_is_registered();
+ if (result) result = ensure_python_targetable_operand_is_registered();
+ if (result) result = ensure_python_vmpa_is_registered();
+ if (result) result = ensure_python_mrange_is_registered();
assert(result);
diff --git a/plugins/pychrysalide/arch/module.h b/plugins/pychrysalide/arch/module.h
index 07d3575..b4cde0e 100644
--- a/plugins/pychrysalide/arch/module.h
+++ b/plugins/pychrysalide/arch/module.h
@@ -31,8 +31,11 @@
-/* Ajoute le module 'arch' au module Python. */
-bool add_arch_module_to_python_module(PyObject *);
+/* Ajoute le module 'arch' à un module Python. */
+bool add_arch_module(PyObject *);
+
+/* Intègre les objets du module 'arch'. */
+bool populate_arch_module(void);
diff --git a/plugins/pychrysalide/arch/operand.c b/plugins/pychrysalide/arch/operand.c
index 427f92b..e464eac 100644
--- a/plugins/pychrysalide/arch/operand.c
+++ b/plugins/pychrysalide/arch/operand.c
@@ -31,6 +31,7 @@
#include <arch/operand.h>
+#include "../access.h"
#include "../helpers.h"
@@ -90,19 +91,26 @@ PyTypeObject *get_python_arch_operand_type(void)
* *
******************************************************************************/
-bool register_python_arch_operand(PyObject *module)
+bool ensure_python_arch_operand_is_registered(void)
{
- PyTypeObject *py_arch_operand_type; /* Type Python 'BinContent' */
+ PyTypeObject *type; /* Type Python 'ArchOperand' */
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- py_arch_operand_type = get_python_arch_operand_type();
+ type = get_python_arch_operand_type();
- APPLY_ABSTRACT_FLAG(py_arch_operand_type);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ APPLY_ABSTRACT_FLAG(type);
- dict = PyModule_GetDict(module);
+ module = get_access_to_python_module("pychrysalide.arch");
- if (!register_class_for_pygobject(dict, G_TYPE_ARCH_OPERAND, py_arch_operand_type, &PyGObject_Type))
- return false;
+ dict = PyModule_GetDict(module);
+
+ if (!register_class_for_pygobject(dict, G_TYPE_ARCH_OPERAND, type, &PyGObject_Type))
+ return false;
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/operand.h b/plugins/pychrysalide/arch/operand.h
index 3ee7ed1..a718d8f 100644
--- a/plugins/pychrysalide/arch/operand.h
+++ b/plugins/pychrysalide/arch/operand.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_arch_operand_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.ArchOperand'. */
-bool register_python_arch_operand(PyObject *);
+bool ensure_python_arch_operand_is_registered(void);
diff --git a/plugins/pychrysalide/arch/processor.c b/plugins/pychrysalide/arch/processor.c
index c2ee530..3ac18fa 100644
--- a/plugins/pychrysalide/arch/processor.c
+++ b/plugins/pychrysalide/arch/processor.c
@@ -38,6 +38,7 @@
#include "instriter.h"
#include "instruction.h"
#include "vmpa.h"
+#include "../access.h"
#include "../helpers.h"
@@ -489,20 +490,27 @@ PyTypeObject *get_python_arch_processor_type(void)
* *
******************************************************************************/
-bool register_python_arch_processor(PyObject *module)
+bool ensure_python_arch_processor_is_registered(void)
{
- PyTypeObject *py_arch_processor_type; /* Type Python 'BinContent' */
+ PyTypeObject *type; /* Type Python 'ArchProcessor' */
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- py_arch_processor_type = get_python_arch_processor_type();
+ type = get_python_arch_processor_type();
- dict = PyModule_GetDict(module);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ module = get_access_to_python_module("pychrysalide.arch");
+
+ dict = PyModule_GetDict(module);
- if (!register_class_for_pygobject(dict, G_TYPE_ARCH_PROCESSOR, py_arch_processor_type, &PyGObject_Type))
- return false;
+ if (!register_class_for_pygobject(dict, G_TYPE_ARCH_PROCESSOR, type, &PyGObject_Type))
+ return false;
- if (!define_python_arch_processor_constants(py_arch_processor_type))
- return false;
+ if (!define_python_arch_processor_constants(type))
+ return false;
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/processor.h b/plugins/pychrysalide/arch/processor.h
index ff6ccb3..2db8950 100644
--- a/plugins/pychrysalide/arch/processor.h
+++ b/plugins/pychrysalide/arch/processor.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_arch_processor_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.ArchProcessor'. */
-bool register_python_arch_processor(PyObject *);
+bool ensure_python_arch_processor_is_registered(void);
diff --git a/plugins/pychrysalide/arch/raw.c b/plugins/pychrysalide/arch/raw.c
index 39b5fe7..318eb6b 100644
--- a/plugins/pychrysalide/arch/raw.c
+++ b/plugins/pychrysalide/arch/raw.c
@@ -32,6 +32,7 @@
#include "instruction.h"
+#include "../access.h"
#include "../helpers.h"
@@ -243,20 +244,27 @@ PyTypeObject *get_python_raw_instruction_type(void)
* *
******************************************************************************/
-bool register_python_raw_instruction(PyObject *module)
+bool ensure_python_raw_instruction_is_registered(void)
{
- PyTypeObject *py_raw_instruction_type; /* Type Python 'RawInstruction'*/
+ PyTypeObject *type; /* Type Python 'RawInstruction'*/
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- PyTypeObject *base; /* Base parente pour héritage */
- py_raw_instruction_type = get_python_raw_instruction_type();
+ type = get_python_raw_instruction_type();
- dict = PyModule_GetDict(module);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ module = get_access_to_python_module("pychrysalide.arch");
- base = get_python_arch_instruction_type();
+ dict = PyModule_GetDict(module);
- if (!register_class_for_pygobject(dict, G_TYPE_RAW_INSTRUCTION, py_raw_instruction_type, base))
- return false;
+ if (!ensure_python_arch_instruction_is_registered())
+ return false;
+
+ if (!register_class_for_pygobject(dict, G_TYPE_RAW_INSTRUCTION, type, get_python_arch_instruction_type()))
+ return false;
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/raw.h b/plugins/pychrysalide/arch/raw.h
index 32c4e2d..552db41 100644
--- a/plugins/pychrysalide/arch/raw.h
+++ b/plugins/pychrysalide/arch/raw.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_raw_instruction_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.RawInstruction'. */
-bool register_python_raw_instruction(PyObject *);
+bool ensure_python_raw_instruction_is_registered(void);
diff --git a/plugins/pychrysalide/arch/targetableop.c b/plugins/pychrysalide/arch/targetableop.c
index 8951492..0fb23e0 100644
--- a/plugins/pychrysalide/arch/targetableop.c
+++ b/plugins/pychrysalide/arch/targetableop.c
@@ -37,6 +37,7 @@
#include "processor.h"
#include "vmpa.h"
+#include "../access.h"
#include "../format/format.h"
@@ -163,15 +164,22 @@ PyTypeObject *get_python_targetable_operand_type(void)
* *
******************************************************************************/
-bool register_python_targetable_operand(PyObject *module)
+bool ensure_python_targetable_operand_is_registered(void)
{
- PyTypeObject *py_targetable_operand_type; /* Type 'TargetableOperand' */
+ PyTypeObject *type; /* Type 'TargetableOperand' */
+ PyObject *module; /* Module à recompléter */
PyObject *dict; /* Dictionnaire du module */
- py_targetable_operand_type = get_python_targetable_operand_type();
+ type = get_python_targetable_operand_type();
- dict = PyModule_GetDict(module);
- pyg_register_interface(dict, "TargetableOperand", G_TYPE_TARGETABLE_OPERAND, py_targetable_operand_type);
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ module = get_access_to_python_module("pychrysalide.arch");
+
+ dict = PyModule_GetDict(module);
+ pyg_register_interface(dict, "TargetableOperand", G_TYPE_TARGETABLE_OPERAND, type);
+
+ }
return true;
diff --git a/plugins/pychrysalide/arch/targetableop.h b/plugins/pychrysalide/arch/targetableop.h
index d79bb87..4c41a4d 100644
--- a/plugins/pychrysalide/arch/targetableop.h
+++ b/plugins/pychrysalide/arch/targetableop.h
@@ -35,7 +35,7 @@
PyTypeObject *get_python_targetable_operand_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.TargetableOperand'. */
-bool register_python_targetable_operand(PyObject *);
+bool ensure_python_targetable_operand_is_registered(void);
diff --git a/plugins/pychrysalide/arch/vmpa.c b/plugins/pychrysalide/arch/vmpa.c
index 39b5cef..883491f 100644
--- a/plugins/pychrysalide/arch/vmpa.c
+++ b/plugins/pychrysalide/arch/vmpa.c
@@ -32,6 +32,7 @@
#include <i18n.h>
+#include "../access.h"
#include "../helpers.h"
@@ -678,23 +679,33 @@ PyTypeObject *get_python_vmpa_type(void)
* *
******************************************************************************/
-bool register_python_vmpa(PyObject *module)
+bool ensure_python_vmpa_is_registered(void)
{
- PyTypeObject *py_vmpa_type; /* Type Python pour 'vmpa' */
+ PyTypeObject *type; /* Type Python pour 'vmpa' */
+ PyObject *module; /* Module à recompléter */
int ret; /* Bilan d'un appel */
- py_vmpa_type = get_python_vmpa_type();
+ type = get_python_vmpa_type();
+
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ if (PyType_Ready(type) != 0)
+ return false;
+
+ if (!py_vmpa_define_constants(type))
+ return false;
+
+ module = get_access_to_python_module("pychrysalide.arch");
- if (PyType_Ready(py_vmpa_type) != 0)
- return false;
+ Py_INCREF(type);
+ ret = PyModule_AddObject(module, "vmpa", (PyObject *)type);
- if (!py_vmpa_define_constants(py_vmpa_type))
- return false;
+ if (ret != 0)
+ return false;
- Py_INCREF(py_vmpa_type);
- ret = PyModule_AddObject(module, "vmpa", (PyObject *)py_vmpa_type);
+ }
- return (ret == 0);
+ return true;
}
@@ -1234,20 +1245,30 @@ PyTypeObject *get_python_mrange_type(void)
* *
******************************************************************************/
-bool register_python_mrange(PyObject *module)
+bool ensure_python_mrange_is_registered(void)
{
- PyTypeObject *py_mrange_type; /* Type Python pour 'mrange' */
+ PyTypeObject *type; /* Type Python pour 'mrange' */
+ PyObject *module; /* Module à recompléter */
int ret; /* Bilan d'un appel */
- py_mrange_type = get_python_mrange_type();
+ type = get_python_mrange_type();
+
+ if (!PyType_HasFeature(type, Py_TPFLAGS_READY))
+ {
+ if (PyType_Ready(type) != 0)
+ return false;
- if (PyType_Ready(py_mrange_type) != 0)
- return false;
+ module = get_access_to_python_module("pychrysalide.arch");
- Py_INCREF(py_mrange_type);
- ret = PyModule_AddObject(module, "mrange", (PyObject *)py_mrange_type);
+ Py_INCREF(type);
+ ret = PyModule_AddObject(module, "mrange", (PyObject *)type);
+
+ if (ret != 0)
+ return false;
+
+ }
- return (ret == 0);
+ return true;
}
diff --git a/plugins/pychrysalide/arch/vmpa.h b/plugins/pychrysalide/arch/vmpa.h
index 46828f5..7705a10 100644
--- a/plugins/pychrysalide/arch/vmpa.h
+++ b/plugins/pychrysalide/arch/vmpa.h
@@ -38,7 +38,7 @@
PyTypeObject *get_python_vmpa_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.vmpa'. */
-bool register_python_vmpa(PyObject *);
+bool ensure_python_vmpa_is_registered(void);
/* Donne accès au coeur d'un objet 'pychrysalide.arch.vmpa'. */
vmpa2t *get_internal_vmpa(PyObject *);
@@ -58,7 +58,7 @@ int convert_any_to_vmpa(PyObject *, void *);
PyTypeObject *get_python_mrange_type(void);
/* Prend en charge l'objet 'pychrysalide.arch.mrange'. */
-bool register_python_mrange(PyObject *);
+bool ensure_python_mrange_is_registered(void);
/* Donne accès au coeur d'un objet 'pychrysalide.arch.mrange'. */
mrange_t *get_internal_mrange(PyObject *);