2021-05-03 22:44:39 +00:00
|
|
|
#pragma once
|
2021-05-03 23:38:47 +00:00
|
|
|
#include "zpl.h"
|
2021-05-03 22:44:39 +00:00
|
|
|
#include "packet.h"
|
|
|
|
#include "cwpack/cwpack.h"
|
|
|
|
|
|
|
|
inline void pkt_pack_msg(cw_pack_context *pc, uint32_t args) {
|
|
|
|
cw_pack_context_init(pc, pkt_buffer, PKT_BUFSIZ, 0);
|
|
|
|
cw_pack_array_size(pc, args);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int32_t pkt_unpack_msg(cw_unpack_context *uc, pkt_header *header, uint32_t args) {
|
|
|
|
cw_unpack_context_init(uc, header->data, header->datalen, 0);
|
|
|
|
|
|
|
|
cw_unpack_next(uc);
|
|
|
|
if (uc->item.type != CWP_ITEM_ARRAY || uc->item.as.array.size != args) {
|
|
|
|
return -1;//todo: error
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int32_t pkt_unpack_msg_raw(cw_unpack_context *uc, uint8_t *data, uint32_t datalen, uint32_t args) {
|
|
|
|
pkt_header header = {.data = data, .datalen = datalen};
|
|
|
|
return pkt_unpack_msg(uc, &header, args);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int32_t pkt_validate_eof_msg(cw_unpack_context *uc) {
|
|
|
|
if (uc->return_code != CWP_RC_OK) return -1; // unpacking failed somwwhere
|
|
|
|
cw_unpack_next(uc);
|
|
|
|
if (uc->return_code != CWP_RC_END_OF_INPUT) return -1; // not finished yet but should be?
|
|
|
|
return 0;
|
|
|
|
}
|
2021-05-03 23:38:47 +00:00
|
|
|
|
2021-05-04 08:08:00 +00:00
|
|
|
inline size_t pkt_pack_msg_size(cw_pack_context *pc) {
|
|
|
|
return pc->current - pc->start; // NOTE(zaklaus): length
|
|
|
|
}
|
|
|
|
|
2021-05-03 23:38:47 +00:00
|
|
|
#ifndef PKT_OFFSETOF
|
|
|
|
#if defined(_MSC_VER) || defined(ZPL_COMPILER_TINYC)
|
|
|
|
# define PKT_OFFSETOF(Type, element) ((size_t) & (((Type *)0)->element))
|
|
|
|
#else
|
|
|
|
# define PKT_OFFSETOF(Type, element) __builtin_offsetof(Type, element)
|
|
|
|
#endif
|
|
|
|
# define PKT_FIELD_SIZEOF(type, member) sizeof(((type *)0)->member)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef PKT_STRUCT_PTR
|
2021-05-03 23:57:19 +00:00
|
|
|
#define PKT_STRUCT_PTR(a) (void*)(a), (uint32_t)sizeof(*(a))
|
2021-05-03 23:38:47 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef PKT_FIELD
|
2021-05-04 11:04:15 +00:00
|
|
|
#define PKT_FIELD(k, t, a) .type = k, .offset = PKT_OFFSETOF(t, a), .size = PKT_FIELD_SIZEOF(t,a), .it_size = PKT_FIELD_SIZEOF(t,a)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef PKT_ARRAY
|
|
|
|
#define PKT_ARRAY(t, a) .type = CWP_ITEM_BIN, .offset = PKT_OFFSETOF(t, a), .size = PKT_FIELD_SIZEOF(t,a), .it_size = PKT_FIELD_SIZEOF(t,a[0])
|
2021-05-03 23:38:47 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef PKT_END
|
|
|
|
#define PKT_END .type = CWP_NOT_AN_ITEM
|
|
|
|
#endif
|
|
|
|
|
2021-05-03 23:57:19 +00:00
|
|
|
#ifndef PKT_IF
|
|
|
|
#define PKT_IF(c) if (c < 0) return -1;
|
|
|
|
#endif
|
|
|
|
|
2021-05-03 23:38:47 +00:00
|
|
|
typedef struct pkt_desc {
|
|
|
|
cwpack_item_types type;
|
|
|
|
size_t offset;
|
|
|
|
size_t size;
|
2021-05-04 11:04:15 +00:00
|
|
|
size_t it_size;
|
2021-05-03 23:38:47 +00:00
|
|
|
} pkt_desc;
|
|
|
|
|
|
|
|
int32_t pkt_unpack_struct(cw_unpack_context *uc, pkt_desc *desc, void *raw_blob, uint32_t blob_size);
|
2021-05-04 08:08:00 +00:00
|
|
|
|
|
|
|
inline int32_t pkt_msg_decode(pkt_header *header, pkt_desc* desc, uint32_t args, void *raw_blob, uint32_t blob_size) {
|
|
|
|
cw_unpack_context uc = {0};
|
2021-05-04 11:04:15 +00:00
|
|
|
PKT_IF(pkt_unpack_msg(&uc, header, args));
|
|
|
|
PKT_IF(pkt_unpack_struct(&uc, desc, raw_blob, blob_size));
|
2021-05-04 08:08:00 +00:00
|
|
|
|
|
|
|
return pkt_validate_eof_msg(&uc);
|
|
|
|
}
|