Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nbsdx/SimpleJSON
Simple C++ JSON library
https://github.com/nbsdx/SimpleJSON
Last synced: 2 months ago
JSON representation
Simple C++ JSON library
- Host: GitHub
- URL: https://github.com/nbsdx/SimpleJSON
- Owner: nbsdx
- Archived: true
- Created: 2015-02-21T05:03:48.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2019-02-24T21:06:08.000Z (almost 6 years ago)
- Last Synced: 2024-08-04T02:09:31.298Z (6 months ago)
- Language: C++
- Size: 30.3 KB
- Stars: 203
- Watchers: 13
- Forks: 84
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- AwesomeCppGameDev - SimpleJSON
README
# SimpleJSON
Simple C++ JSON library## License
Do what the fuck you want public license## About
SimpleJSON is a lightweight JSON library for exporting data in JSON format from C++. By taking advantage of templates and operator overloading on the backend, you're able to create and work with JSON objects right away, just as you would expect from a language such as JavaScript. SimpleJSON is a single C++ Header file, "json.hpp". Feel free to download this file on its own, and include it in your project. No other requirements!#### Platforms
SimpleJSON should work on any platform; it's only requirement is a C++11 compatible compiler, as it make heavy use of the C++11 move semantics, and variadic templates. The tests are tailored for linux, but could be ported to any platform with python support and a C++11 compiler.## API
You can find the API [over here](API.md). For now it's just a Markdown file with C++ syntax highlighting, but it's better than nothing!## Upcoming Features
SimpleJSON is still missing some features, which I hope to get done soon!
* Write more test cases to cover all major components( mostly parsing )One of the biggests goals for SimpleJSON is for it to be lightweight, and small. Having complicated logic isn't bad, but it bloats the codebase in most cases. I'd like to keep things small rather than put in big features that take a ton of space.
If you run into any bugs, or see that I'm missing a featuer, please submit an issue through GitHub and I'll respond as soon as I can!
## Example
More examples can be found in the 'examples' directory. Check out [the API](API.md) for a full list of functions.```cpp
#include "json.hpp"int main() {
json::JSON obj;
// Create a new Array as a field of an Object.
obj["array"] = json::Array( true, "Two", 3, 4.0 );
// Create a new Object as a field of another Object.
obj["obj"] = json::Object();
// Assign to one of the inner object's fields
obj["obj"]["inner"] = "Inside";
// We don't need to specify the type of the JSON object:
obj["new"]["some"]["deep"]["key"] = "Value";
obj["array2"].append( false, "three" );
// We can also parse a string into a JSON object:
obj["parsed"] = JSON::Load( "[ { \"Key\" : \"Value\" }, false ]" );
std::cout << obj << std::endl;
}
```
Output:
```
{
"array" : [true, "Two", 3, 4.000000],
"array2" : [false, "three"],
"new" : {
"some" : {
"deep" : {
"key" : "Value"
}
}
},
"obj" : {
"inner" : "Inside"
},
"parsed" : [{
"Key" : "Value"
}, false]
}
```This example can also be written another way:
```cpp
#include "json.hpp"
#includeusing json::JSON;
int main() {
JSON obj = {
"array", json::Array( true, "Two", 3, 4.0 ),
"obj", {
"inner", "Inside"
},
"new", {
"some", {
"deep", {
"key", "Value"
}
}
},
"array2", json::Array( false, "three" )
};std::cout << obj << std::endl;
```
Sadly, we don't have access to the : character in C++, so we can't use that to seperate key-value pairs, but by using commas, we can achieve a very similar effect. The other point you might notice, is that we have to explictly create arrays. This is a limitation of C++'s operator overloading rules, so we can't use the [] operator to define the array :( I'm looking into ways to make this smoother.