Skip to content

XUranus/minijson

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MiniJson

a mini Json library C++ implement

minijsonC++14WindowsLinuxMSVC 2015+GCC 4.9+

build & test

build static/dynamic library:

mkdir build && cd build
cmake .. && cmake --build .

build and run test coverage:

mkdir build && cd build
# use lcov
cmake .. -DCMAKE_BUILD_TYPE=Debug -DCOVERAGE=lcov
# or use gcovr
# cmake .. -DCMAKE_BUILD_TYPE=Debug -DCOVERAGE=gcovr
cmake --build .
make minijson_coverage_test

usage

  1. Serialization/deserilization of basic type
#include <bits/stdc++.h>
#include "Json.h"
using namespace xuranus::minijson;

int main() {
  std::string jsonStr = R"(
    {
      "name" : "xuranus",
      "age" : 300,
      "skills" : ["C++", "Java", "Python"]
    }
  )";
  JsonElement element = JsonParser(jsonStr).Parse();
  JsonObject object = element.AsJsonObject();
  std::cout << object["name"].AsString() << std::endl; // xuranus
  std::cout << object["age"].AsNumber() << std::endl; // 300
  std::cout << object["skills"].AsJsonArray()[0].AsString() << std::endl; // C++
  std::cout << object["skills"].AsJsonArray()[1].AsString() << std::endl; // Java
  std::cout << object["skills"].AsJsonArray()[2].AsString() << std::endl; // Python

  std::cout << element.Serialize() << std::endl; 
  // {"name" : "xuranus", "age" : 300, "skills" : ["C++", "Java", "Python"]}
}
  1. Serialization/deserilization of struct
#include <bits/stdc++.h>
#include "Json.h"
using namespace xuranus::minijson;

struct Book {
  std::string m_name;
  int m_id;
  float m_price;
  bool m_soldOut;
  std::vector<std::string> m_tags;
  
  SERIALIZE_SECTION_BEGIN
  SERIALIZE_FIELD(name, m_name);
  SERIALIZE_FIELD(id, m_id);
  SERIALIZE_FIELD(price, m_price);
  SERIALIZE_FIELD(soldOut, m_soldOut);
  SERIALIZE_FIELD(tags, m_tags);
  SERIALIZE_SECTION_END
};

int main() {
  Book book1 {};
  book1.m_name = "C++ Primer";
  book1.m_id = 114514;
  book1.m_price = 114.5;
  book1.m_soldOut = true;
  book1.m_tags = {"C++", "Programming", "Language"};

  
  std::string jsonStr = util::Serialize(book1);
  std::cout << jsonStr << std::endl; 
  /**
  * output:
  * {"id":114514,"name":"C++ Primer","price":114.5,"soldOut":true,"tags":["C++","Programming",*"Language"]}
  **/

  Book book2 {};
  util::Deserialize(jsonStr, book2);
  std::cout << book2.m_name << " " << book2.m_id << " " << book2.m_price << std::endl;
  /**
  * output:
  * C++ Primer 114514 114.5
  **/
  return 0;
}

see more usage in test cases at test/MiniJsonTest.cpp

About

a mini Json library C++ implement

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published