From b16765b4830587c42db16587eda86f1eebb9a352 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 20 Feb 2021 16:50:11 -0500 Subject: Zero node padding before passing to reader sinks --- src/node.c | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) (limited to 'src/node.c') diff --git a/src/node.c b/src/node.c index ec14e611..f7ee0457 100644 --- a/src/node.c +++ b/src/node.c @@ -152,6 +152,27 @@ serd_node_set(SerdNode** const dst, const SerdNode* const src) memcpy(*dst, src, size); } +/** + Zero node padding. + + This is used for nodes which live in re-used stack memory during reading, + which must be normalized before being passed to a sink so comparison will + work correctly. +*/ +void +serd_node_zero_pad(SerdNode* node) +{ + char* buf = serd_node_buffer(node); + const size_t size = node->length; + const size_t padded_size = serd_node_pad_size(size); + + memset(buf + size, 0, padded_size - size); + + if (node->flags & (SERD_HAS_DATATYPE | SERD_HAS_LANGUAGE)) { + serd_node_zero_pad(serd_node_meta(node)); + } +} + SerdNode* serd_new_token(const SerdNodeType type, const SerdStringView str) { @@ -275,7 +296,14 @@ serd_node_copy(const SerdNode* node) } const size_t size = serd_node_total_size(node); - SerdNode* copy = (SerdNode*)serd_calloc_aligned(serd_node_align, size); +#ifndef NDEBUG + const size_t unpadded_size = node->length; + const size_t padded_size = serd_node_pad_size(node->length); + for (size_t i = 0; i < padded_size - unpadded_size; ++i) { + assert(serd_node_buffer_c(node)[unpadded_size + i] == '\0'); + } +#endif + SerdNode* copy = (SerdNode*)serd_calloc_aligned(serd_node_align, size); memcpy(copy, node, size); return copy; } -- cgit v1.2.1