diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-04-28 18:06:58 +0200 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-04-28 18:08:09 +0200 |
commit | 073faa7aeca239e2bf5422f6961241009a080f4e (patch) | |
tree | a06954d18b719f6dbeb787beaf76b4dedb42207c /src/libmdsserver/mds-message.c | |
parent | use sig_atomic_t for running (diff) | |
download | mds-073faa7aeca239e2bf5422f6961241009a080f4e.tar.gz mds-073faa7aeca239e2bf5422f6961241009a080f4e.tar.bz2 mds-073faa7aeca239e2bf5422f6961241009a080f4e.tar.xz |
add version when marshaling
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to 'src/libmdsserver/mds-message.c')
-rw-r--r-- | src/libmdsserver/mds-message.c | 8 |
1 files changed, 7 insertions, 1 deletions
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]; |