X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=libsigrokdecode-internal.h;h=e9aef649b93697e430cc3586c2298b9c613e3c7c;hp=aa626cae12744dde2e2987c86d9ac8945086c2dc;hb=1483fb220ce56405433aee298d1637f6b041ac2b;hpb=e195c025c303e361d0cc5a207f9c9443fb8deced diff --git a/libsigrokdecode-internal.h b/libsigrokdecode-internal.h index aa626ca..e9aef64 100644 --- a/libsigrokdecode-internal.h +++ b/libsigrokdecode-internal.h @@ -22,8 +22,21 @@ #ifndef LIBSIGROKDECODE_LIBSIGROKDECODE_INTERNAL_H #define LIBSIGROKDECODE_LIBSIGROKDECODE_INTERNAL_H +#include /* First, so we avoid a _POSIX_C_SOURCE warning. */ #include "libsigrokdecode.h" +/* Custom Python types: */ + +typedef struct { + PyObject_HEAD + struct srd_decoder_inst *di; + uint64_t start_samplenum; + unsigned int itercnt; + uint8_t *inbuf; + uint64_t inbuflen; + PyObject *sample; +} srd_logic; + struct srd_session { int session_id; @@ -34,10 +47,8 @@ struct srd_session { GSList *callbacks; }; - /* srd.c */ SRD_PRIV int srd_decoder_searchpath_add(const char *path); -SRD_PRIV gboolean srd_check_init(void); /* session.c */ SRD_PRIV int session_is_valid(struct srd_session *sess); @@ -62,13 +73,16 @@ SRD_PRIV int srd_info(const char *format, ...); SRD_PRIV int srd_warn(const char *format, ...); SRD_PRIV int srd_err(const char *format, ...); +/* module_sigrokdecode.c */ +PyMODINIT_FUNC PyInit_sigrokdecode(void); + /* util.c */ SRD_PRIV int py_attr_as_str(const PyObject *py_obj, const char *attr, char **outstr); SRD_PRIV int py_dictitem_as_str(const PyObject *py_obj, const char *key, char **outstr); SRD_PRIV int py_str_as_str(const PyObject *py_str, char **outstr); -SRD_PRIV int py_strlist_to_char(const PyObject *py_strlist, char ***outstr); +SRD_PRIV int py_strseq_to_char(const PyObject *py_strseq, char ***outstr); /* exception.c */ SRD_PRIV void srd_exception_catch(const char *format, ...);