diff options
author | Suren A. Chilingaryan <csa@suren.me> | 2020-09-03 03:00:30 +0200 |
---|---|---|
committer | Suren A. Chilingaryan <csa@suren.me> | 2020-09-03 03:00:30 +0200 |
commit | 5172421d248250b4ab3b69eb57fd83656e23a4da (patch) | |
tree | a499d9f1dd0b74b754816884a59927b3171656fc /src/roof-read.h | |
parent | 7b2e6168b049be9e7852b2d364d897592eff69fc (diff) | |
download | ufo-roof-temp-5172421d248250b4ab3b69eb57fd83656e23a4da.tar.gz ufo-roof-temp-5172421d248250b4ab3b69eb57fd83656e23a4da.tar.bz2 ufo-roof-temp-5172421d248250b4ab3b69eb57fd83656e23a4da.tar.xz ufo-roof-temp-5172421d248250b4ab3b69eb57fd83656e23a4da.zip |
Diffstat (limited to 'src/roof-read.h')
-rw-r--r-- | src/roof-read.h | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/roof-read.h b/src/roof-read.h new file mode 100644 index 0000000..1ab846a --- /dev/null +++ b/src/roof-read.h @@ -0,0 +1,45 @@ +#ifndef __ROOF_READ_H +#define __ROOF_READ_H + +typedef struct _RoofRead RoofRead; + +#include "roof-config.h" + +G_BEGIN_DECLS + +typedef struct _RoofReadContext RoofReadContext; +typedef struct _RoofReadInterface RoofReadInterface; +typedef struct _RoofReadInterfaceSettings RoofReadInterfaceSettings; + +typedef guint (*RoofReaderRead)(RoofReadInterface *reader, uint8_t **buf, GError **error); +typedef void (*RoofReaderClose)(RoofReadInterface *reader); + +struct _RoofReadInterfaceSettings { + guint padding; // Packet size + padding +}; + +struct _RoofReadInterface { + RoofReaderRead read; + RoofReaderClose close; + + RoofReadInterfaceSettings settings; +}; + +struct _RoofReadContext { + RoofConfig *cfg; + RoofReadInterface *rdi; + + void *rdbuf; // The buffer we are currently processing + guint n_packets; // Number of packets in the buffer + guint packet_id; // Last processed packet in the buffer + guint fragment_id; // Last processed fragment in the packet +}; + +RoofReadContext *roof_read_context_new(RoofConfig *cfg, RoofReadInterface *rdi, GError **error); +void roof_read_context_free(RoofReadContext *ctx); +const RoofReadInterfaceSettings *roof_read_get_settings(UFORoofRead *ctx, GError **error); + + +G_END_DECLS + +#endif /* __ROOF_READ_H */ |