X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=libsigrokdecode-internal.h;h=e9aef649b93697e430cc3586c2298b9c613e3c7c;hp=898ba045ac741bdfd381c9325438ab167ebcf601;hb=1483fb220ce56405433aee298d1637f6b041ac2b;hpb=62a2b15ce3fe6af6867c30cfc9c14c01d201a898 diff --git a/libsigrokdecode-internal.h b/libsigrokdecode-internal.h index 898ba04..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,6 +73,9 @@ 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);