Commit 953cda14 authored by Philipp A. Hartmann's avatar Philipp A. Hartmann

tutorial.cpp: fix insitu parsing (closes #273)

The insitu parsing example in the tutorial is using a local char
buffer inside a nested scope.  After leaving the scope, the
resulting Document object still references this (now invalid)
memory locations.

Some compilers reuse this space on the stack for other local
variables later in the function, corrupting the original document.

Drop the local scope to extend the lifetime of the buffer.
parent b4844079
...@@ -24,12 +24,10 @@ int main(int, char*[]) { ...@@ -24,12 +24,10 @@ int main(int, char*[]) {
return 1; return 1;
#else #else
// In-situ parsing, decode strings directly in the source string. Source must be string. // In-situ parsing, decode strings directly in the source string. Source must be string.
{ char buffer[sizeof(json)];
char buffer[sizeof(json)]; memcpy(buffer, json, sizeof(json));
memcpy(buffer, json, sizeof(json)); if (document.ParseInsitu(buffer).HasParseError())
if (document.ParseInsitu(buffer).HasParseError()) return 1;
return 1;
}
#endif #endif
printf("\nParsing to document succeeded.\n"); printf("\nParsing to document succeeded.\n");
......
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