libjsonincpp/README.txt

61 lines
2.4 KiB
Plaintext
Raw Normal View History

2024-07-23 13:31:51 +00:00
### libjsonincpp
Suckless C++ library for storing JSON and generating and parsing JSON strings
### Examples
#include <libjsonincpp/jsonobj.h>
#include <libjsonincpp/string_representation.h>
void func(){
json::JSON obj = json::JSON("Hello, World\n");
assert(obj.isString());
std::cout << obj.asString() << std::endl;
}
void foo(){
json::JSON obj = json::JSON(std::vector<JSON>(JSON(12l), JSON(true)));
for (json::JSON& el: obj.asArray()){
std::cout << json::generate_str(el, json::print_pretty) << std::endl;
}
}
### Pros
libjsonincpp is non-recurrsive, out-of-memory-safe C++ library.
Accessing a member of json object that does not exist (for example taking second element of true value, or taking element, corresponding to key "dict-key" of an array value)
does not result in error. libjsonincpp defines a special structure json::JSON_reference. It can be undefined. It is returned by operator[].
Also, this is a correct code in libjsonincpp:
json::JSON obj; // Initial value is null symbol
obj["aaaa"]["foo"][12][0] = JSON("value");
This code will automatically make obj a dictionary, make obj["aaaa"] a dictionary, make obj["aaaa"]["foo"] an array, e.t.c. And at the end, it will perform copy of "value"
### Cons
It has no cons, but more like "limitations":
JSON specification allows some crazy precise float values as JOSN number (imagine unironically handling float with decimal exponent equal to 99....999 with as
many nines as your internet connection can handle). Handling floats and big integers was not my goal. Thus, it can correctly interpret obly numbers with less then 19 digits.
Other number values are stored as unparsed strings.
Also, libregexis024 imposes a restriction on JSON string encoding: All JSON string values MUST be correct UTF-8 strings, otherwise generating string representation of
your JSON object will result in json::misuse exception.
### Dependencies
C++, regexis024_build_system
What is regexis024_build_system? It's nothing. Don't think about it. Just download it and forget about it.
Also, don't forget to disable overcommitment on your system in order for _your system_ to be usable.
Bruh, why don't we already rename OOM-killer to just regular killer and charge it for all the crimes it did?
Why we keep executing OOM-killer on our servers when we can take the guy who thought that overcommitment was a good idea and execute him on an electric chair?