Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ymglez/jsonpack
JsonPack is a high-performance and extremely easy-to-use JSON serialization library
https://github.com/ymglez/jsonpack
Last synced: 2 months ago
JSON representation
JsonPack is a high-performance and extremely easy-to-use JSON serialization library
- Host: GitHub
- URL: https://github.com/ymglez/jsonpack
- Owner: ymglez
- License: apache-2.0
- Created: 2015-09-07T17:31:39.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2016-01-22T12:43:22.000Z (about 9 years ago)
- Last Synced: 2024-08-04T02:09:32.088Z (6 months ago)
- Language: C++
- Size: 12.9 MB
- Stars: 39
- Watchers: 4
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- AwesomeCppGameDev - jsonpack - performance and extremely easy-to-use JSON serialization library (C++)
README
#JsonPack
## Overview
JsonPack is a high-performance and extremely easy-to-use JSON serialization
library for C++ 11, it provide a absolute abstraction layer of this Data Interchange Format. From now on,
you only should take care about managing your C++ objects and JsonPack will make the rest.## Features
* Easy-to-use, contains a very short and intuitive API. See Example section
* Very fast: template metaprograming, zero string copy and fast number conversions.
* Support serialization/deserialization for c++ types:
bool, char, int, unsigned int, long, unsigned long,
long long,unsigned long long, float, double and std::string.
* Support serialization/deserialization for c++ standard containers:
array, vector, deque, list, forward_list, set, multiset, unordered_set, unordered_multiset.
* Support serialization/deserialization for c++ standard associative containers:
map, multimap, unordered_map and unordered_multimap with std::string key
* Parsing error management.* JSON keys match with C++ identifiers name convention when json blob read directly
into the data object.* DOM style parsing with nice data recovering.
## Example
```cpp
#includestruct DataObject
{
DataObject():
mInt(362880),
mFloat(3.1415926535897932384626433832795f),
mCad("This, \" is a \", \'test"),
isObject(true),
caracter('$'),
degrees({{"Washington", {12.5, 15.2}},{"Havana", {25.3, 23.4}},{"Singapour", {6.0}}})
{}int mInt;
float mFloat;
std::string mCad;
bool isObject;
char caracter;
std::map> degrees ;// The defined members, will be the JSON attributes set
// Pairs <"key" : value>, are: <"member-name" : member-value >
DEFINE_JSON_ATTRIBUTES(mFloat, mInt, mCad, isObject, caracter, degrees)
};int main()
{
// manage my object
DataObject src, out;//serialize object
//pretty print
//param bool pretty if or not output will be pretty-printed
//param unsigned indent degree of indentation(spaces)
char* serialized = src.json_pack(true, 2);
printf("pretty json: \n%s\n", serialized);
//deserialize json
try
{
out.json_unpack(serialized, strlen(serialized) );
printf("\ndeserialized object:\n %s\n", out.json_pack());
}
catch (jsonpack::jsonpack_error &e)
{
printf("error: %s\n", e.what());
}free(serialized);
getchar();
return 0;
}
```
## DOM Style example
```cpp
#includestruct DataObject
{
DataObject():
mInt(0),
mFloat(0.0),
mCad(""),
isObject(true),
caracter(0)
{}int mInt;
float mFloat;
std::string mCad;
bool isObject;
char caracter;
};int main()
{
DataObject out;std::string json_obj = "{\"mFloat\":3.1415926535897932384626433832795,\"mInt\":362880,\"mCad\":\"This, \\\" is a 'test\",\"isObject\":true,\"caracter\":\"$\"}";
std::string json_arr = "[45.254, 487.000025255, 0.658]";
try
{
//DOM style parse json object
jsonpack::value obj;obj.json_unpack(json_obj.c_str(), json_obj.length() );
// Explicit type conversion: two ways// obj["mFloat"](out.mFloat);
out.mFloat = obj["mFloat"].get();// obj["mInt"](out.mInt);
out.mInt = obj["mInt"].get();// document_obj["mCad"](out.mCad);
out.mCad = obj["mCad"].get();// obj["isObject"](out.isObject);
out.isObject = obj["isObject"].get();// obj["caracter"](out.caracter);
out.caracter = obj["caracter"].get();printf("\nresult: \nout.mFloat=%0.16f\nout.mInt=%d\nout.mCad=%s\nout.isObject=%d\nout.caracter=%c\n",
out.mFloat, out.mInt, out.mCad.data(), out.isObject, out.caracter );//DOM style parse json array
jsonpack::value list;list.json_unpack(json_arr.c_str(), json_arr.length() );
//can be: array, deque, list, forward_list, set, multiset, unordered_set and unordered_multiset.
// std::vector real_list;
// list(real_list);
auto real_list = list.get>();for(auto v : real_list)
printf("%f ", v);printf("\n");
}
catch (jsonpack::jsonpack_error &e)
{
printf("error: %s\n", e.what());
}
getchar();return 0;
}
```
## Build### You will need:
- cmake >= 2.8.0
- gcc >= 4.7 OR msvc >= 11 OR clang >= 2.9### Using terminal
* Without example:
```bash
$ cd jsonpack
$ mkdir build
$ cd build
$ cmake .. -DCMAKE_BUILD_TYPE=Release
$ make
$ sudo make install
```* With example:
```bash
$ cd jsonpack
$ mkdir build
$ cd build
$ cmake .. -DJSONPACK_BUILD_EXAMPLES=ON -DCMAKE_BUILD_TYPE=Release
$ make
$ sudo make install
```### GUI on Windows
1. Launch cmake GUI client
2. Set 'Where is the source code:' text box and 'Where to build the binaries:' text box.
3. Click 'Configure' button.
4. Choose your Visual Studio version.
5. Click 'Generate' button.
6. Open the created jsonpack.sln on Visual Studio.
7. Build all
## Contributing
1. Fork it!
2. Create your feature branch: git checkout -b my-new-feature
3. Commit your changes: git commit -am 'Add some feature'
4. Push to the branch: git push origin my-new-feature
5. Submit a pull request :D## License
----------Jsonpack is licensed under the Apache License Version 2.0. See
the [`LICENSE`](./LICENSE) file for details.