summaryrefslogtreecommitdiffstats
path: root/lib/buffer.c
diff options
context:
space:
mode:
authorGergely Nagy <algernon@balabit.hu>2012-06-22 15:11:42 +0200
committerGergely Nagy <algernon@balabit.hu>2012-06-22 15:11:42 +0200
commit645e1eb4155bccb4586e63febfbba7828d4a61d7 (patch)
treeed8d47a00533e1806579353ac028eb1025c885c2 /lib/buffer.c
parent88c48725d12663dd807e28d65871f8db4ac7273e (diff)
downloadlibumberlog-645e1eb4155bccb4586e63febfbba7828d4a61d7.tar.gz
libumberlog-645e1eb4155bccb4586e63febfbba7828d4a61d7.tar.xz
libumberlog-645e1eb4155bccb4586e63febfbba7828d4a61d7.zip
Fix error handling in buffer.c
* Don't lose old msg on realloc() failure * Don't dereference NULL on failure when buffer = (...) if (!buffer) { buffer->len = orig_len; ...} * To avoid the above pattern, use integer return values: "buffer" itself will not change in any case. * Add missing error handling Signed-off-by: Miloslav Trmač <mitr@redhat.com> Signed-off-by: Gergely Nagy <algernon@balabit.hu>
Diffstat (limited to 'lib/buffer.c')
-rw-r--r--lib/buffer.c56
1 files changed, 30 insertions, 26 deletions
diff --git a/lib/buffer.c b/lib/buffer.c
index 5cb8d3f..d54b048 100644
--- a/lib/buffer.c
+++ b/lib/buffer.c
@@ -123,26 +123,32 @@ _ul_str_escape (const char *str, char *dest, size_t *length)
return dest;
}
-static inline ul_buffer_t *
+static inline int
_ul_buffer_ensure_size (ul_buffer_t *buffer, size_t size)
{
if (buffer->alloc < size)
{
- buffer->alloc += size * 2;
- buffer->msg = realloc (buffer->msg, buffer->alloc);
- if (!buffer->msg)
- return NULL;
+ size_t new_alloc;
+ void *new_msg;
+
+ new_alloc = buffer->alloc + size * 2;
+ new_msg = realloc (buffer->msg, new_alloc);
+ if (new_msg == NULL)
+ return -1;
+ buffer->alloc = new_alloc;
+ buffer->msg = new_msg;
}
- return buffer;
+ return 0;
}
-ul_buffer_t *
+int
ul_buffer_reset (ul_buffer_t *buffer)
{
+ if (_ul_buffer_ensure_size (buffer, 512) != 0)
+ return -1;
buffer->len = 1;
- _ul_buffer_ensure_size (buffer, 512);
buffer->msg[0] = '{';
- return buffer;
+ return 0;
}
ul_buffer_t *
@@ -154,14 +160,14 @@ ul_buffer_append (ul_buffer_t *buffer, const char *key, const char *value)
/* Append the key to the buffer */
escape_buffer.len = 0;
- _ul_buffer_ensure_size (&escape_buffer, strlen (key) * 6 + 1);
+ if (_ul_buffer_ensure_size (&escape_buffer, strlen (key) * 6 + 1) != 0)
+ goto err;
k = _ul_str_escape (key, escape_buffer.msg, &lk);
if (!k)
return NULL;
- buffer = _ul_buffer_ensure_size (buffer, buffer->len + lk + 4);
- if (!buffer)
- return NULL;
+ if (_ul_buffer_ensure_size (buffer, buffer->len + lk + 4) != 0)
+ goto err;
memcpy (buffer->msg + buffer->len, "\"", 1);
memcpy (buffer->msg + buffer->len + 1, k, lk);
@@ -169,26 +175,24 @@ ul_buffer_append (ul_buffer_t *buffer, const char *key, const char *value)
/* Append the value to the buffer */
escape_buffer.len = 0;
- _ul_buffer_ensure_size (&escape_buffer, strlen (value) * 6 + 1);
+ if (_ul_buffer_ensure_size (&escape_buffer, strlen (value) * 6 + 1) != 0)
+ goto err;
v = _ul_str_escape (value, escape_buffer.msg, &lv);
if (!v)
- {
- buffer->len = orig_len;
- return NULL;
- }
+ goto err;
- buffer = _ul_buffer_ensure_size (buffer, buffer->len + lk + lv + 6);
- if (!buffer)
- {
- buffer->len = orig_len;
- return NULL;
- }
+ if (_ul_buffer_ensure_size (buffer, buffer->len + lk + lv + 6) != 0)
+ goto err;
memcpy (buffer->msg + buffer->len + 1 + lk + 3, v, lv);
memcpy (buffer->msg + buffer->len + 1 + lk + 3 + lv, "\",", 2);
buffer->len += lk + lv + 6;
return buffer;
+
+ err:
+ buffer->len = orig_len;
+ return NULL;
}
char *
@@ -196,13 +200,13 @@ ul_buffer_finalize (ul_buffer_t *buffer)
{
if (buffer->msg[buffer->len - 1] == ',')
{
- if (!_ul_buffer_ensure_size (buffer, buffer->len + 1))
+ if (_ul_buffer_ensure_size (buffer, buffer->len + 1) != 0)
return NULL;
buffer->msg[buffer->len - 1] = '}';
}
else
{
- if (!_ul_buffer_ensure_size (buffer, buffer->len + 2))
+ if (_ul_buffer_ensure_size (buffer, buffer->len + 2) != 0)
return NULL;
buffer->msg[buffer->len++] = '}';
}