2.1 KiB
Write an JSON content
@tableofcontents
The first thing to do when reading or writing a JSON file/stream, is to declare the Document interface
Include ejson @snippet read.cpp ejson_sample_include
Declare document interface @snippet read.cpp ejson_sample_declare_doc
Write an JSON file
Write an json tree is done like: @snippet write.cpp ejson_sample_write_file
When you acces on the fileSystem, it is hard to have atoimic access, then the best way to not corupt your previous file (chash when writing the new) is to store the file in a second one and move the file at the corretc position. This is all done in the single commmand: @snippet write.cpp ejson_sample_write_file_safe_mode
Write an JSON Stream
Writing a stream is done like this: @snippet write.cpp ejson_sample_write_stream
Operation on Tree
Add String: @snippet write.cpp ejson_sample_write_add_string
Add Null: @snippet write.cpp ejson_sample_write_add_null
Add Number: @snippet write.cpp ejson_sample_write_add_number
Add Boolean: @snippet write.cpp ejson_sample_write_add_boolean
Add Array with values: @snippet write.cpp ejson_sample_write_add_array
Add Object with values: @snippet write.cpp ejson_sample_write_add_object
Remove a Value in an Object: @snippet write.cpp ejson_sample_write_rm_object
Remove a Value in an Object: @snippet write.cpp ejson_sample_write_rm_array
Object concept
The ejson concept is to abstract the implementation of the internal system. All the element are mapped on shared memory. Then if you asign an element to an other, it is the same. You need to clone it if you want to have new standalone element.
@snippet read.cpp ejson_sample_read_clone
All example file
@include write.cpp