#include <string.h>
#include "serial.h"
-int serial_init(serializer_t *srl, void *buffer, int size)
+void serial_init(serializer_t *srl, void *buffer, int size)
{
srl->buffer = srl->cursor = buffer;
srl->bufsize = size;
- return 0;
}
-int serial_switch(serializer_t *srl, void *buffer, int size)
+void serial_switch(serializer_t *srl, void *buffer, int size)
{
int used = srl->cursor - srl->buffer;
srl->buffer = buffer;
srl->bufsize = size;
srl->cursor = buffer + used;
- return 0;
}
+/* returns 'size' on success, or remainging space if it was insufficient */
int serial_put(serializer_t *srl, const void *item, int size)
{
int left = srl->bufsize - (srl->cursor - srl->buffer);
+
if (left < size + sizeof(short)) return left - sizeof(short);
*((short *)srl->cursor) = size;
- srl->cursor += 2;
+ srl->cursor += sizeof(short);
if (size) memcpy(srl->cursor, item, size);
srl->cursor += size;
return size;
}
-int serial_get(serializer_t *srl, void *item, int bufsize)
+/* return 0 on success, -1 on wrong encoding (item longer than space left) */
+int serial_get(serializer_t *srl, void **item, int *size)
{
+ int left = srl->bufsize - (srl->cursor - srl->buffer);
short isize = *((short *)srl->cursor);
- if (isize > bufsize || isize == 0) return isize;
+
+ if (isize + sizeof(short) > left) return -1;
srl->cursor += sizeof(short);
- memcpy(item, srl->cursor, isize);
+ *item = srl->cursor;
+ *size = isize;
srl->cursor += isize;
- return isize;
+ return 0;
}
int serial_size(serializer_t *srl)