[utils] cstring_array_terminate, moving msgpack_utils to separate file

This commit is contained in:
Al
2015-07-25 18:39:57 -04:00
parent 42f6be7434
commit a67ec44a08
6 changed files with 142 additions and 83 deletions

99
src/msgpack_utils.c Normal file
View File

@@ -0,0 +1,99 @@
#include "msgpack_utils.h"
static char_array *read_string(char_array *str, size_t len, msgpack_buffer_t *buffer) {
char_array_clear(str);
char_array_cat_len(str, buffer->data->a + buffer->offset, len);
buffer->offset += len;
return str;
}
bool msgpack_bytes_reader(cmp_ctx_t *ctx, void *data, size_t size) {
msgpack_buffer_t *buffer = ctx->buf;
if (buffer->offset + size > char_array_len(buffer->data)) {
return false;
}
memcpy(data, buffer->data->a + buffer->offset, size);
buffer->offset += size;
return true;
}
size_t msgpack_bytes_writer(cmp_ctx_t *ctx, const void *data, size_t count) {
msgpack_buffer_t *buffer = (msgpack_buffer_t *)ctx->buf;
char_array_cat_len(buffer->data, (char *)data, count);
buffer->offset += count;
return count;
}
bool cmp_read_str_size_or_nil(cmp_ctx_t *ctx, char_array **str, uint32_t *size) {
cmp_object_t obj;
if (!cmp_read_object(ctx, &obj)) {
return false;
}
if (cmp_object_is_str(&obj)) {
*size = obj.as.str_size;
*str = read_string(*str, *size, ctx->buf);
} else if (cmp_object_is_nil(&obj)) {
*size = 0;
char_array_clear(*str);
}
return true;
}
bool cmp_write_str_or_nil(cmp_ctx_t *ctx, char_array *str) {
if (str != NULL && char_array_len(str) > 0) {
return cmp_write_str(ctx, str->a, char_array_len(str));
} else {
return cmp_write_nil(ctx);
}
}
bool cmp_write_uint_vector(cmp_ctx_t *ctx, uint32_array *array) {
size_t n = array->n;
if (!cmp_write_array(ctx, n)) {
return false;
}
for (size_t i = 0; i < n; i++) {
if (!cmp_write_uint(ctx, array->a[i])) {
return false;
}
}
return true;
}
bool cmp_read_uint_vector(cmp_ctx_t *ctx, uint32_array **array) {
cmp_object_t obj;
if (!cmp_read_object(ctx, &obj)) {
return false;
}
if (!cmp_object_is_array(&obj)) {
return false;
}
uint32_t size = 0;
if (!cmp_read_array(ctx, &size)) {
return false;
}
if (size == 0) {
*array = NULL;
return true;
}
uint32_array *tmp = uint32_array_new_size((size_t)size);
uint32_t value;
for (int i = 0; i < size; i++) {
if (!cmp_read_uint(ctx, &value)) {
uint32_array_destroy(tmp);
return false;
}
uint32_array_push(tmp, value);
}
*array = tmp;
return true;
}