]> sigrok.org Git - libsigrokdecode.git/blame_incremental - libsigrokdecode-internal.h
type_decoder: update and extend Decoder base class doc strings
[libsigrokdecode.git] / libsigrokdecode-internal.h
... / ...
CommitLineData
1/*
2 * This file is part of the libsigrokdecode project.
3 *
4 * Copyright (C) 2011 Uwe Hermann <uwe@hermann-uwe.de>
5 * Copyright (C) 2012 Bert Vermeulen <bert@biot.com>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, see <http://www.gnu.org/licenses/>.
19 */
20
21#ifndef LIBSIGROKDECODE_LIBSIGROKDECODE_INTERNAL_H
22#define LIBSIGROKDECODE_LIBSIGROKDECODE_INTERNAL_H
23
24/* Use the stable ABI subset as per PEP 384. */
25#define Py_LIMITED_API 0x03020000
26
27#include <Python.h> /* First, so we avoid a _POSIX_C_SOURCE warning. */
28#include "libsigrokdecode.h"
29
30/*
31 * Static definition of tables ending with an all-zero sentinel entry
32 * may raise warnings when compiling with -Wmissing-field-initializers.
33 * GCC suppresses the warning only with { 0 }, clang wants { } instead.
34 */
35#ifdef __clang__
36# define ALL_ZERO { }
37#else
38# define ALL_ZERO { 0 }
39#endif
40
41enum {
42 SRD_TERM_ALWAYS_FALSE,
43 SRD_TERM_HIGH,
44 SRD_TERM_LOW,
45 SRD_TERM_RISING_EDGE,
46 SRD_TERM_FALLING_EDGE,
47 SRD_TERM_EITHER_EDGE,
48 SRD_TERM_NO_EDGE,
49 SRD_TERM_SKIP,
50};
51
52struct srd_term {
53 int type;
54 int channel;
55 uint64_t num_samples_to_skip;
56 uint64_t num_samples_already_skipped;
57};
58
59/* Custom Python types: */
60
61typedef struct {
62 PyObject_HEAD
63 struct srd_decoder_inst *di;
64 uint64_t abs_start_samplenum;
65 unsigned int itercnt;
66 uint8_t *inbuf;
67 uint64_t inbuflen;
68 PyObject *sample;
69} srd_logic;
70
71struct srd_session {
72 int session_id;
73
74 /* List of decoder instances. */
75 GSList *di_list;
76
77 /* List of frontend callbacks to receive decoder output. */
78 GSList *callbacks;
79};
80
81/* srd.c */
82SRD_PRIV int srd_decoder_searchpath_add(const char *path);
83
84/* session.c */
85SRD_PRIV struct srd_pd_callback *srd_pd_output_callback_find(struct srd_session *sess,
86 int output_type);
87
88/* instance.c */
89SRD_PRIV int srd_inst_start(struct srd_decoder_inst *di);
90SRD_PRIV void match_array_free(struct srd_decoder_inst *di);
91SRD_PRIV void condition_list_free(struct srd_decoder_inst *di);
92SRD_PRIV int srd_inst_decode(struct srd_decoder_inst *di,
93 uint64_t abs_start_samplenum, uint64_t abs_end_samplenum,
94 const uint8_t *inbuf, uint64_t inbuflen, uint64_t unitsize);
95SRD_PRIV int process_samples_until_condition_match(struct srd_decoder_inst *di, gboolean *found_match);
96SRD_PRIV int srd_inst_flush(struct srd_decoder_inst *di);
97SRD_PRIV int srd_inst_terminate_reset(struct srd_decoder_inst *di);
98SRD_PRIV void srd_inst_free(struct srd_decoder_inst *di);
99SRD_PRIV void srd_inst_free_all(struct srd_session *sess);
100
101/* log.c */
102#if defined(G_OS_WIN32) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4))
103/*
104 * On MinGW, we need to specify the gnu_printf format flavor or GCC
105 * will assume non-standard Microsoft printf syntax.
106 */
107SRD_PRIV int srd_log(int loglevel, const char *format, ...)
108 __attribute__((__format__ (__gnu_printf__, 2, 3)));
109#else
110SRD_PRIV int srd_log(int loglevel, const char *format, ...) G_GNUC_PRINTF(2, 3);
111#endif
112
113#define srd_spew(...) srd_log(SRD_LOG_SPEW, __VA_ARGS__)
114#define srd_dbg(...) srd_log(SRD_LOG_DBG, __VA_ARGS__)
115#define srd_info(...) srd_log(SRD_LOG_INFO, __VA_ARGS__)
116#define srd_warn(...) srd_log(SRD_LOG_WARN, __VA_ARGS__)
117#define srd_err(...) srd_log(SRD_LOG_ERR, __VA_ARGS__)
118
119/* decoder.c */
120SRD_PRIV long srd_decoder_apiver(const struct srd_decoder *d);
121
122/* type_decoder.c */
123SRD_PRIV PyObject *srd_Decoder_type_new(void);
124SRD_PRIV const char *output_type_name(unsigned int idx);
125
126/* type_logic.c */
127SRD_PRIV PyObject *srd_logic_type_new(void);
128
129/* module_sigrokdecode.c */
130PyMODINIT_FUNC PyInit_sigrokdecode(void);
131
132/* util.c */
133SRD_PRIV PyObject *py_import_by_name(const char *name);
134SRD_PRIV int py_attr_as_str(PyObject *py_obj, const char *attr, char **outstr);
135SRD_PRIV int py_attr_as_strlist(PyObject *py_obj, const char *attr, GSList **outstrlist);
136SRD_PRIV int py_dictitem_as_str(PyObject *py_obj, const char *key, char **outstr);
137SRD_PRIV int py_listitem_as_str(PyObject *py_obj, Py_ssize_t idx, char **outstr);
138SRD_PRIV int py_pydictitem_as_str(PyObject *py_obj, PyObject *py_key, char **outstr);
139SRD_PRIV int py_pydictitem_as_long(PyObject *py_obj, PyObject *py_key, int64_t *out);
140SRD_PRIV int py_str_as_str(PyObject *py_str, char **outstr);
141SRD_PRIV int py_strseq_to_char(PyObject *py_strseq, char ***out_strv);
142SRD_PRIV GVariant *py_obj_to_variant(PyObject *py_obj);
143
144/* exception.c */
145#if defined(G_OS_WIN32) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4))
146/*
147 * On MinGW, we need to specify the gnu_printf format flavor or GCC
148 * will assume non-standard Microsoft printf syntax.
149 */
150SRD_PRIV void srd_exception_catch(const char *format, ...)
151 __attribute__((__format__ (__gnu_printf__, 1, 2)));
152#else
153SRD_PRIV void srd_exception_catch(const char *format, ...) G_GNUC_PRINTF(1, 2);
154#endif
155
156#endif