Commit 9e643575 authored by Guido Casati's avatar Guido Casati

Wrap multi-statement macros ENCODE_U8() and ENCODE_U32() in do { ... } while (0) statements

parent bac4f798
...@@ -24,9 +24,11 @@ ...@@ -24,9 +24,11 @@
#include <arpa/inet.h> // htonl, htons #include <arpa/inet.h> // htonl, htons
#define ENCODE_U8(buffer, value, size) \ #define ENCODE_U8(buffer, value, size) \
*(uint8_t*)(buffer) = value; \ do { \
size += sizeof(uint8_t) *(uint8_t*)(buffer) = value; \
size += sizeof(uint8_t); \
} while (0)
/* Safely encodes a 16-bit value into a buffer, handling /* Safely encodes a 16-bit value into a buffer, handling
misalignment by memcpy 2 bytes to buffer in network misalignment by memcpy 2 bytes to buffer in network
...@@ -49,11 +51,11 @@ ...@@ -49,11 +51,11 @@
} while (0) } while (0)
#define ENCODE_U32(buffer, value, size) \ #define ENCODE_U32(buffer, value, size) \
{ \ do { \
uint32_t tmp = htonl(value); \ uint32_t tmp = htonl(value); \
memcpy(buffer, &tmp, sizeof(tmp)); \ memcpy(buffer, &tmp, sizeof(tmp)); \
} \ size += sizeof(uint32_t); \
size += sizeof(uint32_t) } while (0)
#define IES_ENCODE_U8(buffer, encoded, value) \ #define IES_ENCODE_U8(buffer, encoded, value) \
ENCODE_U8(buffer + encoded, value, encoded) ENCODE_U8(buffer + encoded, value, encoded)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment