/staticstruct

Simple statically typed struct serialization/deserialization library in C++11

Primary LanguageC++MIT LicenseMIT

staticstruct, Simple statically typed struct serialization/deserialization library in C++11

staticstruct is a simple, single .hh/.cc file C++11 library to reconstruct/save statically typed C++ struct.

When we write graphics and machine learning applications, there are many situation that we need to operate with statically-typed, predefined struct data. And we want to serialize/deserialize such data into/from binary and ASCII format(e.g. JSON).

staticstruct help to write such converters/adapters.

Existing serialization library in C++11 is too complex and too generic. In most cases simple basic types and limited support of STL container types are suffice.

staticstruct is based on StaticJSON: https://github.com/netheril96/StaticJSON

Status

Work in progres. currently some deserialization features are available.

Requirements

  • C++11 compiler
    • clang, gcc, MSVC, ...

How to build

Simply copy staticstruct.cc and staticstruct.hh to your project.

Usage

struct MyStruct
{
  float f{};
  std::vector<float> vf;
};

MyStruct s;

// Register handler.
staticstruct::ObjectHandler h;
h.add_property("f", &s.f);
h.add_property("vf", &s.vf);

// Write parser logic.
// `ParseStruct` will iterate over registered properties and call the callback function(lambda).
// Application need to explicitly specify how to set value.
//
// You can use `staticstruct::ParseUtil::SetValue` to set value easily.
//
staticstruct::Reader r;
bool ret = r.ParseStruct(&h, [](std::string key, uint32_t flags, staticstruct::BaseHandler &handler) -> bool {
  if (key == "f") {
    return staticstruct::ParseUtil::SetValue(1.0f, handler);
    // or you can do this: return handler.Float(1.0f);
  } else if (key == "vf") {
    std::vector<float> data = {1.0f, 2.0f, 3.3f, 4.5f};
    return staticstruct::ParseUtil::SetValue(data, handler);
  }
  std::cerr << "Need to implement how to parse property `" + key + "`\n";
  return false;
});

if (!ret) {
  std::cerr << "failed\n";
  return -1;
}

Supported basic types

  • bool
  • short, ushort
  • int, uint(int32, uint32)
  • int64, uintt64
  • float, double
  • std::string

Supported STL containers

  • std::map
  • std::unordered_map
  • std::list
  • std::vector
  • std::array

TODO

  • Specialize frequently used datatype
    • std::vector<float>
    • std::vector<std::array<float, 3>> (float3)
    • std::vector<std::array<float, 4>> (float4)
    • std::vector<std::array<float, 16>> (matrix4x4)
  • Better error report.
  • Refator code.
  • Implement schema generator.
  • Serializer.
  • Unit tests.

License

MIT license.

Third party license

  • StaticJSON: MIT license