diff options
author | Bert Vermeulen <bert@biot.com> | 2011-12-04 10:33:02 +0100 |
---|---|---|
committer | Bert Vermeulen <bert@biot.com> | 2011-12-04 17:56:56 +0100 |
commit | b2c19614a6c4eaa0170971d1261a1bb25212e277 (patch) | |
tree | b599e5e3795c0b094cd4514820db0c7e761653fd /sigrokdecode.h | |
parent | 2b7d0e2bf5147025e9d76d14e266b9905503b957 (diff) | |
download | libsigrokdecode-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.h | 29 |
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 } |