From ef8c2c434e61b7e6e75239d6d72beef2366c4350 Mon Sep 17 00:00:00 2001 From: bobergj Date: Fri, 23 Apr 2021 23:10:03 +0900 Subject: [PATCH] When realloc_if_needed, use loaded_bytes buffer rather always allocating a tmp one. (#1518) --- include/simdjson/dom/parser-inl.h | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/include/simdjson/dom/parser-inl.h b/include/simdjson/dom/parser-inl.h index c81ce67a..fa1ed790 100644 --- a/include/simdjson/dom/parser-inl.h +++ b/include/simdjson/dom/parser-inl.h @@ -100,13 +100,18 @@ inline simdjson_result parser::parse_into_document(document& provided_d // Important: It is possible that provided_doc is actually the internal 'doc' within the parser!!! error_code _error = ensure_capacity(provided_doc, len); if (_error) { return _error; } - std::unique_ptr tmp_buf; if (realloc_if_needed) { - tmp_buf.reset(reinterpret_cast( internal::allocate_padded_buffer(len) )); - if (tmp_buf.get() == nullptr) { return MEMALLOC; } - std::memcpy(static_cast(tmp_buf.get()), buf, len); + // Make sure we have enough capacity to copy len bytes + if (!loaded_bytes || _loaded_bytes_capacity < len) { + loaded_bytes.reset( internal::allocate_padded_buffer(len) ); + if (!loaded_bytes) { + return MEMALLOC; + } + _loaded_bytes_capacity = len; + } + std::memcpy(static_cast(loaded_bytes.get()), buf, len); } - _error = implementation->parse(realloc_if_needed ? tmp_buf.get() : buf, len, provided_doc); + _error = implementation->parse(realloc_if_needed ? reinterpret_cast(loaded_bytes.get()): buf, len, provided_doc); if (_error) { return _error; }