mirror of
https://github.com/msgpack/msgpack-c.git
synced 2025-04-20 07:51:34 +02:00

Refined an intrusive example. It includes base class serialization. We can switch map based and array based serialization.
111 lines
3.2 KiB
C++
111 lines
3.2 KiB
C++
// MessagePack for C++ example
|
|
//
|
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
#include <string>
|
|
#include <iostream>
|
|
#include <iomanip>
|
|
#include <sstream>
|
|
#include <cassert>
|
|
|
|
#if 0 // When you want to adapt map instead of array, you can enable these macro definition.
|
|
#define MSGPACK_USE_DEFINE_MAP
|
|
#define MSGPACK_USE_BOOST
|
|
#endif
|
|
|
|
#include <msgpack.hpp>
|
|
|
|
struct my_base1 {
|
|
int a;
|
|
MSGPACK_DEFINE(a);
|
|
};
|
|
inline bool operator==(my_base1 const& lhs, my_base1 const& rhs) {
|
|
return lhs.a == rhs.a;
|
|
}
|
|
|
|
struct my_base2 {
|
|
std::string b;
|
|
std::string c;
|
|
MSGPACK_DEFINE(b, c);
|
|
};
|
|
inline bool operator==(my_base2 const& lhs, my_base2 const& rhs) {
|
|
return lhs.b == rhs.b && lhs.c == rhs.c;
|
|
}
|
|
|
|
class my_class : public my_base1, private my_base2 {
|
|
public:
|
|
my_class() {} // When you want to convert from msgpack::object to my_class,
|
|
// my_class should be default constractible.
|
|
my_class(std::string const& name, int age):name_(name), age_(age) {}
|
|
void set_b(std::string const& str) { b = str; }
|
|
void set_c(std::string const& str) { c = str; }
|
|
friend bool operator==(my_class const& lhs, my_class const& rhs) {
|
|
return
|
|
static_cast<my_base1 const&>(lhs) == static_cast<my_base1 const&>(rhs) &&
|
|
static_cast<my_base2 const&>(lhs) == static_cast<my_base2 const&>(rhs) &&
|
|
lhs.name_ == rhs.name_ && lhs.age_ == rhs.age_;
|
|
}
|
|
|
|
private:
|
|
std::string name_;
|
|
int age_;
|
|
|
|
public:
|
|
MSGPACK_DEFINE(name_, age_, MSGPACK_BASE(my_base1), MSGPACK_BASE(my_base2));
|
|
};
|
|
|
|
void print(std::string const& buf) {
|
|
for (std::string::const_iterator it = buf.begin(), end = buf.end();
|
|
it != end;
|
|
++it) {
|
|
std::cout
|
|
<< std::setw(2)
|
|
<< std::hex
|
|
<< std::setfill('0')
|
|
<< (static_cast<int>(*it) & 0xff)
|
|
<< ' ';
|
|
}
|
|
std::cout << std::dec << std::endl;
|
|
}
|
|
|
|
int main() {
|
|
{ // pack, unpack
|
|
my_class my("John Smith", 42);
|
|
my.a = 123;
|
|
my.set_b("ABC");
|
|
my.set_c("DEF");
|
|
std::stringstream ss;
|
|
msgpack::pack(ss, my);
|
|
|
|
print(ss.str());
|
|
|
|
msgpack::unpacked unp;
|
|
msgpack::unpack(unp, ss.str().data(), ss.str().size());
|
|
msgpack::object obj = unp.get();
|
|
std::cout << obj << std::endl;
|
|
assert(obj.as<my_class>() == my);
|
|
}
|
|
{ // create object with zone
|
|
my_class my("John Smith", 42);
|
|
my.set_b("ABC");
|
|
my.set_c("DEF");
|
|
msgpack::zone z;
|
|
msgpack::object obj(my, z);
|
|
std::cout << obj << std::endl;
|
|
assert(obj.as<my_class>() == my);
|
|
}
|
|
}
|