summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUwe Hermann <uwe@hermann-uwe.de>2016-08-25 22:22:07 +0200
committerUwe Hermann <uwe@hermann-uwe.de>2016-08-25 22:33:02 +0200
commit40589f25f90c4863cfe2787b72629aa0a8cda082 (patch)
tree8b6df444bb1f898614e3e57db27accb71136b911
parente959f49ac718b45d83304f626559de29403ac52f (diff)
downloadlibsigrokdecode-40589f25f90c4863cfe2787b72629aa0a8cda082.tar.gz
libsigrokdecode-40589f25f90c4863cfe2787b72629aa0a8cda082.zip
Factor out srd_decoder_apiver().
-rw-r--r--decoder.c31
-rw-r--r--libsigrokdecode-internal.h3
2 files changed, 28 insertions, 6 deletions
diff --git a/decoder.c b/decoder.c
index 748280a..25ca476 100644
--- a/decoder.c
+++ b/decoder.c
@@ -587,6 +587,29 @@ static int check_method(PyObject *py_dec, const char *mod_name,
}
/**
+ * Get the API version of the specified decoder.
+ *
+ * @param d The decoder to use. Must not be NULL.
+ *
+ * @return The API version of the decoder, or 0 upon errors.
+ */
+SRD_PRIV long srd_decoder_apiver(const struct srd_decoder *d)
+{
+ PyObject *py_apiver;
+ long apiver;
+
+ if (!d)
+ return 0;
+
+ py_apiver = PyObject_GetAttrString(d->py_dec, "api_version");
+ apiver = (py_apiver && PyLong_Check(py_apiver))
+ ? PyLong_AsLong(py_apiver) : 0;
+ Py_XDECREF(py_apiver);
+
+ return apiver;
+}
+
+/**
* Load a protocol decoder module into the embedded Python interpreter.
*
* @param module_name The module name to be loaded.
@@ -597,7 +620,7 @@ static int check_method(PyObject *py_dec, const char *mod_name,
*/
SRD_API int srd_decoder_load(const char *module_name)
{
- PyObject *py_basedec, *py_apiver;
+ PyObject *py_basedec;
struct srd_decoder *d;
long apiver;
int is_subclass;
@@ -648,11 +671,7 @@ SRD_API int srd_decoder_load(const char *module_name)
* Check that this decoder has the correct PD API version.
* PDs of different API versions are incompatible and cannot work.
*/
- py_apiver = PyObject_GetAttrString(d->py_dec, "api_version");
- apiver = (py_apiver && PyLong_Check(py_apiver))
- ? PyLong_AsLong(py_apiver) : 0;
- Py_XDECREF(py_apiver);
-
+ apiver = srd_decoder_apiver(d);
if (apiver != 2) {
srd_exception_catch("Only PDs of API version 2 are supported");
goto err_out;
diff --git a/libsigrokdecode-internal.h b/libsigrokdecode-internal.h
index d32414a..8259b97 100644
--- a/libsigrokdecode-internal.h
+++ b/libsigrokdecode-internal.h
@@ -86,6 +86,9 @@ SRD_PRIV int srd_log(int loglevel, const char *format, ...) G_GNUC_PRINTF(2, 3);
#define srd_warn(...) srd_log(SRD_LOG_WARN, __VA_ARGS__)
#define srd_err(...) srd_log(SRD_LOG_ERR, __VA_ARGS__)
+/* decoder.c */
+SRD_PRIV long srd_decoder_apiver(const struct srd_decoder *d);
+
/* type_decoder.c */
SRD_PRIV PyObject *srd_Decoder_type_new(void);