|
|
@@ -16,11 +16,11 @@
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
+#include "c99defs.h"
|
|
|
+
|
|
|
/*
|
|
|
* General programmable serialization functions. (A shared interface to
|
|
|
* various reading/writing to/from different inputs/outputs)
|
|
|
- *
|
|
|
- * TODO: Not currently implemented
|
|
|
*/
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
@@ -34,16 +34,37 @@ enum serialize_seek_type {
|
|
|
};
|
|
|
|
|
|
struct serializer {
|
|
|
- void *param;
|
|
|
- size_t (*serialize)(struct serializer, void *, size_t);
|
|
|
- uint64_t (*seek)(struct serializer, int64_t, enum serialize_seek_type);
|
|
|
- uint64_t (*getpos)(struct serializer);
|
|
|
+ void *data;
|
|
|
+
|
|
|
+ size_t (*read)(void *, void *, size_t);
|
|
|
+ size_t (*write)(void *, const void *, size_t);
|
|
|
+ uint64_t (*seek)(void *, int64_t, enum serialize_seek_type);
|
|
|
+ uint64_t (*get_pos)(void *);
|
|
|
};
|
|
|
|
|
|
+static inline size_t s_read(struct serializer *s, void *data, size_t size)
|
|
|
+{
|
|
|
+ if (s && s->read && data && size)
|
|
|
+ return s->read(s->data, (void*)data, size);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+static inline size_t s_write(struct serializer *s, const void *data,
|
|
|
+ size_t size)
|
|
|
+{
|
|
|
+ if (s && s->write && data && size)
|
|
|
+ return s->write(s->data, (void*)data, size);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
static inline size_t serialize(struct serializer *s, void *data, size_t len)
|
|
|
{
|
|
|
- if (s->serialize)
|
|
|
- return s->serialize(s, data, len);
|
|
|
+ if (s) {
|
|
|
+ if (s->write)
|
|
|
+ return s->write(s, data, len);
|
|
|
+ else if (s->read)
|
|
|
+ return s->read(s, data, len);
|
|
|
+ }
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
|
@@ -51,66 +72,91 @@ static inline size_t serialize(struct serializer *s, void *data, size_t len)
|
|
|
static inline uint64_t serializer_seek(struct serializer *s, int64_t offset,
|
|
|
enum serialize_seek_type seek_type)
|
|
|
{
|
|
|
- if (s->seek)
|
|
|
+ if (s && s->seek)
|
|
|
return s->seek(s, offset, seek_type);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static inline uint64_t serializer_getpos(struct serializer *s)
|
|
|
+static inline uint64_t serializer_get_pos(struct serializer *s)
|
|
|
{
|
|
|
- if (s->getpos)
|
|
|
- return s->getpos(s);
|
|
|
+ if (s && s->get_pos)
|
|
|
+ return s->get_pos(s);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_u8(struct serializer *s, uint8_t u8)
|
|
|
+/* formatted this to be similar to the AVIO layout that ffmpeg uses */
|
|
|
+
|
|
|
+static inline void s_w8(struct serializer *s, uint8_t u8)
|
|
|
+{
|
|
|
+ s_write(s, &u8, sizeof(uint8_t));
|
|
|
+}
|
|
|
+
|
|
|
+static inline void s_wl16(struct serializer *s, uint16_t u16)
|
|
|
+{
|
|
|
+ s_w8(s, (uint8_t)u16);
|
|
|
+ s_w8(s, u16 >> 8);
|
|
|
+}
|
|
|
+
|
|
|
+static inline void s_wl24(struct serializer *s, uint32_t u24)
|
|
|
+{
|
|
|
+ s_w8 (s, (uint8_t)u24);
|
|
|
+ s_wl16(s, (uint16_t)(u24 >> 8));
|
|
|
+}
|
|
|
+
|
|
|
+static inline void s_wl32(struct serializer *s, uint32_t u32)
|
|
|
{
|
|
|
- serialize(s, &u8, sizeof(uint8_t));
|
|
|
+ s_wl16(s, (uint16_t)u32);
|
|
|
+ s_wl16(s, (uint16_t)(u32 >> 16));
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_i8(struct serializer *s, int8_t i8)
|
|
|
+static inline void s_wl64(struct serializer *s, uint64_t u64)
|
|
|
{
|
|
|
- serialize(s, &i8, sizeof(int8_t));
|
|
|
+ s_wl32(s, (uint32_t)u64);
|
|
|
+ s_wl32(s, (uint32_t)(u64 >> 32));
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_u16(struct serializer *s, uint16_t u16)
|
|
|
+static inline void s_wlf(struct serializer *s, float f)
|
|
|
{
|
|
|
- serialize(s, &u16, sizeof(uint16_t));
|
|
|
+ s_wl32(s, *(uint32_t*)&f);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_i16(struct serializer *s, int16_t i16)
|
|
|
+static inline void s_wld(struct serializer *s, double d)
|
|
|
{
|
|
|
- serialize(s, &i16, sizeof(int16_t));
|
|
|
+ s_wl64(s, *(uint64_t*)&d);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_u32(struct serializer *s, uint32_t u32)
|
|
|
+static inline void s_wb16(struct serializer *s, uint16_t u16)
|
|
|
{
|
|
|
- serialize(s, &u32, sizeof(uint32_t));
|
|
|
+ s_w8(s, u16 >> 8);
|
|
|
+ s_w8(s, (uint8_t)u16);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_i32(struct serializer *s, int32_t i32)
|
|
|
+static inline void s_wb24(struct serializer *s, uint32_t u24)
|
|
|
{
|
|
|
- serialize(s, &i32, sizeof(int32_t));
|
|
|
+ s_wb16(s, (uint16_t)(u24 >> 8));
|
|
|
+ s_w8 (s, (uint8_t)u24);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_u64(struct serializer *s, uint32_t u64)
|
|
|
+static inline void s_wb32(struct serializer *s, uint32_t u32)
|
|
|
{
|
|
|
- serialize(s, &u64, sizeof(uint64_t));
|
|
|
+ s_wb16(s, (uint16_t)(u32 >> 16));
|
|
|
+ s_wb16(s, (uint16_t)u32);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_i64(struct serializer *s, int32_t i64)
|
|
|
+static inline void s_wb64(struct serializer *s, uint64_t u64)
|
|
|
{
|
|
|
- serialize(s, &i64, sizeof(int64_t));
|
|
|
+ s_wb32(s, (uint32_t)(u64 >> 32));
|
|
|
+ s_wb32(s, (uint32_t)u64);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_float(struct serializer *s, float f)
|
|
|
+static inline void s_wbf(struct serializer *s, float f)
|
|
|
{
|
|
|
- serialize(s, &f, sizeof(float));
|
|
|
+ s_wb32(s, *(uint32_t*)&f);
|
|
|
}
|
|
|
|
|
|
-static inline void serializer_write_double(struct serializer *s, double d)
|
|
|
+static inline void s_wbd(struct serializer *s, double d)
|
|
|
{
|
|
|
- serialize(s, &d, sizeof(double));
|
|
|
+ s_wb64(s, *(uint64_t*)&d);
|
|
|
}
|
|
|
|
|
|
#ifdef __cplusplus
|