summaryrefslogtreecommitdiff
path: root/plugins/pychrysa/gtkext/module.c
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2015-07-17 16:36:21 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2015-07-17 16:36:21 (GMT)
commit24d3836fcf8d443eb654b981f65478cd9923b8f1 (patch)
tree7672a28b864127e8958c3c6cce751dcf646d2fbe /plugins/pychrysa/gtkext/module.c
parenta61f089babe336b012da31a494b0f7470b6e1a9a (diff)
Updated the Python bindings.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@552 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'plugins/pychrysa/gtkext/module.c')
-rw-r--r--plugins/pychrysa/gtkext/module.c39
1 files changed, 32 insertions, 7 deletions
diff --git a/plugins/pychrysa/gtkext/module.c b/plugins/pychrysa/gtkext/module.c
index ef006e2..507b3cb 100644
--- a/plugins/pychrysa/gtkext/module.c
+++ b/plugins/pychrysa/gtkext/module.c
@@ -25,7 +25,11 @@
#include "module.h"
+#include <assert.h>
+
+
#include "blockview.h"
+#include "bufferview.h"
#include "viewpanel.h"
@@ -44,25 +48,46 @@
bool add_gtkext_module_to_python_module(PyObject *super)
{
- bool result;
- PyObject *module;
+ bool result; /* Bilan à retourner */
+ PyObject *module; /* Sous-module mis en place */
int ret; /* Bilan d'un appel */
- static PyMethodDef py_gtkext_methods[] = {
- { NULL }
+ static PyModuleDef py_chrysalide_gtkext_module = {
+
+ .m_base = PyModuleDef_HEAD_INIT,
+
+ .m_name = "pychrysalide.gtkext",
+ .m_doc = "Python module for Chrysalide.gtkext",
+
+ .m_size = -1,
+
};
- module = Py_InitModule("pychrysalide.gtkext", py_gtkext_methods);
+ result = false;
+
+ module = PyModule_Create(&py_chrysalide_gtkext_module);
if (module == NULL) return false;
+ ret = PyState_AddModule(super, &py_chrysalide_gtkext_module);
+ if (ret != 0) goto agmtpm_exit;
+
+ ret = _PyImport_FixupBuiltin(module, "pychrysalide.gtkext");
+ if (ret != 0) goto agmtpm_exit;
+
Py_INCREF(module);
- ret = PyModule_AddObject(super, "pychrysalide.gtkext", module);
+ ret = PyModule_AddObject(super, "gtkext", module);
+ if (ret != 0) goto agmtpm_exit;
- result = (ret == 0);
+ result = true;
result &= register_python_view_panel(module);
+ result &= register_python_buffer_view(module);
result &= register_python_block_view(module);
+ agmtpm_exit:
+
+ assert(result);
+
return result;
}