Being explicit about aligned_free

This commit is contained in:
Daniel Lemire 2019-03-15 12:11:50 -04:00 committed by GitHub
parent 374fe1af1e
commit 40a5d5ddfa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 4 additions and 2 deletions

View File

@ -61,7 +61,7 @@ Under Windows, we build some tools using the windows/dirent_portable.h file (whi
const char * filename = ... // const char * filename = ... //
// use whatever means you want to get a string of your JSON document // use whatever means you want to get a string of your JSON document
std::string_view p = get_corpus(filename); std::string_view p = get_corpus(filename); // you are responsible for freeing p.data()
ParsedJson pj; ParsedJson pj;
pj.allocateCapacity(p.size()); // allocate memory for parsing up to p.size() bytes pj.allocateCapacity(p.size()); // allocate memory for parsing up to p.size() bytes
const int res = json_parse(p, pj); // do the parsing, return 0 on success const int res = json_parse(p, pj); // do the parsing, return 0 on success
@ -71,7 +71,7 @@ if (res != 0) {
std::cout << "Error parsing:" << simdjson::errorMsg(res) << std::endl; std::cout << "Error parsing:" << simdjson::errorMsg(res) << std::endl;
} }
// You can safely delete the string content // You can safely delete the string content
free((void*)p.data()); aligned_free((void*)p.data());
// the ParsedJson document can be used here // the ParsedJson document can be used here
// js can be reused with other json_parse calls. // js can be reused with other json_parse calls.
``` ```
@ -91,6 +91,7 @@ ParsedJson pj = build_parsed_json(p); // do the parsing
if( ! pj.isValid() ) { if( ! pj.isValid() ) {
// something went wrong // something went wrong
} }
aligned_free((void*)p.data());
``` ```
## Usage: easy single-header version ## Usage: easy single-header version
@ -112,6 +113,7 @@ int main(int argc, char *argv[]) {
} else { } else {
std::cout << "valid" << std::endl; std::cout << "valid" << std::endl;
} }
aligned_free((void*)p.data());
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
``` ```