diff options
Diffstat (limited to 'plugins/pychrysalide/gui/constants.c')
-rw-r--r-- | plugins/pychrysalide/gui/constants.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/plugins/pychrysalide/gui/constants.c b/plugins/pychrysalide/gui/constants.c index 40942f6..3cd943c 100644 --- a/plugins/pychrysalide/gui/constants.c +++ b/plugins/pychrysalide/gui/constants.c @@ -71,3 +71,59 @@ bool define_panel_item_constants(PyTypeObject *type) return result; } + + +/****************************************************************************** +* * +* 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 constante PanelItemPersonality. * +* * +* Retour : Bilan de l'opération, voire indications supplémentaires. * +* * +* Remarques : - * +* * +******************************************************************************/ + +int convert_to_panel_item_personality(PyObject *arg, void *dst) +{ + int result; /* Bilan à retourner */ + unsigned long value; /* Valeur transcrite */ + + result = PyObject_IsInstance(arg, (PyObject *)&PyLong_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 PanelItemPersonality"); + break; + + case 1: + value = PyLong_AsUnsignedLong(arg); + + if (value > PIP_COUNT) + { + PyErr_SetString(PyExc_TypeError, "invalid value for PanelItemPersonality"); + result = 0; + } + + else + *((PanelItemPersonality *)dst) = value; + + break; + + default: + assert(false); + break; + + } + + return result; + +} |