summaryrefslogtreecommitdiff
path: root/sigrokdecode.h
diff options
context:
space:
mode:
authorBert Vermeulen <bert@biot.com>2011-12-04 10:33:02 +0100
committerBert Vermeulen <bert@biot.com>2011-12-04 17:56:56 +0100
commitb2c19614a6c4eaa0170971d1261a1bb25212e277 (patch)
treeb599e5e3795c0b094cd4514820db0c7e761653fd /sigrokdecode.h
parent2b7d0e2bf5147025e9d76d14e266b9905503b957 (diff)
downloadlibsigrokdecode-b2c19614a6c4eaa0170971d1261a1bb25212e277.tar.gz
libsigrokdecode-b2c19614a6c4eaa0170971d1261a1bb25212e277.zip
refactored PD framework, now using new sigrok.Decoder object
This uses the new python unified type/class object API to construct an object for PDs to subclass. The sigrok.Decoder class has a method put() which is implemented as a C function, and receives the PD's object instance as its first parameter.
Diffstat (limited to 'sigrokdecode.h')
-rw-r--r--sigrokdecode.h29
1 files changed, 23 insertions, 6 deletions
diff --git a/sigrokdecode.h b/sigrokdecode.h
index b856f4f..c1ef9ff 100644
--- a/sigrokdecode.h
+++ b/sigrokdecode.h
@@ -88,24 +88,41 @@ struct srd_decoder {
/** TODO */
GSList *outputformats;
+ /** TODO */
+ PyObject *py_mod;
+
/** Python object that performs the decoding */
PyObject *py_decobj;
};
struct srd_decoder_instance {
+ struct srd_decoder *decoder;
PyObject *py_instance;
+ GSList *pd_output;
};
int srd_init(void);
-GSList *srd_list_decoders(void);
-struct srd_decoder *srd_get_decoder_by_id(const char *id);
+int srd_exit(void);
+int set_modulepath(void);
struct srd_decoder_instance *srd_instance_new(const char *id);
int srd_instance_set_probe(struct srd_decoder_instance *di,
const char *probename, int num);
-int srd_session_start(const char *driver, int unitsize, uint64_t starttime,
- uint64_t samplerate);
-int srd_session_feed(uint8_t *inbuf, uint64_t inbuflen);
-int srd_exit(void);
+int srd_instance_start(struct srd_decoder_instance *di,
+ const char *driver, int unitsize, uint64_t starttime);
+int srd_run_decoder(struct srd_decoder_instance *dec,
+ uint8_t *inbuf, uint64_t inbuflen);
+
+/* decoder.c */
+GSList *srd_list_decoders(void);
+struct srd_decoder *srd_get_decoder_by_id(const char *id);
+int srd_load_decoder(const char *name, struct srd_decoder **dec);
+int srd_unload_decoder(struct srd_decoder *dec);
+int srd_load_all_decoders(void);
+int srd_unload_all_decoders(void);
+
+/* util.c */
+int h_str(PyObject *py_res, PyObject *py_mod, const char *key, char **outstr);
+
#ifdef __cplusplus
}