X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=libsigrokdecode-internal.h;h=bcf6bb75b243a027a727db752a3af97f8240f392;hp=aa626cae12744dde2e2987c86d9ac8945086c2dc;hb=fd4918101e0878be9d399a344511253f5867a646;hpb=e195c025c303e361d0cc5a207f9c9443fb8deced diff --git a/libsigrokdecode-internal.h b/libsigrokdecode-internal.h index aa626ca..bcf6bb7 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); @@ -50,17 +61,30 @@ SRD_PRIV struct srd_decoder_inst *srd_inst_find_by_obj( const GSList *stack, SRD_PRIV int srd_inst_start(struct srd_decoder_inst *di); SRD_PRIV int srd_inst_decode(const struct srd_decoder_inst *di, uint64_t start_samplenum, uint64_t end_samplenum, - const uint8_t *inbuf, uint64_t inbuflen); + const uint8_t *inbuf, uint64_t inbuflen, uint64_t unitsize); SRD_PRIV void srd_inst_free(struct srd_decoder_inst *di); SRD_PRIV void srd_inst_free_all(struct srd_session *sess, GSList *stack); /* log.c */ -SRD_PRIV int srd_log(int loglevel, const char *format, ...); -SRD_PRIV int srd_spew(const char *format, ...); -SRD_PRIV int srd_dbg(const char *format, ...); -SRD_PRIV int srd_info(const char *format, ...); -SRD_PRIV int srd_warn(const char *format, ...); -SRD_PRIV int srd_err(const char *format, ...); +#if defined(G_OS_WIN32) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4)) +/* + * On MinGW, we need to specify the gnu_printf format flavor or GCC + * will assume non-standard Microsoft printf syntax. + */ +SRD_PRIV int srd_log(int loglevel, const char *format, ...) + __attribute__((__format__ (__gnu_printf__, 2, 3))); +#else +SRD_PRIV int srd_log(int loglevel, const char *format, ...) G_GNUC_PRINTF(2, 3); +#endif + +#define srd_spew(...) srd_log(SRD_LOG_SPEW, __VA_ARGS__) +#define srd_dbg(...) srd_log(SRD_LOG_DBG, __VA_ARGS__) +#define srd_info(...) srd_log(SRD_LOG_INFO, __VA_ARGS__) +#define srd_warn(...) srd_log(SRD_LOG_WARN, __VA_ARGS__) +#define srd_err(...) srd_log(SRD_LOG_ERR, __VA_ARGS__) + +/* module_sigrokdecode.c */ +PyMODINIT_FUNC PyInit_sigrokdecode(void); /* util.c */ SRD_PRIV int py_attr_as_str(const PyObject *py_obj, const char *attr, @@ -68,7 +92,7 @@ SRD_PRIV int py_attr_as_str(const PyObject *py_obj, const char *attr, 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, ...);