diff options
-rw-r--r-- | src/libmdsserver/fd-table.c | 8 | ||||
-rw-r--r-- | src/libmdsserver/fd-table.h | 3 | ||||
-rw-r--r-- | src/libmdsserver/hash-table.c | 8 | ||||
-rw-r--r-- | src/libmdsserver/hash-table.h | 3 | ||||
-rw-r--r-- | src/libmdsserver/linked-list.c | 8 | ||||
-rw-r--r-- | src/libmdsserver/linked-list.h | 2 | ||||
-rw-r--r-- | src/libmdsserver/mds-message.c | 8 | ||||
-rw-r--r-- | src/libmdsserver/mds-message.h | 2 |
8 files changed, 38 insertions, 4 deletions
diff --git a/src/libmdsserver/fd-table.c b/src/libmdsserver/fd-table.c index 78876ce..6514289 100644 --- a/src/libmdsserver/fd-table.c +++ b/src/libmdsserver/fd-table.c @@ -253,7 +253,7 @@ void fd_table_clear(fd_table_t* restrict this) size_t fd_table_marshal_size(const fd_table_t* restrict this) { size_t bitcap = (this->capacity + 63) / 64; - return (this->capacity + 2) * sizeof(size_t) + bitcap * sizeof(uint64_t); + return (this->capacity + 2) * sizeof(size_t) + bitcap * sizeof(uint64_t) + sizeof(int); } @@ -267,6 +267,9 @@ void fd_table_marshal(const fd_table_t* restrict this, char* restrict data) { size_t bitcap = (this->capacity + 63) / 64; + ((int*)data)[0] = FD_TABLE_T_VERSION; + data += sizeof(int) / sizeof(char); + ((size_t*)data)[0] = this->capacity; ((size_t*)data)[1] = this->size; data += 2 * sizeof(size_t) / sizeof(char); @@ -291,6 +294,9 @@ int fd_table_unmarshal(fd_table_t* restrict this, char* restrict data, remap_fun { size_t bitcap; + /* ((int*)data)[0] == FD_TABLE_T_VERSION */ + data += sizeof(int) / sizeof(char); + this->capacity = ((size_t*)data)[0]; this->size = ((size_t*)data)[1]; data += 2 * sizeof(size_t) / sizeof(char); diff --git a/src/libmdsserver/fd-table.h b/src/libmdsserver/fd-table.h index 5fe9d98..289a401 100644 --- a/src/libmdsserver/fd-table.h +++ b/src/libmdsserver/fd-table.h @@ -24,6 +24,9 @@ #include <stdint.h> + +#define FD_TABLE_T_VERSION 0 + /** * Value lookup table optimised for file descriptors as keys */ diff --git a/src/libmdsserver/hash-table.c b/src/libmdsserver/hash-table.c index 78d5d49..2dbf8ad 100644 --- a/src/libmdsserver/hash-table.c +++ b/src/libmdsserver/hash-table.c @@ -388,7 +388,7 @@ size_t hash_table_marshal_size(const hash_table_t* restrict this) } } - return rc + m * 3 * sizeof(size_t); + return rc + m * 3 * sizeof(size_t) + sizeof(int); } @@ -402,6 +402,9 @@ void hash_table_marshal(const hash_table_t* restrict this, char* restrict data) { size_t i, n = this->capacity; + ((int*)data)[0] = HASH_TABLE_T_VERSION; + data += sizeof(int) / sizeof(char); + ((size_t*)data)[0] = this->capacity; data += 1 * sizeof(size_t) / sizeof(char); ((float*)data)[0] = this->load_factor; @@ -441,6 +444,9 @@ int hash_table_unmarshal(hash_table_t* restrict this, char* restrict data, remap { size_t i, n; + /* ((int*)data)[0] == HASH_TABLE_T_VERSION */ + data += sizeof(int) / sizeof(char); + this->value_comparator = NULL; this->key_comparator = NULL; this->hasher = NULL; diff --git a/src/libmdsserver/hash-table.h b/src/libmdsserver/hash-table.h index 33c0aed..9a84db2 100644 --- a/src/libmdsserver/hash-table.h +++ b/src/libmdsserver/hash-table.h @@ -22,6 +22,9 @@ #include "table-common.h" + +#define HASH_TABLE_T_VERSION 0 + /** * Hash table entry */ diff --git a/src/libmdsserver/linked-list.c b/src/libmdsserver/linked-list.c index 916eaf9..601bda0 100644 --- a/src/libmdsserver/linked-list.c +++ b/src/libmdsserver/linked-list.c @@ -430,7 +430,7 @@ void linked_list_remove(linked_list_t* restrict this, ssize_t node) */ size_t linked_list_marshal_size(const linked_list_t* restrict this) { - return sizeof(size_t) * (4 + this->reuse_head + 3 * this->end); + return sizeof(size_t) * (4 + this->reuse_head + 3 * this->end) + sizeof(int); } @@ -442,6 +442,9 @@ size_t linked_list_marshal_size(const linked_list_t* restrict this) */ void linked_list_marshal(const linked_list_t* restrict this, char* restrict data) { + ((int*)data)[0] = LINKED_LIST_T_VERSION; + data += sizeof(int) / sizeof(char); + ((size_t*)data)[0] = this->capacity; ((size_t*)data)[1] = this->end; ((size_t*)data)[2] = this->reuse_head; @@ -473,6 +476,9 @@ int linked_list_unmarshal(linked_list_t* restrict this, char* restrict data) { size_t n; + /* ((int*)data)[0] == LINKED_LIST_T_VERSION */ + data += sizeof(int) / sizeof(char); + this->reusable = NULL; this->values = NULL; this->next = NULL; diff --git a/src/libmdsserver/linked-list.h b/src/libmdsserver/linked-list.h index aa8a09b..69298ca 100644 --- a/src/libmdsserver/linked-list.h +++ b/src/libmdsserver/linked-list.h @@ -53,6 +53,8 @@ +#define LINKED_LIST_T_VERSION 0 + /** * Linear array sentinel doubly linked list class */ diff --git a/src/libmdsserver/mds-message.c b/src/libmdsserver/mds-message.c index a999c2a..99554cb 100644 --- a/src/libmdsserver/mds-message.c +++ b/src/libmdsserver/mds-message.c @@ -307,7 +307,7 @@ size_t mds_message_marshal_size(mds_message_t* this, int include_buffer) rc += strlen(this->headers[i]); rc *= sizeof(char); rc += (include_buffer ? 4 : 2) * sizeof(size_t); - rc += (include_buffer ? 1 : 0) * sizeof(int); + rc += (include_buffer ? 2 : 1) * sizeof(int); return rc; } @@ -325,6 +325,9 @@ void mds_message_marshal(mds_message_t* this, char* data, int include_buffer) { size_t i, n; + ((int*)data)[0] = MDS_MESSAGE_T_VERSION; + data += sizeof(int) / sizeof(char); + ((size_t*)data)[0] = this->header_count; ((size_t*)data)[1] = this->payload_size; if (include_buffer) @@ -369,6 +372,9 @@ int mds_message_unmarshal(mds_message_t* this, char* data) { size_t i, n, header_count; + /* ((int*)data)[0] == MDS_MESSAGE_T_VERSION */ + data += sizeof(int) / sizeof(char); + header_count = ((size_t*)data)[0]; this->header_count = 0; this->payload_size = ((size_t*)data)[1]; diff --git a/src/libmdsserver/mds-message.h b/src/libmdsserver/mds-message.h index f1cd3b1..1bc7816 100644 --- a/src/libmdsserver/mds-message.h +++ b/src/libmdsserver/mds-message.h @@ -22,6 +22,8 @@ #include <stddef.h> +#define MDS_MESSAGE_T_VERSION 0 + /** * Message passed between a server and a client or between two of either */ |