mirror of
				https://github.com/msgpack/msgpack-c.git
				synced 2025-10-21 15:51:44 +02:00 
			
		
		
		
	 1bfcf55469
			
		
	
	1bfcf55469
	
	
	
		
			
			msgpack::unpacked is a typedef of the msgpack::object_handle. I recommend using msgpack::object_handle. It can be used not only holding unpacked msgpack objects but also msgpack::objects that are created by any types. Replaced unpack() APIs in test codes and examples. They used to use old APIs.
		
			
				
	
	
		
			150 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // MessagePack for C++ example
 | |
| //
 | |
| // Copyright (C) 2015 KONDO Takatoshi
 | |
| //
 | |
| //    Distributed under the Boost Software License, Version 1.0.
 | |
| //    (See accompanying file LICENSE_1_0.txt or copy at
 | |
| //    http://www.boost.org/LICENSE_1_0.txt)
 | |
| //
 | |
| 
 | |
| #include <iostream>
 | |
| #include <sstream>
 | |
| #include <cassert>
 | |
| 
 | |
| #include <array>
 | |
| #include <tuple>
 | |
| #include <unordered_map>
 | |
| #include <unordered_set>
 | |
| #include <forward_list>
 | |
| #include <string>
 | |
| 
 | |
| #include <msgpack.hpp>
 | |
| 
 | |
| void array() {
 | |
|     std::array<int, 5> a { { 1, 2, 3, 4, 5 } };
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, a);
 | |
| 
 | |
|     msgpack::object_handle oh = msgpack::unpack(ss.str().data(), ss.str().size());
 | |
|     msgpack::object obj = oh.get();
 | |
| 
 | |
|     std::cout << obj << std::endl;
 | |
|     assert((obj.as<std::array<int, 5>>()) == a);
 | |
| }
 | |
| 
 | |
| void tuple() {
 | |
|     std::tuple<bool, std::string, int> t(true, "ABC", 42);
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, t);
 | |
| 
 | |
|     auto oh = msgpack::unpack(ss.str().data(), ss.str().size());
 | |
|     auto obj = oh.get();
 | |
| 
 | |
|     std::cout << obj << std::endl;
 | |
|     assert(obj.as<decltype(t)>() == t);
 | |
| }
 | |
| 
 | |
| void unordered_map() {
 | |
|     std::unordered_map<std::string, int> m { {"ABC", 1}, {"DEF", 3} };
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, m);
 | |
| 
 | |
|     auto oh = msgpack::unpack(ss.str().data(), ss.str().size());
 | |
|     msgpack::object obj = oh.get();
 | |
| 
 | |
|     std::cout << obj << std::endl;
 | |
|     assert(obj.as<decltype(m)>() == m);
 | |
| }
 | |
| 
 | |
| void unordered_set() {
 | |
|     std::unordered_set<std::string> s { "ABC", "DEF" };
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, s);
 | |
| 
 | |
|     auto oh = msgpack::unpack(ss.str().data(), ss.str().size());
 | |
|     auto obj = oh.get();
 | |
| 
 | |
|     std::cout << obj << std::endl;
 | |
|     assert(obj.as<decltype(s)>() == s);
 | |
| }
 | |
| 
 | |
| void forward_list() {
 | |
|     using type = std::forward_list<std::string>;
 | |
|     type f { "ABC", "DEF" };
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, f);
 | |
| 
 | |
|     auto oh = msgpack::unpack(ss.str().data(), ss.str().size());
 | |
|     auto obj = oh.get();
 | |
| 
 | |
|     std::cout << obj << std::endl;
 | |
|     assert(obj.as<type>() == f);
 | |
| }
 | |
| 
 | |
| void combi() {
 | |
|     std::array<int, 5>                   a { { 1, 2, 3, 4, 5 } };
 | |
|     std::tuple<bool, std::string, int>   t {true, "ABC", 42};
 | |
|     std::unordered_map<std::string, int> m { {"ABC", 1}, {"DEF", 3} };
 | |
|     std::unordered_set<std::string>      s { "ABC", "DEF" };
 | |
|     std::forward_list<std::string>       f { "ABC", "DEF" };
 | |
| 
 | |
|     std::stringstream ss;
 | |
|     msgpack::pack(ss, a);
 | |
|     msgpack::pack(ss, t);
 | |
|     msgpack::pack(ss, m);
 | |
|     msgpack::pack(ss, s);
 | |
|     msgpack::pack(ss, f);
 | |
| 
 | |
|     std::size_t offset = 0;
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
|     {
 | |
|         auto oh = msgpack::unpack(ss.str().data(), ss.str().size(), offset);
 | |
|         auto obj = oh.get();
 | |
| 
 | |
|         std::cout << obj << std::endl;
 | |
|         assert(obj.as<decltype(a)>() == a);
 | |
|     }
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
|     {
 | |
|         auto oh = msgpack::unpack(ss.str().data(), ss.str().size(), offset);
 | |
|         auto obj = oh.get();
 | |
| 
 | |
|         std::cout << obj << std::endl;
 | |
|         assert(obj.as<decltype(t)>() == t);
 | |
|     }
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
|     {
 | |
|         auto oh = msgpack::unpack(ss.str().data(), ss.str().size(), offset);
 | |
|         auto obj = oh.get();
 | |
| 
 | |
|         std::cout << obj << std::endl;
 | |
|         assert(obj.as<decltype(m)>() == m);
 | |
|     }
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
|     {
 | |
|         auto oh = msgpack::unpack(ss.str().data(), ss.str().size(), offset);
 | |
|         auto obj = oh.get();
 | |
| 
 | |
|         std::cout << obj << std::endl;
 | |
|         assert(obj.as<decltype(s)>() == s);
 | |
|     }
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
|     {
 | |
|         auto oh = msgpack::unpack(ss.str().data(), ss.str().size(), offset);
 | |
|         auto obj = oh.get();
 | |
| 
 | |
|         std::cout << obj << std::endl;
 | |
|         assert(obj.as<decltype(f)>() == f);
 | |
|     }
 | |
|     std::cout << "offset: " << offset << std::endl;
 | |
| }
 | |
| 
 | |
| int main() {
 | |
|     array();
 | |
|     tuple();
 | |
|     unordered_map();
 | |
|     unordered_set();
 | |
|     forward_list();
 | |
|     combi();
 | |
| }
 |