aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-11-11 15:29:59 +0100
committerDavid Robillard <d@drobilla.net>2018-12-31 11:37:49 -0500
commit64d6f4eee1d5014b25f366e1615bb8ad39e667f7 (patch)
tree5981c73deec04567d353429afba132cbf24012ff /src
parent4a49f7d02aed06e76678da09d85cc8bc0bc3649c (diff)
downloadserd-64d6f4eee1d5014b25f366e1615bb8ad39e667f7.tar.gz
serd-64d6f4eee1d5014b25f366e1615bb8ad39e667f7.tar.bz2
serd-64d6f4eee1d5014b25f366e1615bb8ad39e667f7.zip
Simplify reader stack pushing code
Diffstat (limited to 'src')
-rw-r--r--src/reader.h30
1 files changed, 16 insertions, 14 deletions
diff --git a/src/reader.h b/src/reader.h
index 4edef344..506aaff2 100644
--- a/src/reader.h
+++ b/src/reader.h
@@ -145,27 +145,29 @@ push_byte(SerdReader* reader, SerdNode* node, const uint8_t c)
{
SERD_STACK_ASSERT_TOP(reader, node);
uint8_t* const s = (uint8_t*)serd_stack_push(&reader->stack, 1);
- if (!s) {
- return SERD_ERR_OVERFLOW;
+
+ if (s) {
+ ++node->n_bytes;
+ *(s - 1) = c;
+ *s = '\0';
}
- ++node->n_bytes;
- *(s - 1) = c;
- *s = '\0';
- return SERD_SUCCESS;
+ return s ? SERD_SUCCESS : SERD_ERR_OVERFLOW;
}
static inline SerdStatus
-push_bytes(SerdReader* reader, SerdNode* ref, const uint8_t* bytes, unsigned len)
+push_bytes(SerdReader* reader,
+ SerdNode* ref,
+ const uint8_t* bytes,
+ unsigned len)
{
- if (reader->stack.buf_size < reader->stack.size + len) {
- return SERD_ERR_OVERFLOW;
- }
-
- for (unsigned i = 0; i < len; ++i) {
- push_byte(reader, ref, bytes[i]);
+ const bool has_space = reader->stack.buf_size >= reader->stack.size + len;
+ if (has_space) {
+ for (unsigned i = 0; i < len; ++i) {
+ push_byte(reader, ref, bytes[i]);
+ }
}
- return SERD_SUCCESS;
+ return has_space ? SERD_SUCCESS : SERD_ERR_OVERFLOW;
}
#endif // SERD_READER_H