diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2019-03-04 20:52:50 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2019-03-04 20:52:50 (GMT) |
commit | 27c21356d494824850005932f3dee5f38d7a8e82 (patch) | |
tree | 6d7381f9cde78d28b4664f73ef03d0adb5b7b288 /plugins/pychrysalide/analysis/binary.c | |
parent | 72bebbd9dc7d59f69e23442b6c5b5526feb2a1a9 (diff) |
Provided access to the graph layout from Python.
Diffstat (limited to 'plugins/pychrysalide/analysis/binary.c')
-rw-r--r-- | plugins/pychrysalide/analysis/binary.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/plugins/pychrysalide/analysis/binary.c b/plugins/pychrysalide/analysis/binary.c index f73684b..bc57ab4 100644 --- a/plugins/pychrysalide/analysis/binary.c +++ b/plugins/pychrysalide/analysis/binary.c @@ -330,3 +330,48 @@ bool ensure_python_loaded_binary_is_registered(void) return true; } + + +/****************************************************************************** +* * +* Paramètres : arg = argument quelconque à tenter de convertir. * +* dst = destination des valeurs récupérées en cas de succès. * +* * +* Description : Tente de convertir en ensemble de binaire chargé. * +* * +* Retour : Bilan de l'opération, voire indications supplémentaires. * +* * +* Remarques : - * +* * +******************************************************************************/ + +int convert_to_loaded_binary(PyObject *arg, void *dst) +{ + int result; /* Bilan à retourner */ + + result = PyObject_IsInstance(arg, (PyObject *)get_python_loaded_binary_type()); + + switch (result) + { + case -1: + /* L'exception est déjà fixée par Python */ + result = 0; + break; + + case 0: + PyErr_SetString(PyExc_TypeError, "unable to convert the provided argument to loaded binary"); + break; + + case 1: + *((GLoadedBinary **)dst) = G_LOADED_BINARY(pygobject_get(arg)); + break; + + default: + assert(false); + break; + + } + + return result; + +} |