tmate/msgpack
2013-06-10 02:50:07 -04:00
..
example Adding msgpack 2013-06-10 02:50:07 -04:00
src Adding msgpack 2013-06-10 02:50:07 -04:00
test Adding msgpack 2013-06-10 02:50:07 -04:00
.gitignore Adding msgpack 2013-06-10 02:50:07 -04:00
AUTHORS Adding msgpack 2013-06-10 02:50:07 -04:00
bootstrap Adding msgpack 2013-06-10 02:50:07 -04:00
cases_compact.mpac Adding msgpack 2013-06-10 02:50:07 -04:00
cases_gen.rb Adding msgpack 2013-06-10 02:50:07 -04:00
cases.json Adding msgpack 2013-06-10 02:50:07 -04:00
cases.mpac Adding msgpack 2013-06-10 02:50:07 -04:00
ChangeLog Adding msgpack 2013-06-10 02:50:07 -04:00
configure.in Adding msgpack 2013-06-10 02:50:07 -04:00
COPYING Adding msgpack 2013-06-10 02:50:07 -04:00
crosslang.cc Adding msgpack 2013-06-10 02:50:07 -04:00
crosslang.rb Adding msgpack 2013-06-10 02:50:07 -04:00
Doxyfile Adding msgpack 2013-06-10 02:50:07 -04:00
LICENSE Adding msgpack 2013-06-10 02:50:07 -04:00
Makefile.am Adding msgpack 2013-06-10 02:50:07 -04:00
msgpack_vc8.sln Adding msgpack 2013-06-10 02:50:07 -04:00
msgpack_vc8.vcproj Adding msgpack 2013-06-10 02:50:07 -04:00
msgpack_vc.postbuild.bat Adding msgpack 2013-06-10 02:50:07 -04:00
msgpack.pc.in Adding msgpack 2013-06-10 02:50:07 -04:00
NOTICE Adding msgpack 2013-06-10 02:50:07 -04:00
pack_define.h Adding msgpack 2013-06-10 02:50:07 -04:00
pack_template.h Adding msgpack 2013-06-10 02:50:07 -04:00
preprocess Adding msgpack 2013-06-10 02:50:07 -04:00
README_crosslang.md Adding msgpack 2013-06-10 02:50:07 -04:00
README.md Adding msgpack 2013-06-10 02:50:07 -04:00
sysdep.h Adding msgpack 2013-06-10 02:50:07 -04:00
unpack_define.h Adding msgpack 2013-06-10 02:50:07 -04:00
unpack_template.h Adding msgpack 2013-06-10 02:50:07 -04:00

MessagePack for C/C++

Binary-based efficient object serialization library.

Installation

Download latest package from releases of MessagePack and extract it.

On UNIX-like platform, run ./configure && make && sudo make install:

$ ./configure
$ make
$ sudo make install

On Windows, open msgpack_vc8.vcproj or msgpack_vc2008 file and build it using batch build. DLLs are built on lib folder, and the headers are built on include folder.

To use the library in your program, include msgpack.hpp header and link "msgpack" library.

Example

#include <msgpack.hpp>
#include <vector>

int main(void) {
    // This is target object.
    std::vector<std::string> target;
    target.push_back("Hello,");
    target.push_back("World!");

    // Serialize it.
    msgpack::sbuffer buffer;  // simple buffer
    msgpack::pack(&buffer, target);

    // Deserialize the serialized data.
    msgpack::unpacked msg;    // includes memory pool and deserialized object
    msgpack::unpack(&msg, sbuf.data(), sbuf.size());
    msgpack::object obj = msg.get();

    // Print the deserialized object to stdout.
    std::cout << obj << std::endl;    // ["Hello," "World!"]

    // Convert the deserialized object to staticaly typed object.
    std::vector<std::string> result;
    obj.convert(&result);

    // If the type is mismatched, it throws msgpack::type_error.
    obj.as<int>();  // type is mismatched, msgpack::type_error is thrown
}

API documents and other example codes are available at the wiki.

License

Copyright (C) 2008-2010 FURUHASHI Sadayuki

   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.

See also NOTICE file.