X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=libsigrokdecode.h;h=03a5de096b18ebd7d2c4cf3fbf9ba103a3894ffe;hp=db06d43dcdccc1ade489ee19473c6a49ea046f04;hb=04867deb37b0f8cdfad55ab7bdb8708fd13f53fc;hpb=2372b1998ae5d252433d7a7a07744ba2ea81b96e diff --git a/libsigrokdecode.h b/libsigrokdecode.h index db06d43..03a5de0 100644 --- a/libsigrokdecode.h +++ b/libsigrokdecode.h @@ -19,10 +19,9 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef LIBSIGROKDECODE_SIGROKDECODE_H -#define LIBSIGROKDECODE_SIGROKDECODE_H +#ifndef LIBSIGROKDECODE_LIBSIGROKDECODE_H +#define LIBSIGROKDECODE_LIBSIGROKDECODE_H -#include /* First, so we avoid a _POSIX_C_SOURCE warning. */ #include #include @@ -65,7 +64,7 @@ struct srd_session; */ /** Status/error codes returned by libsigrokdecode functions. */ -enum { +enum srd_error_code { SRD_OK = 0, /**< No error */ SRD_ERR = -1, /**< Generic/unspecified error */ SRD_ERR_MALLOC = -2, /**< Malloc/calloc/realloc error */ @@ -81,7 +80,7 @@ enum { }; /* libsigrokdecode loglevels. */ -enum { +enum srd_loglevel { SRD_LOG_NONE = 0, /**< Output no messages at all. */ SRD_LOG_ERR = 1, /**< Output error messages. */ SRD_LOG_WARN = 2, /**< Output warnings. */ @@ -126,14 +125,14 @@ enum { * - add a check in module_sigrokdecode.c:Decoder_put() * - add a debug string in type_decoder.c:OUTPUT_TYPES */ -enum { +enum srd_output_type { SRD_OUTPUT_ANN, SRD_OUTPUT_PYTHON, SRD_OUTPUT_BINARY, SRD_OUTPUT_META, }; -enum { +enum srd_configkey { SRD_CONF_SAMPLERATE = 10000, }; @@ -180,14 +179,14 @@ struct srd_decoder { */ GSList *binary; - /** List of decoder options. */ + /** List of decoder options. */ GSList *options; /** Python module. */ - PyObject *py_mod; + void *py_mod; /** sigrokdecode.Decoder class. */ - PyObject *py_dec; + void *py_dec; }; /** @@ -209,7 +208,7 @@ struct srd_decoder_option { char *id; char *desc; GVariant *def; - GSList *values; + GSList *values; }; struct srd_decoder_annotation_row { @@ -221,7 +220,7 @@ struct srd_decoder_annotation_row { struct srd_decoder_inst { struct srd_decoder *decoder; struct srd_session *sess; - PyObject *py_inst; + void *py_inst; char *inst_id; GSList *pd_output; int dec_num_channels; @@ -249,7 +248,7 @@ struct srd_proto_data { void *data; }; struct srd_proto_data_annotation { - int ann_format; + int ann_class; char **ann_text; }; struct srd_proto_data_binary { @@ -267,23 +266,6 @@ struct srd_pd_callback { void *cb_data; }; -/* Custom Python types: */ - -typedef struct { - PyObject_HEAD -} srd_Decoder; - -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; - - /* srd.c */ SRD_API int srd_init(const char *path); SRD_API int srd_exit(void); @@ -295,7 +277,7 @@ SRD_API int srd_session_metadata_set(struct srd_session *sess, int key, GVariant *data); SRD_API int srd_session_send(struct srd_session *sess, 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_API int srd_session_destroy(struct srd_session *sess); SRD_API int srd_pd_output_callback_add(struct srd_session *sess, int output_type, srd_pd_output_callback cb, void *cb_data); @@ -313,7 +295,7 @@ SRD_API int srd_decoder_unload_all(void); SRD_API int srd_inst_option_set(struct srd_decoder_inst *di, GHashTable *options); SRD_API int srd_inst_channel_set_all(struct srd_decoder_inst *di, - GHashTable *channels, int unit_size); + GHashTable *channels); SRD_API struct srd_decoder_inst *srd_inst_new(struct srd_session *sess, const char *id, GHashTable *options); SRD_API int srd_inst_stack(struct srd_session *sess, @@ -328,8 +310,6 @@ SRD_API int srd_log_loglevel_set(int loglevel); SRD_API int srd_log_loglevel_get(void); SRD_API int srd_log_callback_set(srd_log_callback cb, void *cb_data); SRD_API int srd_log_callback_set_default(void); -SRD_API int srd_log_logdomain_set(const char *logdomain); -SRD_API char *srd_log_logdomain_get(void); /* error.c */ SRD_API const char *srd_strerror(int error_code);