mirror of
https://github.com/msgpack/msgpack-c.git
synced 2025-10-24 09:12:30 +02:00
Compare commits
86 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
2a349cf418 | ||
![]() |
1bac5a2c00 | ||
![]() |
bf4a57da34 | ||
![]() |
2fcbe6116d | ||
![]() |
0176dd760a | ||
![]() |
d30548af3f | ||
![]() |
ab12b2b2b9 | ||
![]() |
7ce69a362f | ||
![]() |
cc08146b1c | ||
![]() |
6896cc602f | ||
![]() |
d8f366daf2 | ||
![]() |
ef649009e4 | ||
![]() |
847a7852e5 | ||
![]() |
e265beef91 | ||
![]() |
dc679a2572 | ||
![]() |
b6bc7f7ecb | ||
![]() |
501260eb54 | ||
![]() |
8615358515 | ||
![]() |
dd083ca933 | ||
![]() |
c203928fae | ||
![]() |
197ed8c983 | ||
![]() |
990860fe65 | ||
![]() |
dbeb6e61c6 | ||
![]() |
2b3f37f9e0 | ||
![]() |
f50148a9cc | ||
![]() |
9fc8ec5b61 | ||
![]() |
751a6f98fe | ||
![]() |
9d8e6b92fc | ||
![]() |
c868da2879 | ||
![]() |
e0c40c1c59 | ||
![]() |
f185284776 | ||
![]() |
1656ef0111 | ||
![]() |
3cb2e4f7c6 | ||
![]() |
3104f7e451 | ||
![]() |
ab8e7ea822 | ||
![]() |
6daef66ea7 | ||
![]() |
04286eb9dc | ||
![]() |
d15e30bf4a | ||
![]() |
fb1d480faf | ||
![]() |
c8fa0be345 | ||
![]() |
643b0c9523 | ||
![]() |
06930616b2 | ||
![]() |
6e5fc6d396 | ||
![]() |
17b0753023 | ||
![]() |
7491348d40 | ||
![]() |
eef2036c36 | ||
![]() |
fbec8f4470 | ||
![]() |
8e0137e1d2 | ||
![]() |
1dac3f890a | ||
![]() |
9f33266f23 | ||
![]() |
d8c7fd5161 | ||
![]() |
731bc643d0 | ||
![]() |
12e8615ac5 | ||
![]() |
22703d2cdb | ||
![]() |
cb518f472a | ||
![]() |
271f1fa319 | ||
![]() |
9ecc4f0a1e | ||
![]() |
977eab7c4a | ||
![]() |
c9f342f4b2 | ||
![]() |
126e4d8414 | ||
![]() |
14ee1e5827 | ||
![]() |
ecbb9055a2 | ||
![]() |
862f04104d | ||
![]() |
d47f72be0c | ||
![]() |
98c5767372 | ||
![]() |
97a7b7545a | ||
![]() |
caf5616573 | ||
![]() |
b8076fa71f | ||
![]() |
2360466aa9 | ||
![]() |
28370b36aa | ||
![]() |
9d82356ea9 | ||
![]() |
ca24e040c4 | ||
![]() |
0fd629857d | ||
![]() |
8eff14db11 | ||
![]() |
81e26fe9b9 | ||
![]() |
9eb4583dd5 | ||
![]() |
5a23c86dc1 | ||
![]() |
ffd0525607 | ||
![]() |
3dc636bf3e | ||
![]() |
260ce4aa1d | ||
![]() |
8bc827ebf5 | ||
![]() |
a97f764088 | ||
![]() |
143b90af3e | ||
![]() |
4e0a6ae624 | ||
![]() |
17aa517e41 | ||
![]() |
2c1a1fd4f8 |
10
.gitignore
vendored
10
.gitignore
vendored
@@ -9,16 +9,6 @@
|
|||||||
/configure
|
/configure
|
||||||
/msgpack_vc2008.sln
|
/msgpack_vc2008.sln
|
||||||
/msgpack_vc2008.vcproj
|
/msgpack_vc2008.vcproj
|
||||||
/src/msgpack/pack_define.h
|
|
||||||
/src/msgpack/pack_template.h
|
|
||||||
/src/msgpack/sysdep.h
|
|
||||||
/src/msgpack/type/define.hpp
|
|
||||||
/src/msgpack/type/tuple.hpp
|
|
||||||
/src/msgpack/unpack_define.h
|
|
||||||
/src/msgpack/unpack_template.h
|
|
||||||
/src/msgpack/zone.hpp
|
|
||||||
/test/cases.mpac
|
|
||||||
/test/cases_compact.mpac
|
|
||||||
Makefile.in
|
Makefile.in
|
||||||
|
|
||||||
# Files generated by the configure script.
|
# Files generated by the configure script.
|
||||||
|
25
.travis.yml
Normal file
25
.travis.yml
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
language: cpp
|
||||||
|
cache:
|
||||||
|
- apt
|
||||||
|
compiler:
|
||||||
|
- clang
|
||||||
|
- gcc
|
||||||
|
before_install:
|
||||||
|
# We need this line to have g++4.8 available in apt
|
||||||
|
- sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
|
||||||
|
- sudo apt-get update -qq
|
||||||
|
- sudo apt-get update
|
||||||
|
- sudo apt-get install valgrind
|
||||||
|
- sudo apt-get install libgtest-dev
|
||||||
|
- "cd /usr/src/gtest && sudo cmake . && sudo cmake --build . && sudo mv libg* /usr/local/lib/ ; cd -"
|
||||||
|
install:
|
||||||
|
- sudo apt-get install -qq gcc-4.8 g++-4.8
|
||||||
|
# We want to compile with g++ 4.8 when rather than the default g++
|
||||||
|
- sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 90
|
||||||
|
|
||||||
|
env:
|
||||||
|
- ACTION="ci/build_autotools.sh" PARAM="cpp03"
|
||||||
|
- ACTION="ci/build_cmake.sh" PARAM="cpp03"
|
||||||
|
|
||||||
|
script:
|
||||||
|
- git clean -xdf && ${ACTION} ${PARAM}
|
193
CMakeLists.txt
Normal file
193
CMakeLists.txt
Normal file
@@ -0,0 +1,193 @@
|
|||||||
|
CMAKE_MINIMUM_REQUIRED (VERSION 2.8.6)
|
||||||
|
PROJECT (msgpack)
|
||||||
|
|
||||||
|
SET (VERSION 0.5.9)
|
||||||
|
SET (VERSION_MAJOR 0)
|
||||||
|
SET (VERSION_MINOR 5)
|
||||||
|
|
||||||
|
SET (prefix ${CMAKE_INSTALL_PREFIX})
|
||||||
|
SET (exec_prefix "\${prefix}")
|
||||||
|
SET (libdir "\${exec_prefix}/lib")
|
||||||
|
SET (includedir "\${prefix}/include")
|
||||||
|
|
||||||
|
FIND_PACKAGE (GTest)
|
||||||
|
FIND_PACKAGE (ZLIB)
|
||||||
|
FIND_PACKAGE (Threads)
|
||||||
|
IF (GTEST_FOUND AND ZLIB_FOUND AND THREADS_FOUND)
|
||||||
|
OPTION (MSGPACK_BUILD_TESTS "Build msgpack tests." ON)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
OPTION (MSGPACK_ENABLE_CXX "Enable C++ interface." ON)
|
||||||
|
|
||||||
|
INCLUDE (CheckCXXSourceCompiles)
|
||||||
|
CHECK_CXX_SOURCE_COMPILES ("
|
||||||
|
#include <bits/atomicity.h>
|
||||||
|
int atomic_sub(int i) { return __gnu_cxx::__exchange_and_add(&i, -1) - 1; }
|
||||||
|
int atomic_add(int i) { return __gnu_cxx::__exchange_and_add(&i, 1) + 1; }
|
||||||
|
int main(int argc, char * argv[])
|
||||||
|
{
|
||||||
|
atomic_sub(1);
|
||||||
|
atomic_add(1);
|
||||||
|
}
|
||||||
|
" MSGPACK_ENABLE_GCC_CXX_ATOMIC)
|
||||||
|
|
||||||
|
IF (MSGPACK_ENABLE_CXX)
|
||||||
|
LIST (APPEND msgpack_SOURCES
|
||||||
|
src/object.cpp
|
||||||
|
)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
IF (MSGPACK_ENABLE_GCC_CXX_ATOMIC)
|
||||||
|
LIST (APPEND msgpack_SOURCES
|
||||||
|
src/gcc_atomic.cpp
|
||||||
|
)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
|
||||||
|
LIST (APPEND msgpack_SOURCES
|
||||||
|
src/unpack.c
|
||||||
|
src/objectc.c
|
||||||
|
src/version.c
|
||||||
|
src/vrefbuffer.c
|
||||||
|
src/zone.c
|
||||||
|
)
|
||||||
|
|
||||||
|
LIST (APPEND msgpack_HEADERS
|
||||||
|
src/msgpack/pack_define.h
|
||||||
|
src/msgpack/pack_template.h
|
||||||
|
src/msgpack/unpack_define.h
|
||||||
|
src/msgpack/unpack_template.h
|
||||||
|
src/msgpack/sysdep.h
|
||||||
|
src/msgpack/sbuffer.h
|
||||||
|
src/msgpack/version.h
|
||||||
|
src/msgpack/vrefbuffer.h
|
||||||
|
src/msgpack/zbuffer.h
|
||||||
|
src/msgpack/fbuffer.h
|
||||||
|
src/msgpack/pack.h
|
||||||
|
src/msgpack/unpack.h
|
||||||
|
src/msgpack/object.h
|
||||||
|
src/msgpack/zone.h
|
||||||
|
)
|
||||||
|
|
||||||
|
IF (MSGPACK_ENABLE_CXX)
|
||||||
|
LIST (APPEND msgpack_HEADERS
|
||||||
|
src/msgpack.hpp
|
||||||
|
src/msgpack/sbuffer.hpp
|
||||||
|
src/msgpack/vrefbuffer.hpp
|
||||||
|
src/msgpack/zbuffer.hpp
|
||||||
|
src/msgpack/fbuffer.hpp
|
||||||
|
src/msgpack/pack.hpp
|
||||||
|
src/msgpack/unpack.hpp
|
||||||
|
src/msgpack/object.hpp
|
||||||
|
src/msgpack/zone.hpp
|
||||||
|
src/msgpack/type.hpp
|
||||||
|
src/msgpack/type/bool.hpp
|
||||||
|
src/msgpack/type/deque.hpp
|
||||||
|
src/msgpack/type/float.hpp
|
||||||
|
src/msgpack/type/fixint.hpp
|
||||||
|
src/msgpack/type/int.hpp
|
||||||
|
src/msgpack/type/list.hpp
|
||||||
|
src/msgpack/type/map.hpp
|
||||||
|
src/msgpack/type/nil.hpp
|
||||||
|
src/msgpack/type/pair.hpp
|
||||||
|
src/msgpack/type/raw.hpp
|
||||||
|
src/msgpack/type/set.hpp
|
||||||
|
src/msgpack/type/string.hpp
|
||||||
|
src/msgpack/type/vector.hpp
|
||||||
|
src/msgpack/type/tuple.hpp
|
||||||
|
src/msgpack/type/define.hpp
|
||||||
|
src/msgpack/type/tr1/unordered_map.hpp
|
||||||
|
src/msgpack/type/tr1/unordered_set.hpp
|
||||||
|
)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
EXECUTE_PROCESS (
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_CURRENT_BINARY_DIR}/src/msgpack
|
||||||
|
)
|
||||||
|
|
||||||
|
CONFIGURE_FILE (
|
||||||
|
src/msgpack/version.h.in
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/src/msgpack/version.h
|
||||||
|
)
|
||||||
|
|
||||||
|
CONFIGURE_FILE (
|
||||||
|
msgpack.pc.in
|
||||||
|
msgpack.pc
|
||||||
|
@ONLY
|
||||||
|
)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES (
|
||||||
|
./
|
||||||
|
src/
|
||||||
|
src/msgpack/
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/src/
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/src/msgpack/
|
||||||
|
)
|
||||||
|
|
||||||
|
ADD_LIBRARY (msgpack SHARED
|
||||||
|
${msgpack_SOURCES}
|
||||||
|
${msgpack_HEADERS}
|
||||||
|
)
|
||||||
|
|
||||||
|
ADD_LIBRARY (msgpack-static STATIC
|
||||||
|
${msgpack_SOURCES}
|
||||||
|
${msgpack_HEADERS}
|
||||||
|
)
|
||||||
|
|
||||||
|
SET_TARGET_PROPERTIES (msgpack-static PROPERTIES OUTPUT_NAME "msgpack")
|
||||||
|
SET_TARGET_PROPERTIES (msgpack PROPERTIES IMPORT_SUFFIX "_import.lib")
|
||||||
|
SET_TARGET_PROPERTIES (msgpack PROPERTIES SOVERSION 3 VERSION 3.0.0)
|
||||||
|
|
||||||
|
IF (MSGPACK_BUILD_TESTS)
|
||||||
|
ENABLE_TESTING ()
|
||||||
|
ADD_SUBDIRECTORY (test)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
|
SET_PROPERTY (TARGET msgpack APPEND_STRING PROPERTY COMPILE_FLAGS "-Wall -g -O3 -DPIC")
|
||||||
|
SET_PROPERTY (TARGET msgpack-static APPEND_STRING PROPERTY COMPILE_FLAGS "-Wall -g -O3" )
|
||||||
|
ENDIF ()
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
||||||
|
IF (CMAKE_CXX_FLAGS MATCHES "/W[0-4]")
|
||||||
|
STRING(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
|
||||||
|
ELSE ()
|
||||||
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W4")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
IF (NOT DEFINED CMAKE_INSTALL_LIBDIR)
|
||||||
|
SET(CMAKE_INSTALL_LIBDIR lib)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
INSTALL (TARGETS msgpack msgpack-static DESTINATION ${CMAKE_INSTALL_LIBDIR})
|
||||||
|
INSTALL (DIRECTORY src/msgpack DESTINATION include)
|
||||||
|
INSTALL (DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/src/msgpack DESTINATION include)
|
||||||
|
INSTALL (FILES src/msgpack.h src/msgpack.hpp DESTINATION include)
|
||||||
|
INSTALL (FILES ${CMAKE_CURRENT_BINARY_DIR}/msgpack.pc DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig)
|
||||||
|
|
||||||
|
# Doxygen
|
||||||
|
FIND_PACKAGE (Doxygen)
|
||||||
|
IF (DOXYGEN_FOUND)
|
||||||
|
ADD_CUSTOM_TARGET (
|
||||||
|
doxygen_c
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_c
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "FILE_PATTERNS = *.h" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_c
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "OUTPUT_DIRECTORY = doc_c" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_c
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "PROJECT_NAME = \"MessagePack for C\"" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_c
|
||||||
|
COMMAND ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_c
|
||||||
|
VERBATIM
|
||||||
|
)
|
||||||
|
ADD_CUSTOM_TARGET (
|
||||||
|
doxygen_cpp
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_cpp
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "FILE_PATTERNS = *.hpp" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_cpp
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "OUTPUT_DIRECTORY = doc_cpp" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_cpp
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E echo "PROJECT_NAME = \"MessagePack for C++\"" >> ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_cpp
|
||||||
|
COMMAND ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile_cpp
|
||||||
|
VERBATIM
|
||||||
|
)
|
||||||
|
ADD_CUSTOM_TARGET (
|
||||||
|
doxygen
|
||||||
|
DEPENDS doxygen_c doxygen_cpp
|
||||||
|
)
|
||||||
|
ENDIF ()
|
14
ChangeLog
14
ChangeLog
@@ -1,3 +1,17 @@
|
|||||||
|
2014-07-02 version 0.5.9:
|
||||||
|
|
||||||
|
* Support std::tr1 unordered containers by default (#51, #63, #68, #69)
|
||||||
|
* Remove some warnings (#56)
|
||||||
|
* Fix segmentation fault after malloc failures (#58, #59)
|
||||||
|
* Fix alloc/dealloc mismatch (#52, #61)
|
||||||
|
* Fix sample codes (#60, #64)
|
||||||
|
* Support implicit conversion from integer to float/double (#54)
|
||||||
|
* Improve documents (#45, #75, #82, #83)
|
||||||
|
* Support CMake (#20, #87)
|
||||||
|
* Remove Ruby dependencies in bootstrap (#86, #87)
|
||||||
|
* Add FILE* buffer (#40)
|
||||||
|
* Other bug fixes and refactoring: #39, #73, #77, #79, #80, #81, #84, #90
|
||||||
|
|
||||||
2013-12-23 version 0.5.8:
|
2013-12-23 version 0.5.8:
|
||||||
|
|
||||||
* Move to the new github repository msgpack/msgpack-c
|
* Move to the new github repository msgpack/msgpack-c
|
||||||
|
@@ -6,12 +6,10 @@ DOC_FILES = \
|
|||||||
NOTICE \
|
NOTICE \
|
||||||
msgpack_vc8.vcproj \
|
msgpack_vc8.vcproj \
|
||||||
msgpack_vc8.sln \
|
msgpack_vc8.sln \
|
||||||
msgpack_vc2008.vcproj \
|
|
||||||
msgpack_vc2008.sln \
|
|
||||||
msgpack_vc.postbuild.bat
|
msgpack_vc.postbuild.bat
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
$(DOC_FILES)
|
$(DOC_FILES) CMakeLists.txt test/CMakeLists.txt
|
||||||
|
|
||||||
pkgconfigdir = $(libdir)/pkgconfig
|
pkgconfigdir = $(libdir)/pkgconfig
|
||||||
pkgconfig_DATA = msgpack.pc
|
pkgconfig_DATA = msgpack.pc
|
||||||
|
@@ -103,7 +103,7 @@ int main(void) {
|
|||||||
msgpack::sbuffer buffer;
|
msgpack::sbuffer buffer;
|
||||||
|
|
||||||
msgpack::packer<msgpack::sbuffer> pk(&buffer);
|
msgpack::packer<msgpack::sbuffer> pk(&buffer);
|
||||||
pk.pack_array(3)
|
pk.pack_array(3);
|
||||||
pk.pack(std::string("Log message ... 1"));
|
pk.pack(std::string("Log message ... 1"));
|
||||||
pk.pack(std::string("Log message ... 2"));
|
pk.pack(std::string("Log message ... 2"));
|
||||||
pk.pack(std::string("Log message ... 3"));
|
pk.pack(std::string("Log message ... 3"));
|
||||||
@@ -112,10 +112,10 @@ int main(void) {
|
|||||||
msgpack::sbuffer buffer2;
|
msgpack::sbuffer buffer2;
|
||||||
|
|
||||||
msgpack::packer<msgpack::sbuffer> pk2(&buffer2);
|
msgpack::packer<msgpack::sbuffer> pk2(&buffer2);
|
||||||
pk2.pack_map(2)
|
pk2.pack_map(2);
|
||||||
pk2.pack(std::string("x"));
|
pk2.pack(std::string("x"));
|
||||||
pk2.pack(3);
|
pk2.pack(3);
|
||||||
pk2.pack(std::string("y));
|
pk2.pack(std::string("y"));
|
||||||
pk2.pack(3.4321);
|
pk2.pack(3.4321);
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -124,7 +124,7 @@ int main(void) {
|
|||||||
|
|
||||||
## User-defined classes
|
## User-defined classes
|
||||||
|
|
||||||
You can use serialize/deserializes user-defined classes using MSGPACK_DEFINE macro.
|
You can use serialize/deserializes user-defined classes using `MSGPACK_DEFINE` macro.
|
||||||
|
|
||||||
```cpp
|
```cpp
|
||||||
#include <msgpack.hpp>
|
#include <msgpack.hpp>
|
||||||
|
150
README.md
150
README.md
@@ -1,30 +1,136 @@
|
|||||||
MessagePack for C/C++
|
# Msgpack for C/C++
|
||||||
=====================
|
|
||||||
Binary-based efficient object serialization library.
|
It's like JSON but small and fast.
|
||||||
|
|
||||||
|
|
||||||
## Installation
|
## Overview
|
||||||
|
|
||||||
Download latest package from [releases of MessagePack](http://sourceforge.net/projects/msgpack/files/) and extract it.
|
MessagePack is an efficient binary serialization format. It lets you exchange data among multiple languages like JSON. But it's faster and smaller. Small integers are encoded into a single byte, and typical short strings require only one extra byte in addition to the strings themselves.
|
||||||
|
|
||||||
On UNIX-like platform, run ./configure && make && sudo make install:
|
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
Msgpack is Copyright (C) 2008-2010 FURUHASHI Sadayuki and licensed under the Apache License, Version 2.0 (the "License"). For details see the `COPYING` file in this directory.
|
||||||
|
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
The source for msgpack-c is held at [msgpack-c](https://github.com/msgpack/msgpack-c) github.com site.
|
||||||
|
|
||||||
|
To report an issue, use the [msgpack-c issue tracker](https://github.com/msgpack/msgpack-c/issues) at github.com.
|
||||||
|
|
||||||
|
## Version
|
||||||
|
0.5.9 [](https://travis-ci.org/msgpack/msgpack-c)
|
||||||
|
|
||||||
|
## Using Msgpack
|
||||||
|
|
||||||
|
### Building and Installing
|
||||||
|
|
||||||
|
#### Install from git repository
|
||||||
|
|
||||||
|
##### Using autotools
|
||||||
|
You will need gcc (4.1.0 or higher), autotools.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c.git
|
||||||
|
$ cd msgpack-c
|
||||||
|
$ ./bootstrap
|
||||||
$ ./configure
|
$ ./configure
|
||||||
$ make
|
$ make
|
||||||
$ sudo make install
|
$ 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,
|
##### Using cmake
|
||||||
and the headers are built on include folder.
|
You will need gcc (4.1.0 or higher), cmake.
|
||||||
|
|
||||||
To use the library in your program, include msgpack.hpp header and link "msgpack" library.
|
```
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c.git
|
||||||
|
$ cd msgpack-c
|
||||||
|
$ cmake .
|
||||||
|
$ make
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Install from package
|
||||||
|
|
||||||
|
##### UNIX-like platform with ./configure
|
||||||
|
|
||||||
|
On typical UNIX-like platforms, download source package from [Releases](https://github.com/msgpack/msgpack-c/releases) and run `./configure && make && make install`. Example:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ wget https://github.com/msgpack/msgpack-c/releases/download/cpp-0.5.9/msgpack-0.5.9.tar.gz
|
||||||
|
$ tar zxvf msgpack-0.5.9.tar.gz
|
||||||
|
$ cd msgpack-0.5.9
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
```
|
||||||
|
|
||||||
|
##### FreeBSD with Ports Collection
|
||||||
|
|
||||||
|
On FreeBSD, you can use Ports Collection. Install [net/msgpack](http://www.freebsd.org/cgi/cvsweb.cgi/ports/devel/msgpack/) package.
|
||||||
|
|
||||||
|
##### Gentoo Linux with Portage
|
||||||
|
|
||||||
|
On Gentoo Linux, you can use emerge. Install [dev-libs/msgpack](http://gentoo-portage.com/dev-libs/msgpack) package.
|
||||||
|
|
||||||
|
##### Mac OS X with MacPorts
|
||||||
|
|
||||||
|
On Mac OS X, you can install MessagePack for C using MacPorts.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ sudo port install msgpack
|
||||||
|
```
|
||||||
|
|
||||||
|
You might need to run `sudo port selfupdate` before installing to update the package repository.
|
||||||
|
|
||||||
|
You can also install via Homebrew.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ sudo brew install msgpack
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
## Example
|
##### Windows
|
||||||
|
|
||||||
|
Clone msgpack-c git repository.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c.git
|
||||||
|
```
|
||||||
|
|
||||||
|
or using GUI git client.
|
||||||
|
|
||||||
|
e.g.) tortoise git https://code.google.com/p/tortoisegit/
|
||||||
|
|
||||||
|
Launch cmake GUI client. http://www.cmake.org/cmake/resources/software.html
|
||||||
|
|
||||||
|
Set 'Where is the source code:' text box and 'Where to build the binaries:' text box.
|
||||||
|
|
||||||
|
Click 'Configure' button.
|
||||||
|
|
||||||
|
Choose your Visual Studio version.
|
||||||
|
|
||||||
|
Click 'Generate' button.
|
||||||
|
|
||||||
|
Open the created msgpack.sln on Visual Studio.
|
||||||
|
|
||||||
|
Build all.
|
||||||
|
|
||||||
|
### Linking with an Application
|
||||||
|
|
||||||
|
Include `msgpack.hpp` (or `msgpack.h` for C) in your application and link with libmsgpack. Here is a typical gcc link command:
|
||||||
|
|
||||||
|
g++ myapp.cpp -lmsgpack -o myapp
|
||||||
|
|
||||||
|
|
||||||
|
### Code Example
|
||||||
```CPP
|
```CPP
|
||||||
#include <msgpack.hpp>
|
#include <msgpack.hpp>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
int main(void) {
|
int main() {
|
||||||
// This is target object.
|
// This is target object.
|
||||||
std::vector<std::string> target;
|
std::vector<std::string> target;
|
||||||
target.push_back("Hello,");
|
target.push_back("Hello,");
|
||||||
@@ -50,24 +156,6 @@ int main(void) {
|
|||||||
obj.as<int>(); // type is mismatched, msgpack::type_error is thrown
|
obj.as<int>(); // type is mismatched, msgpack::type_error is thrown
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
### Quickstart Guides
|
||||||
|
|
||||||
See [QuickStart for C](QUICKSTART-C.md) and [QuickStart for C++](QUICKSTART-CPP.md) for other example codes.
|
For more detailed examples see [QuickStart for C](QUICKSTART-C.md) and [QuickStart for C++](QUICKSTART-CPP.md).
|
||||||
|
|
||||||
## 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.
|
|
||||||
|
|
||||||
|
@@ -22,7 +22,7 @@ as comparing that implementations.
|
|||||||
or
|
or
|
||||||
$ port install msgpack # MacPorts
|
$ port install msgpack # MacPorts
|
||||||
|
|
||||||
$ g++ -Wall -lmsgpack crosslang.cc -o crosslang
|
$ g++ -Wall crosslang.cc -lmsgpack -o crosslang
|
||||||
|
|
||||||
$ ./crosslang
|
$ ./crosslang
|
||||||
Usage: ./crosslang [in-file] [out-file]
|
Usage: ./crosslang [in-file] [out-file]
|
||||||
|
@@ -38,13 +38,6 @@ test -f ChangeLog || touch ChangeLog
|
|||||||
test -f NEWS || touch NEWS
|
test -f NEWS || touch NEWS
|
||||||
test -f README || cp -f README.md README
|
test -f README || cp -f README.md README
|
||||||
|
|
||||||
./preprocess
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ACLOCAL="aclocal"
|
ACLOCAL="aclocal"
|
||||||
ACLOCAL_FILES="aclocal.m4"
|
ACLOCAL_FILES="aclocal.m4"
|
||||||
ALWAYS_CLEAN="config.status config.log config.cache libtool"
|
ALWAYS_CLEAN="config.status config.log config.cache libtool"
|
||||||
|
47
ci/build_autotools.sh
Executable file
47
ci/build_autotools.sh
Executable file
@@ -0,0 +1,47 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
./bootstrap
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $1 = "cpp11" ]
|
||||||
|
then
|
||||||
|
./configure CXXFLAGS="-std=c++11"
|
||||||
|
else
|
||||||
|
./configure
|
||||||
|
fi
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make check
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make install DESTDIR=`pwd`/install
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
56
ci/build_cmake.sh
Executable file
56
ci/build_cmake.sh
Executable file
@@ -0,0 +1,56 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
mkdir build
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd build
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $1 = "cpp11" ]
|
||||||
|
then
|
||||||
|
cmake -DMSGPACK_CXX11=ON ..
|
||||||
|
else
|
||||||
|
cmake ..
|
||||||
|
fi
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make test
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
make install DESTDIR=`pwd`/install
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
@@ -1,6 +1,6 @@
|
|||||||
AC_INIT(src/object.cpp)
|
AC_INIT(src/object.cpp)
|
||||||
AC_CONFIG_AUX_DIR(ac)
|
AC_CONFIG_AUX_DIR(ac)
|
||||||
AM_INIT_AUTOMAKE(msgpack, 0.5.8)
|
AM_INIT_AUTOMAKE(msgpack, 0.5.9)
|
||||||
AC_CONFIG_HEADER(config.h)
|
AC_CONFIG_HEADER(config.h)
|
||||||
|
|
||||||
AC_SUBST(CFLAGS)
|
AC_SUBST(CFLAGS)
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
// or
|
// or
|
||||||
// $ port install msgpack # MacPorts
|
// $ port install msgpack # MacPorts
|
||||||
//
|
//
|
||||||
// $ g++ -Wall -lmsgpack crosslang.cc
|
// $ g++ -Wall crosslang.cc -lmsgpack
|
||||||
//
|
//
|
||||||
#include <msgpack.hpp>
|
#include <msgpack.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
@@ -34,13 +34,10 @@ public:
|
|||||||
|
|
||||||
m_pac.buffer_consumed(count);
|
m_pac.buffer_consumed(count);
|
||||||
|
|
||||||
while(m_pac.execute()) {
|
msgpack::unpacked result;
|
||||||
msgpack::object msg = m_pac.data();
|
while (m_pac.next(&result)) {
|
||||||
|
msgpack::object msg = result.get();
|
||||||
auto_zone life( m_pac.release_zone() );
|
auto_zone& life = result.zone();
|
||||||
|
|
||||||
m_pac.reset();
|
|
||||||
|
|
||||||
process_message(msg, life);
|
process_message(msg, life);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -12,6 +12,7 @@ copy src\msgpack\sbuffer.h include\msgpack\
|
|||||||
copy src\msgpack\version.h include\msgpack\
|
copy src\msgpack\version.h include\msgpack\
|
||||||
copy src\msgpack\vrefbuffer.h include\msgpack\
|
copy src\msgpack\vrefbuffer.h include\msgpack\
|
||||||
copy src\msgpack\zbuffer.h include\msgpack\
|
copy src\msgpack\zbuffer.h include\msgpack\
|
||||||
|
copy src\msgpack\fbuffer.h include\msgpack\
|
||||||
copy src\msgpack\pack.h include\msgpack\
|
copy src\msgpack\pack.h include\msgpack\
|
||||||
copy src\msgpack\unpack.h include\msgpack\
|
copy src\msgpack\unpack.h include\msgpack\
|
||||||
copy src\msgpack\object.h include\msgpack\
|
copy src\msgpack\object.h include\msgpack\
|
||||||
@@ -20,6 +21,7 @@ copy src\msgpack.hpp include\
|
|||||||
copy src\msgpack\sbuffer.hpp include\msgpack\
|
copy src\msgpack\sbuffer.hpp include\msgpack\
|
||||||
copy src\msgpack\vrefbuffer.hpp include\msgpack\
|
copy src\msgpack\vrefbuffer.hpp include\msgpack\
|
||||||
copy src\msgpack\zbuffer.hpp include\msgpack\
|
copy src\msgpack\zbuffer.hpp include\msgpack\
|
||||||
|
copy src\msgpack\fbuffer.hpp include\msgpack\
|
||||||
copy src\msgpack\pack.hpp include\msgpack\
|
copy src\msgpack\pack.hpp include\msgpack\
|
||||||
copy src\msgpack\unpack.hpp include\msgpack\
|
copy src\msgpack\unpack.hpp include\msgpack\
|
||||||
copy src\msgpack\object.hpp include\msgpack\
|
copy src\msgpack\object.hpp include\msgpack\
|
||||||
|
@@ -159,102 +159,22 @@
|
|||||||
<File
|
<File
|
||||||
RelativePath=".\src\objectc.c"
|
RelativePath=".\src\objectc.c"
|
||||||
>
|
>
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\unpack.c"
|
RelativePath=".\src\unpack.c"
|
||||||
>
|
>
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\version.c"
|
RelativePath=".\src\version.c"
|
||||||
>
|
>
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\vrefbuffer.c"
|
RelativePath=".\src\vrefbuffer.c"
|
||||||
>
|
>
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\zone.c"
|
RelativePath=".\src\zone.c"
|
||||||
>
|
>
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32"
|
|
||||||
>
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
CompileAs="2"
|
|
||||||
/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\object.cpp"
|
RelativePath=".\src\object.cpp"
|
||||||
|
17
preprocess
17
preprocess
@@ -12,23 +12,6 @@ preprocess() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
if [ "$1" = "clean" ];then
|
|
||||||
rm -f src/msgpack/type/tuple.hpp
|
|
||||||
rm -f src/msgpack/type/define.hpp
|
|
||||||
rm -f src/msgpack/zone.hpp
|
|
||||||
else
|
|
||||||
preprocess src/msgpack/type/tuple.hpp
|
preprocess src/msgpack/type/tuple.hpp
|
||||||
preprocess src/msgpack/type/define.hpp
|
preprocess src/msgpack/type/define.hpp
|
||||||
preprocess src/msgpack/zone.hpp
|
preprocess src/msgpack/zone.hpp
|
||||||
fi
|
|
||||||
cp -f sysdep.h src/msgpack/
|
|
||||||
cp -f pack_define.h src/msgpack/
|
|
||||||
cp -f pack_template.h src/msgpack/
|
|
||||||
cp -f unpack_define.h src/msgpack/
|
|
||||||
cp -f unpack_template.h src/msgpack/
|
|
||||||
cp -f cases.mpac test/
|
|
||||||
cp -f cases_compact.mpac test/
|
|
||||||
|
|
||||||
sed -e 's/8\.00/9.00/' < msgpack_vc8.vcproj > msgpack_vc2008.vcproj
|
|
||||||
sed -e 's/9\.00/10.00/' -e 's/msgpack_vc8/msgpack_vc2008/' < msgpack_vc8.sln > msgpack_vc2008.sln
|
|
||||||
|
|
||||||
|
@@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
lib_LTLIBRARIES = libmsgpack.la
|
lib_LTLIBRARIES = libmsgpack.la
|
||||||
|
|
||||||
libmsgpack_la_SOURCES = \
|
libmsgpack_la_SOURCES = \
|
||||||
@@ -42,11 +41,13 @@ nobase_include_HEADERS = \
|
|||||||
msgpack/unpack_define.h \
|
msgpack/unpack_define.h \
|
||||||
msgpack/unpack_template.h \
|
msgpack/unpack_template.h \
|
||||||
msgpack/sysdep.h \
|
msgpack/sysdep.h \
|
||||||
|
gcc_atomic.h \
|
||||||
msgpack.h \
|
msgpack.h \
|
||||||
msgpack/sbuffer.h \
|
msgpack/sbuffer.h \
|
||||||
msgpack/version.h \
|
msgpack/version.h \
|
||||||
msgpack/vrefbuffer.h \
|
msgpack/vrefbuffer.h \
|
||||||
msgpack/zbuffer.h \
|
msgpack/zbuffer.h \
|
||||||
|
msgpack/fbuffer.h \
|
||||||
msgpack/pack.h \
|
msgpack/pack.h \
|
||||||
msgpack/unpack.h \
|
msgpack/unpack.h \
|
||||||
msgpack/object.h \
|
msgpack/object.h \
|
||||||
@@ -58,6 +59,7 @@ nobase_include_HEADERS += \
|
|||||||
msgpack/sbuffer.hpp \
|
msgpack/sbuffer.hpp \
|
||||||
msgpack/vrefbuffer.hpp \
|
msgpack/vrefbuffer.hpp \
|
||||||
msgpack/zbuffer.hpp \
|
msgpack/zbuffer.hpp \
|
||||||
|
msgpack/fbuffer.hpp \
|
||||||
msgpack/pack.hpp \
|
msgpack/pack.hpp \
|
||||||
msgpack/unpack.hpp \
|
msgpack/unpack.hpp \
|
||||||
msgpack/object.hpp \
|
msgpack/object.hpp \
|
||||||
@@ -104,4 +106,3 @@ doxygen_cpp:
|
|||||||
doxygen Doxyfile_cpp
|
doxygen Doxyfile_cpp
|
||||||
|
|
||||||
doxygen: doxygen_c doxygen_cpp
|
doxygen: doxygen_c doxygen_cpp
|
||||||
|
|
||||||
|
@@ -20,6 +20,7 @@
|
|||||||
* @{
|
* @{
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "msgpack/object.h"
|
#include "msgpack/object.h"
|
||||||
#include "msgpack/zone.h"
|
#include "msgpack/zone.h"
|
||||||
#include "msgpack/pack.h"
|
#include "msgpack/pack.h"
|
||||||
|
47
src/msgpack/fbuffer.h
Normal file
47
src/msgpack/fbuffer.h
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* MessagePack for C FILE* buffer adaptor
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Vladimir Volodko
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
#ifndef MSGPACK_FBUFFER_H__
|
||||||
|
#define MSGPACK_FBUFFER_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup msgpack_fbuffer FILE* buffer
|
||||||
|
* @ingroup msgpack_buffer
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
static inline int msgpack_fbuffer_write(void* data, const char* buf, unsigned int len)
|
||||||
|
{
|
||||||
|
return (1 == fwrite(buf, len, 1, (FILE *)data)) ? 0 : -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @} */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* msgpack/fbuffer.h */
|
||||||
|
|
56
src/msgpack/fbuffer.hpp
Normal file
56
src/msgpack/fbuffer.hpp
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ FILE* buffer adaptor
|
||||||
|
//
|
||||||
|
// Copyright (C) 2013 Vladimir Volodko
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_FBUFFER_HPP__
|
||||||
|
#define MSGPACK_FBUFFER_HPP__
|
||||||
|
|
||||||
|
#include <cstdio>
|
||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
|
||||||
|
class fbuffer {
|
||||||
|
public:
|
||||||
|
explicit fbuffer(FILE* file) : m_file(file) { }
|
||||||
|
|
||||||
|
public:
|
||||||
|
void write(const char* buf, unsigned int len)
|
||||||
|
{
|
||||||
|
if (1 != fwrite(buf, len, 1, m_file)) {
|
||||||
|
throw std::runtime_error("fwrite() failed");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
FILE* file() const
|
||||||
|
{
|
||||||
|
return m_file;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
fbuffer(const fbuffer&);
|
||||||
|
fbuffer& operator= (const fbuffer&);
|
||||||
|
|
||||||
|
private:
|
||||||
|
FILE* m_file;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif /* msgpack/fbuffer.hpp */
|
||||||
|
|
@@ -234,6 +234,59 @@ void operator<< (object::with_zone& o, const T& v)
|
|||||||
v.msgpack_object(static_cast<object*>(&o), o.zone);
|
v.msgpack_object(static_cast<object*>(&o), o.zone);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline void operator<< (object::with_zone& o, const object& v)
|
||||||
|
{
|
||||||
|
o.type = v.type;
|
||||||
|
|
||||||
|
switch(v.type) {
|
||||||
|
case type::NIL:
|
||||||
|
case type::BOOLEAN:
|
||||||
|
case type::POSITIVE_INTEGER:
|
||||||
|
case type::NEGATIVE_INTEGER:
|
||||||
|
case type::DOUBLE:
|
||||||
|
::memcpy(&o.via, &v.via, sizeof(v.via));
|
||||||
|
return;
|
||||||
|
|
||||||
|
case type::RAW:
|
||||||
|
o.via.raw.ptr = static_cast<const char*>(o.zone->malloc(v.via.raw.size));
|
||||||
|
o.via.raw.size = v.via.raw.size;
|
||||||
|
::memcpy(const_cast<char*>(o.via.raw.ptr), v.via.raw.ptr, v.via.raw.size);
|
||||||
|
return;
|
||||||
|
|
||||||
|
case type::ARRAY:
|
||||||
|
o.via.array.ptr = static_cast<object*>(o.zone->malloc(sizeof(object) * v.via.array.size));
|
||||||
|
o.via.array.size = v.via.array.size;
|
||||||
|
for(object* po(o.via.array.ptr), * pv(v.via.array.ptr),
|
||||||
|
* const pvend(v.via.array.ptr + v.via.array.size);
|
||||||
|
pv < pvend; ++po, ++pv) {
|
||||||
|
new (po) object(*pv, o.zone);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
|
case type::MAP:
|
||||||
|
o.via.map.ptr = static_cast<object_kv*>(o.zone->malloc(sizeof(object_kv) * v.via.map.size));
|
||||||
|
o.via.map.size = v.via.map.size;
|
||||||
|
for(object_kv* po(o.via.map.ptr), * pv(v.via.map.ptr),
|
||||||
|
* const pvend(v.via.map.ptr + v.via.map.size);
|
||||||
|
pv < pvend; ++po, ++pv) {
|
||||||
|
object_kv* kv = new (po) object_kv;
|
||||||
|
new (&kv->key) object(pv->key, o.zone);
|
||||||
|
new (&kv->val) object(pv->val, o.zone);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw type_error();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline void operator<< (object::with_zone& o, const object::with_zone& v)
|
||||||
|
{
|
||||||
|
return o << static_cast<object>(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline bool operator==(const object x, const object y)
|
inline bool operator==(const object x, const object y)
|
||||||
{
|
{
|
||||||
@@ -412,6 +465,12 @@ packer<Stream>& operator<< (packer<Stream>& o, const object& v)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
packer<Stream>& operator<< (packer<Stream>& o, const object::with_zone& v)
|
||||||
|
{
|
||||||
|
return o << static_cast<object>(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
} // namespace msgpack
|
||||||
|
|
||||||
|
@@ -40,7 +40,7 @@ extern "C" {
|
|||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
typedef int (*msgpack_packer_write)(void* data, const char* buf, unsigned int len);
|
typedef int (*msgpack_packer_write)(void* data, const char* buf, size_t len);
|
||||||
|
|
||||||
typedef struct msgpack_packer {
|
typedef struct msgpack_packer {
|
||||||
void* data;
|
void* data;
|
||||||
|
@@ -656,18 +656,18 @@ if(sizeof(unsigned long long) == 2) {
|
|||||||
|
|
||||||
msgpack_pack_inline_func(_float)(msgpack_pack_user x, float d)
|
msgpack_pack_inline_func(_float)(msgpack_pack_user x, float d)
|
||||||
{
|
{
|
||||||
|
unsigned char buf[5];
|
||||||
union { float f; uint32_t i; } mem;
|
union { float f; uint32_t i; } mem;
|
||||||
mem.f = d;
|
mem.f = d;
|
||||||
unsigned char buf[5];
|
|
||||||
buf[0] = 0xca; _msgpack_store32(&buf[1], mem.i);
|
buf[0] = 0xca; _msgpack_store32(&buf[1], mem.i);
|
||||||
msgpack_pack_append_buffer(x, buf, 5);
|
msgpack_pack_append_buffer(x, buf, 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
msgpack_pack_inline_func(_double)(msgpack_pack_user x, double d)
|
msgpack_pack_inline_func(_double)(msgpack_pack_user x, double d)
|
||||||
{
|
{
|
||||||
|
unsigned char buf[9];
|
||||||
union { double f; uint64_t i; } mem;
|
union { double f; uint64_t i; } mem;
|
||||||
mem.f = d;
|
mem.f = d;
|
||||||
unsigned char buf[9];
|
|
||||||
buf[0] = 0xcb;
|
buf[0] = 0xcb;
|
||||||
#if defined(__arm__) && !(__ARM_EABI__) // arm-oabi
|
#if defined(__arm__) && !(__ARM_EABI__) // arm-oabi
|
||||||
// https://github.com/msgpack/msgpack-perl/pull/1
|
// https://github.com/msgpack/msgpack-perl/pull/1
|
||||||
@@ -713,7 +713,7 @@ msgpack_pack_inline_func(_false)(msgpack_pack_user x)
|
|||||||
msgpack_pack_inline_func(_array)(msgpack_pack_user x, size_t n)
|
msgpack_pack_inline_func(_array)(msgpack_pack_user x, size_t n)
|
||||||
{
|
{
|
||||||
if(n < 16) {
|
if(n < 16) {
|
||||||
unsigned char d = 0x90 | n;
|
unsigned char d = 0x90 | (uint8_t)n;
|
||||||
msgpack_pack_append_buffer(x, &d, 1);
|
msgpack_pack_append_buffer(x, &d, 1);
|
||||||
} else if(n < 65536) {
|
} else if(n < 65536) {
|
||||||
unsigned char buf[3];
|
unsigned char buf[3];
|
||||||
@@ -734,7 +734,7 @@ msgpack_pack_inline_func(_array)(msgpack_pack_user x, size_t n)
|
|||||||
msgpack_pack_inline_func(_map)(msgpack_pack_user x, size_t n)
|
msgpack_pack_inline_func(_map)(msgpack_pack_user x, size_t n)
|
||||||
{
|
{
|
||||||
if(n < 16) {
|
if(n < 16) {
|
||||||
unsigned char d = 0x80 | n;
|
unsigned char d = 0x80 | (uint8_t)n;
|
||||||
msgpack_pack_append_buffer(x, &TAKE8_8(d), 1);
|
msgpack_pack_append_buffer(x, &TAKE8_8(d), 1);
|
||||||
} else if(n < 65536) {
|
} else if(n < 65536) {
|
||||||
unsigned char buf[3];
|
unsigned char buf[3];
|
@@ -64,17 +64,18 @@ static inline void msgpack_sbuffer_free(msgpack_sbuffer* sbuf)
|
|||||||
#define MSGPACK_SBUFFER_INIT_SIZE 8192
|
#define MSGPACK_SBUFFER_INIT_SIZE 8192
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline int msgpack_sbuffer_write(void* data, const char* buf, unsigned int len)
|
static inline int msgpack_sbuffer_write(void* data, const char* buf, size_t len)
|
||||||
{
|
{
|
||||||
msgpack_sbuffer* sbuf = (msgpack_sbuffer*)data;
|
msgpack_sbuffer* sbuf = (msgpack_sbuffer*)data;
|
||||||
|
|
||||||
if(sbuf->alloc - sbuf->size < len) {
|
if(sbuf->alloc - sbuf->size < len) {
|
||||||
|
void* tmp;
|
||||||
size_t nsize = (sbuf->alloc) ?
|
size_t nsize = (sbuf->alloc) ?
|
||||||
sbuf->alloc * 2 : MSGPACK_SBUFFER_INIT_SIZE;
|
sbuf->alloc * 2 : MSGPACK_SBUFFER_INIT_SIZE;
|
||||||
|
|
||||||
while(nsize < sbuf->size + len) { nsize *= 2; }
|
while(nsize < sbuf->size + len) { nsize *= 2; }
|
||||||
|
|
||||||
void* tmp = realloc(sbuf->data, nsize);
|
tmp = realloc(sbuf->data, nsize);
|
||||||
if(!tmp) { return -1; }
|
if(!tmp) { return -1; }
|
||||||
|
|
||||||
sbuf->data = (char*)tmp;
|
sbuf->data = (char*)tmp;
|
||||||
|
@@ -47,7 +47,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void write(const char* buf, unsigned int len)
|
void write(const char* buf, size_t len)
|
||||||
{
|
{
|
||||||
if(base::alloc - base::size < len) {
|
if(base::alloc - base::size < len) {
|
||||||
expand_buffer(len);
|
expand_buffer(len);
|
||||||
|
@@ -191,5 +191,18 @@ typedef unsigned int _msgpack_atomic_counter_t;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if !defined(__cplusplus) && defined(_MSC_VER)
|
||||||
|
#if !defined(FALSE)
|
||||||
|
#define FALSE (0)
|
||||||
|
#endif
|
||||||
|
#if !defined(TRUE)
|
||||||
|
#define TRUE (!FALSE)
|
||||||
|
#endif
|
||||||
|
#define bool int
|
||||||
|
#define true TRUE
|
||||||
|
#define false FALSE
|
||||||
|
#define inline __inline
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* msgpack/sysdep.h */
|
#endif /* msgpack/sysdep.h */
|
||||||
|
|
@@ -13,4 +13,5 @@
|
|||||||
#include "type/vector.hpp"
|
#include "type/vector.hpp"
|
||||||
#include "type/tuple.hpp"
|
#include "type/tuple.hpp"
|
||||||
#include "type/define.hpp"
|
#include "type/define.hpp"
|
||||||
|
#include "type/tr1/unordered_map.hpp"
|
||||||
|
#include "type/tr1/unordered_set.hpp"
|
||||||
|
3465
src/msgpack/type/define.hpp
Normal file
3465
src/msgpack/type/define.hpp
Normal file
File diff suppressed because it is too large
Load Diff
@@ -46,7 +46,7 @@
|
|||||||
return v; \
|
return v; \
|
||||||
} \
|
} \
|
||||||
template <> \
|
template <> \
|
||||||
void operator<< (object::with_zone& o, const enum& v) \
|
inline void operator<< (object::with_zone& o, const enum& v) \
|
||||||
{ \
|
{ \
|
||||||
o << static_cast<int>(v); \
|
o << static_cast<int>(v); \
|
||||||
} \
|
} \
|
||||||
@@ -107,8 +107,13 @@ struct define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> {
|
|||||||
{
|
{
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
if(o.type != type::ARRAY) { throw type_error(); }
|
||||||
const size_t size = o.via.array.size;
|
const size_t size = o.via.array.size;
|
||||||
<%0.upto(i) {|j|%>
|
if(size > 0) {
|
||||||
if(size <= <%=j%>) { return; } o.via.array.ptr[<%=j%>].convert(&a<%=j%>);<%}%>
|
msgpack::object *ptr = o.via.array.ptr;
|
||||||
|
switch(size) {
|
||||||
|
default:<%(i).downto(0) {|j|%>
|
||||||
|
case <%=j+1%>: ptr[<%=j%>].convert(&a<%=j%>);<%}%>
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void msgpack_object(msgpack::object* o, msgpack::zone* z) const
|
void msgpack_object(msgpack::object* o, msgpack::zone* z) const
|
||||||
{
|
{
|
||||||
|
@@ -115,16 +115,61 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const type::fix_uint64& v)
|
|||||||
|
|
||||||
|
|
||||||
inline void operator<< (object& o, type::fix_int8 v)
|
inline void operator<< (object& o, type::fix_int8 v)
|
||||||
{ v.get() < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v.get() : o.type = type::POSITIVE_INTEGER, o.via.u64 = v.get(); }
|
{
|
||||||
|
if ( v.get() < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v.get() ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v.get() ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, type::fix_int16 v)
|
inline void operator<< (object& o, type::fix_int16 v)
|
||||||
{ v.get() < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v.get() : o.type = type::POSITIVE_INTEGER, o.via.u64 = v.get(); }
|
{
|
||||||
|
if ( v.get() < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v.get() ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v.get() ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, type::fix_int32 v)
|
inline void operator<< (object& o, type::fix_int32 v)
|
||||||
{ v.get() < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v.get() : o.type = type::POSITIVE_INTEGER, o.via.u64 = v.get(); }
|
{
|
||||||
|
if ( v.get() < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v.get() ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v.get() ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, type::fix_int64 v)
|
inline void operator<< (object& o, type::fix_int64 v)
|
||||||
{ v.get() < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v.get() : o.type = type::POSITIVE_INTEGER, o.via.u64 = v.get(); }
|
{
|
||||||
|
if( v.get() < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v.get() ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v.get() ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
inline void operator<< (object& o, type::fix_uint8 v)
|
inline void operator<< (object& o, type::fix_uint8 v)
|
||||||
|
@@ -29,8 +29,18 @@ namespace msgpack {
|
|||||||
|
|
||||||
inline float& operator>> (object o, float& v)
|
inline float& operator>> (object o, float& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::DOUBLE) { throw type_error(); }
|
if(o.type == type::DOUBLE) {
|
||||||
v = (float)o.via.dec;
|
v = (float)o.via.dec;
|
||||||
|
}
|
||||||
|
else if (o.type == type::POSITIVE_INTEGER) {
|
||||||
|
v = (float)o.via.u64;
|
||||||
|
}
|
||||||
|
else if (o.type == type::NEGATIVE_INTEGER) {
|
||||||
|
v = (float)o.via.i64;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw type_error();
|
||||||
|
}
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -44,8 +54,18 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const float& v)
|
|||||||
|
|
||||||
inline double& operator>> (object o, double& v)
|
inline double& operator>> (object o, double& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::DOUBLE) { throw type_error(); }
|
if(o.type == type::DOUBLE) {
|
||||||
v = o.via.dec;
|
v = o.via.dec;
|
||||||
|
}
|
||||||
|
else if (o.type == type::POSITIVE_INTEGER) {
|
||||||
|
v = (double)o.via.u64;
|
||||||
|
}
|
||||||
|
else if (o.type == type::NEGATIVE_INTEGER) {
|
||||||
|
v = (double)o.via.i64;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw type_error();
|
||||||
|
}
|
||||||
return v;
|
return v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -98,8 +98,16 @@ namespace detail {
|
|||||||
template <>
|
template <>
|
||||||
struct object_char_sign<true> {
|
struct object_char_sign<true> {
|
||||||
static inline void make(object& o, char v) {
|
static inline void make(object& o, char v) {
|
||||||
v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v
|
if( v < 0 )
|
||||||
: o.type = type::POSITIVE_INTEGER, o.via.u64 = v;
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v ;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -203,19 +211,74 @@ inline void operator<< (object& o, char v)
|
|||||||
|
|
||||||
|
|
||||||
inline void operator<< (object& o, signed char v)
|
inline void operator<< (object& o, signed char v)
|
||||||
{ v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v : o.type = type::POSITIVE_INTEGER, o.via.u64 = v; }
|
{
|
||||||
|
if( v < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, signed short v)
|
inline void operator<< (object& o, signed short v)
|
||||||
{ v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v : o.type = type::POSITIVE_INTEGER, o.via.u64 = v; }
|
{
|
||||||
|
if(v < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, signed int v)
|
inline void operator<< (object& o, signed int v)
|
||||||
{ v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v : o.type = type::POSITIVE_INTEGER, o.via.u64 = v; }
|
{
|
||||||
|
if( v < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, signed long v)
|
inline void operator<< (object& o, signed long v)
|
||||||
{ v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v : o.type = type::POSITIVE_INTEGER, o.via.u64 = v; }
|
{
|
||||||
|
if( v < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void operator<< (object& o, signed long long v)
|
inline void operator<< (object& o, signed long long v)
|
||||||
{ v < 0 ? o.type = type::NEGATIVE_INTEGER, o.via.i64 = v : o.type = type::POSITIVE_INTEGER, o.via.u64 = v; }
|
{
|
||||||
|
if( v < 0 )
|
||||||
|
{
|
||||||
|
o.type = type::NEGATIVE_INTEGER ;
|
||||||
|
o.via.i64 = v ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
o.type = type::POSITIVE_INTEGER ;
|
||||||
|
o.via.u64 = v ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline void operator<< (object& o, unsigned char v)
|
inline void operator<< (object& o, unsigned char v)
|
||||||
|
@@ -19,13 +19,34 @@
|
|||||||
#define MSGPACK_TYPE_TR1_UNORDERED_MAP_HPP__
|
#define MSGPACK_TYPE_TR1_UNORDERED_MAP_HPP__
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
#include "msgpack/object.hpp"
|
||||||
|
|
||||||
|
#define LIBSTDCXX_HAS_STD_UNORDERED_MAP defined(__GLIBCXX__) && __GLIBCXX__ >= 20090421 \
|
||||||
|
&& (__cplusplus >= 201103L || __GXX_EXPERIMENTAL_CXX0X__)
|
||||||
|
|
||||||
|
#if LIBSTDCXX_HAS_STD_UNORDERED_MAP || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
|
#define MSGPACK_HAS_STD_UNOURDERED_MAP
|
||||||
|
#include <unordered_map>
|
||||||
|
#define MSGPACK_STD_TR1 std
|
||||||
|
|
||||||
|
#else // LIBSTDCXX_HAS_STD_UNORDERED_MAP || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
|
#if __GNUC__ >= 4
|
||||||
|
|
||||||
|
#define MSGPACK_HAS_STD_TR1_UNOURDERED_MAP
|
||||||
|
|
||||||
#include <tr1/unordered_map>
|
#include <tr1/unordered_map>
|
||||||
|
#define MSGPACK_STD_TR1 std::tr1
|
||||||
|
|
||||||
|
#endif // __GNUC__ >= 4
|
||||||
|
|
||||||
|
#endif // LIBSTDCXX_HAS_STD_UNORDERED_MAP || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
namespace msgpack {
|
namespace msgpack {
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
template <typename K, typename V>
|
||||||
inline std::tr1::unordered_map<K, V> operator>> (object o, std::tr1::unordered_map<K, V>& v)
|
inline MSGPACK_STD_TR1::unordered_map<K, V> operator>> (object o, MSGPACK_STD_TR1::unordered_map<K, V>& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
if(o.type != type::MAP) { throw type_error(); }
|
||||||
object_kv* p(o.via.map.ptr);
|
object_kv* p(o.via.map.ptr);
|
||||||
@@ -39,10 +60,10 @@ inline std::tr1::unordered_map<K, V> operator>> (object o, std::tr1::unordered_m
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
template <typename Stream, typename K, typename V>
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_map<K,V>& v)
|
inline packer<Stream>& operator<< (packer<Stream>& o, const MSGPACK_STD_TR1::unordered_map<K,V>& v)
|
||||||
{
|
{
|
||||||
o.pack_map(v.size());
|
o.pack_map(v.size());
|
||||||
for(typename std::tr1::unordered_map<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
for(typename MSGPACK_STD_TR1::unordered_map<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
||||||
it != it_end; ++it) {
|
it != it_end; ++it) {
|
||||||
o.pack(it->first);
|
o.pack(it->first);
|
||||||
o.pack(it->second);
|
o.pack(it->second);
|
||||||
@@ -51,7 +72,7 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename K, typename V>
|
template <typename K, typename V>
|
||||||
inline void operator<< (object::with_zone& o, const std::tr1::unordered_map<K,V>& v)
|
inline void operator<< (object::with_zone& o, const MSGPACK_STD_TR1::unordered_map<K,V>& v)
|
||||||
{
|
{
|
||||||
o.type = type::MAP;
|
o.type = type::MAP;
|
||||||
if(v.empty()) {
|
if(v.empty()) {
|
||||||
@@ -62,7 +83,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_map<K,V>
|
|||||||
object_kv* const pend = p + v.size();
|
object_kv* const pend = p + v.size();
|
||||||
o.via.map.ptr = p;
|
o.via.map.ptr = p;
|
||||||
o.via.map.size = v.size();
|
o.via.map.size = v.size();
|
||||||
typename std::tr1::unordered_map<K,V>::const_iterator it(v.begin());
|
typename MSGPACK_STD_TR1::unordered_map<K,V>::const_iterator it(v.begin());
|
||||||
do {
|
do {
|
||||||
p->key = object(it->first, o.zone);
|
p->key = object(it->first, o.zone);
|
||||||
p->val = object(it->second, o.zone);
|
p->val = object(it->second, o.zone);
|
||||||
@@ -74,7 +95,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_map<K,V>
|
|||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
template <typename K, typename V>
|
||||||
inline std::tr1::unordered_multimap<K, V> operator>> (object o, std::tr1::unordered_multimap<K, V>& v)
|
inline MSGPACK_STD_TR1::unordered_multimap<K, V> operator>> (object o, MSGPACK_STD_TR1::unordered_multimap<K, V>& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
if(o.type != type::MAP) { throw type_error(); }
|
||||||
object_kv* p(o.via.map.ptr);
|
object_kv* p(o.via.map.ptr);
|
||||||
@@ -89,10 +110,10 @@ inline std::tr1::unordered_multimap<K, V> operator>> (object o, std::tr1::unorde
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
template <typename Stream, typename K, typename V>
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_multimap<K,V>& v)
|
inline packer<Stream>& operator<< (packer<Stream>& o, const MSGPACK_STD_TR1::unordered_multimap<K,V>& v)
|
||||||
{
|
{
|
||||||
o.pack_map(v.size());
|
o.pack_map(v.size());
|
||||||
for(typename std::tr1::unordered_multimap<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
for(typename MSGPACK_STD_TR1::unordered_multimap<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
||||||
it != it_end; ++it) {
|
it != it_end; ++it) {
|
||||||
o.pack(it->first);
|
o.pack(it->first);
|
||||||
o.pack(it->second);
|
o.pack(it->second);
|
||||||
@@ -101,7 +122,7 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename K, typename V>
|
template <typename K, typename V>
|
||||||
inline void operator<< (object::with_zone& o, const std::tr1::unordered_multimap<K,V>& v)
|
inline void operator<< (object::with_zone& o, const MSGPACK_STD_TR1::unordered_multimap<K,V>& v)
|
||||||
{
|
{
|
||||||
o.type = type::MAP;
|
o.type = type::MAP;
|
||||||
if(v.empty()) {
|
if(v.empty()) {
|
||||||
@@ -112,7 +133,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_multimap
|
|||||||
object_kv* const pend = p + v.size();
|
object_kv* const pend = p + v.size();
|
||||||
o.via.map.ptr = p;
|
o.via.map.ptr = p;
|
||||||
o.via.map.size = v.size();
|
o.via.map.size = v.size();
|
||||||
typename std::tr1::unordered_multimap<K,V>::const_iterator it(v.begin());
|
typename MSGPACK_STD_TR1::unordered_multimap<K,V>::const_iterator it(v.begin());
|
||||||
do {
|
do {
|
||||||
p->key = object(it->first, o.zone);
|
p->key = object(it->first, o.zone);
|
||||||
p->val = object(it->second, o.zone);
|
p->val = object(it->second, o.zone);
|
||||||
@@ -125,5 +146,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_multimap
|
|||||||
|
|
||||||
} // namespace msgpack
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#undef MSGPACK_STD_TR1
|
||||||
|
|
||||||
#endif /* msgpack/type/map.hpp */
|
#endif /* msgpack/type/map.hpp */
|
||||||
|
|
||||||
|
@@ -19,13 +19,34 @@
|
|||||||
#define MSGPACK_TYPE_TR1_UNORDERED_SET_HPP__
|
#define MSGPACK_TYPE_TR1_UNORDERED_SET_HPP__
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
#include "msgpack/object.hpp"
|
||||||
|
|
||||||
|
#define LIBSTDCXX_HAS_STD_UNORDERED_SET defined(__GLIBCXX__) && __GLIBCXX__ >= 20090421 \
|
||||||
|
&& (__cplusplus >= 201103L || __GXX_EXPERIMENTAL_CXX0X__)
|
||||||
|
|
||||||
|
#if LIBSTDCXX_HAS_STD_UNORDERED_SET || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
|
#define MSGPACK_HAS_STD_UNOURDERED_SET
|
||||||
|
#include <unordered_set>
|
||||||
|
#define MSGPACK_STD_TR1 std
|
||||||
|
|
||||||
|
#else // LIBSTDCXX_HAS_STD_UNORDERED_SET || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
|
#if __GNUC__ >= 4
|
||||||
|
|
||||||
|
#define MSGPACK_HAS_STD_TR1_UNOURDERED_SET
|
||||||
|
|
||||||
#include <tr1/unordered_set>
|
#include <tr1/unordered_set>
|
||||||
|
#define MSGPACK_STD_TR1 std::tr1
|
||||||
|
|
||||||
|
#endif // __GNUC__ >= 4
|
||||||
|
|
||||||
|
#endif // LIBSTDCXX_HAS_STD_UNORDERED_SET || defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
|
||||||
|
|
||||||
namespace msgpack {
|
namespace msgpack {
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline std::tr1::unordered_set<T>& operator>> (object o, std::tr1::unordered_set<T>& v)
|
inline MSGPACK_STD_TR1::unordered_set<T>& operator>> (object o, MSGPACK_STD_TR1::unordered_set<T>& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
if(o.type != type::ARRAY) { throw type_error(); }
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
object* p = o.via.array.ptr + o.via.array.size;
|
||||||
@@ -38,10 +59,10 @@ inline std::tr1::unordered_set<T>& operator>> (object o, std::tr1::unordered_set
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
template <typename Stream, typename T>
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_set<T>& v)
|
inline packer<Stream>& operator<< (packer<Stream>& o, const MSGPACK_STD_TR1::unordered_set<T>& v)
|
||||||
{
|
{
|
||||||
o.pack_array(v.size());
|
o.pack_array(v.size());
|
||||||
for(typename std::tr1::unordered_set<T>::const_iterator it(v.begin()), it_end(v.end());
|
for(typename MSGPACK_STD_TR1::unordered_set<T>::const_iterator it(v.begin()), it_end(v.end());
|
||||||
it != it_end; ++it) {
|
it != it_end; ++it) {
|
||||||
o.pack(*it);
|
o.pack(*it);
|
||||||
}
|
}
|
||||||
@@ -49,7 +70,7 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline void operator<< (object::with_zone& o, const std::tr1::unordered_set<T>& v)
|
inline void operator<< (object::with_zone& o, const MSGPACK_STD_TR1::unordered_set<T>& v)
|
||||||
{
|
{
|
||||||
o.type = type::ARRAY;
|
o.type = type::ARRAY;
|
||||||
if(v.empty()) {
|
if(v.empty()) {
|
||||||
@@ -60,7 +81,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_set<T>&
|
|||||||
object* const pend = p + v.size();
|
object* const pend = p + v.size();
|
||||||
o.via.array.ptr = p;
|
o.via.array.ptr = p;
|
||||||
o.via.array.size = v.size();
|
o.via.array.size = v.size();
|
||||||
typename std::tr1::unordered_set<T>::const_iterator it(v.begin());
|
typename MSGPACK_STD_TR1::unordered_set<T>::const_iterator it(v.begin());
|
||||||
do {
|
do {
|
||||||
*p = object(*it, o.zone);
|
*p = object(*it, o.zone);
|
||||||
++p;
|
++p;
|
||||||
@@ -71,7 +92,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_set<T>&
|
|||||||
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline std::tr1::unordered_multiset<T>& operator>> (object o, std::tr1::unordered_multiset<T>& v)
|
inline MSGPACK_STD_TR1::unordered_multiset<T>& operator>> (object o, MSGPACK_STD_TR1::unordered_multiset<T>& v)
|
||||||
{
|
{
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
if(o.type != type::ARRAY) { throw type_error(); }
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
object* p = o.via.array.ptr + o.via.array.size;
|
||||||
@@ -84,10 +105,10 @@ inline std::tr1::unordered_multiset<T>& operator>> (object o, std::tr1::unordere
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
template <typename Stream, typename T>
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_multiset<T>& v)
|
inline packer<Stream>& operator<< (packer<Stream>& o, const MSGPACK_STD_TR1::unordered_multiset<T>& v)
|
||||||
{
|
{
|
||||||
o.pack_array(v.size());
|
o.pack_array(v.size());
|
||||||
for(typename std::tr1::unordered_multiset<T>::const_iterator it(v.begin()), it_end(v.end());
|
for(typename MSGPACK_STD_TR1::unordered_multiset<T>::const_iterator it(v.begin()), it_end(v.end());
|
||||||
it != it_end; ++it) {
|
it != it_end; ++it) {
|
||||||
o.pack(*it);
|
o.pack(*it);
|
||||||
}
|
}
|
||||||
@@ -95,7 +116,7 @@ inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline void operator<< (object::with_zone& o, const std::tr1::unordered_multiset<T>& v)
|
inline void operator<< (object::with_zone& o, const MSGPACK_STD_TR1::unordered_multiset<T>& v)
|
||||||
{
|
{
|
||||||
o.type = type::ARRAY;
|
o.type = type::ARRAY;
|
||||||
if(v.empty()) {
|
if(v.empty()) {
|
||||||
@@ -106,7 +127,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_multiset
|
|||||||
object* const pend = p + v.size();
|
object* const pend = p + v.size();
|
||||||
o.via.array.ptr = p;
|
o.via.array.ptr = p;
|
||||||
o.via.array.size = v.size();
|
o.via.array.size = v.size();
|
||||||
typename std::tr1::unordered_multiset<T>::const_iterator it(v.begin());
|
typename MSGPACK_STD_TR1::unordered_multiset<T>::const_iterator it(v.begin());
|
||||||
do {
|
do {
|
||||||
*p = object(*it, o.zone);
|
*p = object(*it, o.zone);
|
||||||
++p;
|
++p;
|
||||||
@@ -118,5 +139,7 @@ inline void operator<< (object::with_zone& o, const std::tr1::unordered_multiset
|
|||||||
|
|
||||||
} // namespace msgpack
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#undef MSGPACK_STD_TR1
|
||||||
|
|
||||||
#endif /* msgpack/type/set.hpp */
|
#endif /* msgpack/type/set.hpp */
|
||||||
|
|
||||||
|
13691
src/msgpack/type/tuple.hpp
Normal file
13691
src/msgpack/type/tuple.hpp
Normal file
File diff suppressed because it is too large
Load Diff
@@ -232,7 +232,7 @@ msgpack_unpack_func(int, _execute)(msgpack_unpack_struct(_context)* ctx, const c
|
|||||||
case 0xdd: // array 32
|
case 0xdd: // array 32
|
||||||
case 0xde: // map 16
|
case 0xde: // map 16
|
||||||
case 0xdf: // map 32
|
case 0xdf: // map 32
|
||||||
again_fixed_trail(NEXT_CS(p), 2 << (((unsigned int)*p) & 0x01));
|
again_fixed_trail(NEXT_CS(p), 2u << (((unsigned int)*p) & 0x01));
|
||||||
default:
|
default:
|
||||||
goto _failed;
|
goto _failed;
|
||||||
}
|
}
|
||||||
@@ -397,7 +397,7 @@ _end:
|
|||||||
ctx->cs = cs;
|
ctx->cs = cs;
|
||||||
ctx->trail = trail;
|
ctx->trail = trail;
|
||||||
ctx->top = top;
|
ctx->top = top;
|
||||||
*off = p - (const unsigned char*)data;
|
*off = (size_t)(p - (const unsigned char*)data);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
@@ -98,6 +98,7 @@ void msgpack_vrefbuffer_clear(msgpack_vrefbuffer* vref);
|
|||||||
static inline msgpack_vrefbuffer* msgpack_vrefbuffer_new(size_t ref_size, size_t chunk_size)
|
static inline msgpack_vrefbuffer* msgpack_vrefbuffer_new(size_t ref_size, size_t chunk_size)
|
||||||
{
|
{
|
||||||
msgpack_vrefbuffer* vbuf = (msgpack_vrefbuffer*)malloc(sizeof(msgpack_vrefbuffer));
|
msgpack_vrefbuffer* vbuf = (msgpack_vrefbuffer*)malloc(sizeof(msgpack_vrefbuffer));
|
||||||
|
if (vbuf == NULL) return NULL;
|
||||||
if(!msgpack_vrefbuffer_init(vbuf, ref_size, chunk_size)) {
|
if(!msgpack_vrefbuffer_init(vbuf, ref_size, chunk_size)) {
|
||||||
free(vbuf);
|
free(vbuf);
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -130,7 +131,7 @@ static inline const struct iovec* msgpack_vrefbuffer_vec(const msgpack_vrefbuffe
|
|||||||
|
|
||||||
static inline size_t msgpack_vrefbuffer_veclen(const msgpack_vrefbuffer* vref)
|
static inline size_t msgpack_vrefbuffer_veclen(const msgpack_vrefbuffer* vref)
|
||||||
{
|
{
|
||||||
return vref->tail - vref->array;
|
return (size_t)(vref->tail - vref->array);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -65,7 +65,7 @@ static inline char* msgpack_zbuffer_release_buffer(msgpack_zbuffer* zbuf);
|
|||||||
#define MSGPACK_ZBUFFER_RESERVE_SIZE 512
|
#define MSGPACK_ZBUFFER_RESERVE_SIZE 512
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline int msgpack_zbuffer_write(void* data, const char* buf, unsigned int len);
|
static inline int msgpack_zbuffer_write(void* data, const char* buf, size_t len);
|
||||||
|
|
||||||
static inline bool msgpack_zbuffer_expand(msgpack_zbuffer* zbuf);
|
static inline bool msgpack_zbuffer_expand(msgpack_zbuffer* zbuf);
|
||||||
|
|
||||||
@@ -91,6 +91,7 @@ void msgpack_zbuffer_destroy(msgpack_zbuffer* zbuf)
|
|||||||
msgpack_zbuffer* msgpack_zbuffer_new(int level, size_t init_size)
|
msgpack_zbuffer* msgpack_zbuffer_new(int level, size_t init_size)
|
||||||
{
|
{
|
||||||
msgpack_zbuffer* zbuf = (msgpack_zbuffer*)malloc(sizeof(msgpack_zbuffer));
|
msgpack_zbuffer* zbuf = (msgpack_zbuffer*)malloc(sizeof(msgpack_zbuffer));
|
||||||
|
if (zbuf == NULL) return NULL;
|
||||||
if(!msgpack_zbuffer_init(zbuf, level, init_size)) {
|
if(!msgpack_zbuffer_init(zbuf, level, init_size)) {
|
||||||
free(zbuf);
|
free(zbuf);
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -123,7 +124,7 @@ bool msgpack_zbuffer_expand(msgpack_zbuffer* zbuf)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int msgpack_zbuffer_write(void* data, const char* buf, unsigned int len)
|
int msgpack_zbuffer_write(void* data, const char* buf, size_t len)
|
||||||
{
|
{
|
||||||
msgpack_zbuffer* zbuf = (msgpack_zbuffer*)data;
|
msgpack_zbuffer* zbuf = (msgpack_zbuffer*)data;
|
||||||
|
|
||||||
|
@@ -40,7 +40,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void write(const char* buf, unsigned int len)
|
void write(const char* buf, size_t len)
|
||||||
{
|
{
|
||||||
if(msgpack_zbuffer_write(this, buf, len) < 0) {
|
if(msgpack_zbuffer_write(this, buf, len) < 0) {
|
||||||
throw std::bad_alloc();
|
throw std::bad_alloc();
|
||||||
|
@@ -90,13 +90,14 @@ void* msgpack_zone_malloc_expand(msgpack_zone* zone, size_t size);
|
|||||||
|
|
||||||
void* msgpack_zone_malloc_no_align(msgpack_zone* zone, size_t size)
|
void* msgpack_zone_malloc_no_align(msgpack_zone* zone, size_t size)
|
||||||
{
|
{
|
||||||
|
char* ptr;
|
||||||
msgpack_zone_chunk_list* cl = &zone->chunk_list;
|
msgpack_zone_chunk_list* cl = &zone->chunk_list;
|
||||||
|
|
||||||
if(zone->chunk_list.free < size) {
|
if(zone->chunk_list.free < size) {
|
||||||
return msgpack_zone_malloc_expand(zone, size);
|
return msgpack_zone_malloc_expand(zone, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
char* ptr = cl->ptr;
|
ptr = cl->ptr;
|
||||||
cl->free -= size;
|
cl->free -= size;
|
||||||
cl->ptr += size;
|
cl->ptr += size;
|
||||||
|
|
||||||
|
464
src/msgpack/zone.hpp
Normal file
464
src/msgpack/zone.hpp
Normal file
@@ -0,0 +1,464 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ memory pool
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_ZONE_HPP__
|
||||||
|
#define MSGPACK_ZONE_HPP__
|
||||||
|
|
||||||
|
#include "zone.h"
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <memory>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
|
||||||
|
class zone : public msgpack_zone {
|
||||||
|
public:
|
||||||
|
zone(size_t chunk_size = MSGPACK_ZONE_CHUNK_SIZE);
|
||||||
|
~zone();
|
||||||
|
|
||||||
|
public:
|
||||||
|
void* malloc(size_t size);
|
||||||
|
void* malloc_no_align(size_t size);
|
||||||
|
|
||||||
|
void push_finalizer(void (*func)(void*), void* data);
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void push_finalizer(std::auto_ptr<T> obj);
|
||||||
|
|
||||||
|
void clear();
|
||||||
|
|
||||||
|
void swap(zone& o);
|
||||||
|
static void* operator new(std::size_t size) throw(std::bad_alloc)
|
||||||
|
{
|
||||||
|
void* p = ::malloc(size);
|
||||||
|
if (!p) throw std::bad_alloc();
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
static void operator delete(void *p) throw()
|
||||||
|
{
|
||||||
|
::free(p);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
T* allocate();
|
||||||
|
|
||||||
|
template <typename T, typename A1>
|
||||||
|
T* allocate(A1 a1);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2>
|
||||||
|
T* allocate(A1 a1, A2 a2);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13, A14 a14);
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15>
|
||||||
|
T* allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13, A14 a14, A15 a15);
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
void undo_malloc(size_t size);
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static void object_destructor(void* obj);
|
||||||
|
|
||||||
|
typedef msgpack_zone base;
|
||||||
|
|
||||||
|
private:
|
||||||
|
zone(const zone&);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
inline zone::zone(size_t chunk_size)
|
||||||
|
{
|
||||||
|
msgpack_zone_init(this, chunk_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline zone::~zone()
|
||||||
|
{
|
||||||
|
msgpack_zone_destroy(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void* zone::malloc(size_t size)
|
||||||
|
{
|
||||||
|
void* ptr = msgpack_zone_malloc(this, size);
|
||||||
|
if(!ptr) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void* zone::malloc_no_align(size_t size)
|
||||||
|
{
|
||||||
|
void* ptr = msgpack_zone_malloc_no_align(this, size);
|
||||||
|
if(!ptr) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::push_finalizer(void (*func)(void*), void* data)
|
||||||
|
{
|
||||||
|
if(!msgpack_zone_push_finalizer(this, func, data)) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline void zone::push_finalizer(std::auto_ptr<T> obj)
|
||||||
|
{
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, obj.get())) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
obj.release();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::clear()
|
||||||
|
{
|
||||||
|
msgpack_zone_clear(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::swap(zone& o)
|
||||||
|
{
|
||||||
|
msgpack_zone_swap(this, &o);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void zone::object_destructor(void* obj)
|
||||||
|
{
|
||||||
|
reinterpret_cast<T*>(obj)->~T();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::undo_malloc(size_t size)
|
||||||
|
{
|
||||||
|
base::chunk_list.ptr -= size;
|
||||||
|
base::chunk_list.free += size;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
T* zone::allocate()
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T();
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1>
|
||||||
|
T* zone::allocate(A1 a1)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13, A14 a14)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15>
|
||||||
|
T* zone::allocate(A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7, A8 a8, A9 a9, A10 a10, A11 a11, A12 a12, A13 a13, A14 a14, A15 a15)
|
||||||
|
{
|
||||||
|
void* x = malloc(sizeof(T));
|
||||||
|
if(!msgpack_zone_push_finalizer(this, &zone::object_destructor<T>, x)) {
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15);
|
||||||
|
} catch (...) {
|
||||||
|
--base::finalizer_array.tail;
|
||||||
|
undo_malloc(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif /* msgpack/zone.hpp */
|
||||||
|
|
@@ -44,7 +44,16 @@ public:
|
|||||||
void clear();
|
void clear();
|
||||||
|
|
||||||
void swap(zone& o);
|
void swap(zone& o);
|
||||||
|
static void* operator new(std::size_t size) throw(std::bad_alloc)
|
||||||
|
{
|
||||||
|
void* p = ::malloc(size);
|
||||||
|
if (!p) throw std::bad_alloc();
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
static void operator delete(void *p) throw()
|
||||||
|
{
|
||||||
|
::free(p);
|
||||||
|
}
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
T* allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>);
|
T* allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>);
|
||||||
|
10
src/unpack.c
10
src/unpack.c
@@ -56,7 +56,7 @@ static int template_execute(template_context* ctx,
|
|||||||
|
|
||||||
|
|
||||||
static inline msgpack_object template_callback_root(unpack_user* u)
|
static inline msgpack_object template_callback_root(unpack_user* u)
|
||||||
{ msgpack_object o = {}; return o; }
|
{ msgpack_object o = { MSGPACK_OBJECT_NIL }; return o; }
|
||||||
|
|
||||||
static inline int template_callback_uint8(unpack_user* u, uint8_t d, msgpack_object* o)
|
static inline int template_callback_uint8(unpack_user* u, uint8_t d, msgpack_object* o)
|
||||||
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
||||||
@@ -71,19 +71,19 @@ static inline int template_callback_uint64(unpack_user* u, uint64_t d, msgpack_o
|
|||||||
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
||||||
|
|
||||||
static inline int template_callback_int8(unpack_user* u, int8_t d, msgpack_object* o)
|
static inline int template_callback_int8(unpack_user* u, int8_t d, msgpack_object* o)
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = (uint64_t)d; return 0; }
|
||||||
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
||||||
|
|
||||||
static inline int template_callback_int16(unpack_user* u, int16_t d, msgpack_object* o)
|
static inline int template_callback_int16(unpack_user* u, int16_t d, msgpack_object* o)
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = (uint64_t)d; return 0; }
|
||||||
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
||||||
|
|
||||||
static inline int template_callback_int32(unpack_user* u, int32_t d, msgpack_object* o)
|
static inline int template_callback_int32(unpack_user* u, int32_t d, msgpack_object* o)
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = (uint64_t)d; return 0; }
|
||||||
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
||||||
|
|
||||||
static inline int template_callback_int64(unpack_user* u, int64_t d, msgpack_object* o)
|
static inline int template_callback_int64(unpack_user* u, int64_t d, msgpack_object* o)
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = (uint64_t)d; return 0; }
|
||||||
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
else { o->type = MSGPACK_OBJECT_NEGATIVE_INTEGER; o->via.i64 = d; return 0; } }
|
||||||
|
|
||||||
static inline int template_callback_float(unpack_user* u, float d, msgpack_object* o)
|
static inline int template_callback_float(unpack_user* u, float d, msgpack_object* o)
|
||||||
|
@@ -98,7 +98,7 @@ int msgpack_vrefbuffer_append_ref(msgpack_vrefbuffer* vbuf,
|
|||||||
const char* buf, size_t len)
|
const char* buf, size_t len)
|
||||||
{
|
{
|
||||||
if(vbuf->tail == vbuf->end) {
|
if(vbuf->tail == vbuf->end) {
|
||||||
const size_t nused = vbuf->tail - vbuf->array;
|
const size_t nused = (size_t)(vbuf->tail - vbuf->array);
|
||||||
const size_t nnext = nused * 2;
|
const size_t nnext = nused * 2;
|
||||||
|
|
||||||
struct iovec* nvec = (struct iovec*)realloc(
|
struct iovec* nvec = (struct iovec*)realloc(
|
||||||
@@ -169,11 +169,11 @@ int msgpack_vrefbuffer_migrate(msgpack_vrefbuffer* vbuf, msgpack_vrefbuffer* to)
|
|||||||
empty->next = NULL;
|
empty->next = NULL;
|
||||||
|
|
||||||
|
|
||||||
const size_t nused = vbuf->tail - vbuf->array;
|
const size_t nused = (size_t)(vbuf->tail - vbuf->array);
|
||||||
if(to->tail + nused < vbuf->end) {
|
if(to->tail + nused < vbuf->end) {
|
||||||
const size_t tosize = to->tail - to->array;
|
const size_t tosize = (size_t)(to->tail - to->array);
|
||||||
const size_t reqsize = nused + tosize;
|
const size_t reqsize = nused + tosize;
|
||||||
size_t nnext = (to->end - to->array) * 2;
|
size_t nnext = (size_t)(to->end - to->array) * 2;
|
||||||
while(nnext < reqsize) {
|
while(nnext < reqsize) {
|
||||||
nnext *= 2;
|
nnext *= 2;
|
||||||
}
|
}
|
||||||
|
@@ -84,9 +84,8 @@ void* msgpack_zone_malloc_expand(msgpack_zone* zone, size_t size)
|
|||||||
|
|
||||||
msgpack_zone_chunk* chunk = (msgpack_zone_chunk*)malloc(
|
msgpack_zone_chunk* chunk = (msgpack_zone_chunk*)malloc(
|
||||||
sizeof(msgpack_zone_chunk) + sz);
|
sizeof(msgpack_zone_chunk) + sz);
|
||||||
|
if (chunk == NULL) return NULL;
|
||||||
char* ptr = ((char*)chunk) + sizeof(msgpack_zone_chunk);
|
char* ptr = ((char*)chunk) + sizeof(msgpack_zone_chunk);
|
||||||
|
|
||||||
chunk->next = cl->head;
|
chunk->next = cl->head;
|
||||||
cl->head = chunk;
|
cl->head = chunk;
|
||||||
cl->free = sz - size;
|
cl->free = sz - size;
|
||||||
@@ -128,7 +127,7 @@ bool msgpack_zone_push_finalizer_expand(msgpack_zone* zone,
|
|||||||
{
|
{
|
||||||
msgpack_zone_finalizer_array* const fa = &zone->finalizer_array;
|
msgpack_zone_finalizer_array* const fa = &zone->finalizer_array;
|
||||||
|
|
||||||
const size_t nused = fa->end - fa->array;
|
const size_t nused = (size_t)(fa->end - fa->array);
|
||||||
|
|
||||||
size_t nnext;
|
size_t nnext;
|
||||||
if(nused == 0) {
|
if(nused == 0) {
|
||||||
|
55
test/CMakeLists.txt
Normal file
55
test/CMakeLists.txt
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
FIND_PACKAGE (GTest REQUIRED)
|
||||||
|
FIND_PACKAGE (ZLIB REQUIRED)
|
||||||
|
FIND_PACKAGE (Threads REQUIRED)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES (
|
||||||
|
${GTEST_INCLUDE_DIRS}
|
||||||
|
${ZLIB_INCLUDE_DIRS}
|
||||||
|
)
|
||||||
|
|
||||||
|
SET (check_PROGRAMS
|
||||||
|
pack_unpack.cc
|
||||||
|
version.cc
|
||||||
|
streaming_c.cc
|
||||||
|
pack_unpack_c.cc
|
||||||
|
zone.cc
|
||||||
|
msgpack_test.cpp
|
||||||
|
buffer.cc
|
||||||
|
msgpackc_test.cpp
|
||||||
|
streaming.cc
|
||||||
|
convert.cc
|
||||||
|
fixint_c.cc
|
||||||
|
)
|
||||||
|
|
||||||
|
IF (MSGPACK_ENABLE_CXX)
|
||||||
|
LIST (APPEND check_PROGRAMS
|
||||||
|
cases.cc
|
||||||
|
fixint.cc
|
||||||
|
object.cc
|
||||||
|
)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
FOREACH (source_file ${check_PROGRAMS})
|
||||||
|
GET_FILENAME_COMPONENT (source_file_we ${source_file} NAME_WE)
|
||||||
|
ADD_EXECUTABLE (
|
||||||
|
${source_file_we}
|
||||||
|
${source_file}
|
||||||
|
)
|
||||||
|
TARGET_LINK_LIBRARIES (${source_file_we}
|
||||||
|
msgpack
|
||||||
|
${GTEST_BOTH_LIBRARIES}
|
||||||
|
${ZLIB_LIBRARIES}
|
||||||
|
${CMAKE_THREAD_LIBS_INIT}
|
||||||
|
)
|
||||||
|
ADD_TEST (${source_file_we} ${source_file_we})
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
|
SET_PROPERTY (TARGET ${source_file_we} APPEND_STRING PROPERTY COMPILE_FLAGS "-Wall -g -O3")
|
||||||
|
ENDIF ()
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
||||||
|
IF (CMAKE_CXX_FLAGS MATCHES "/W[0-4]")
|
||||||
|
STRING(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
|
||||||
|
ELSE ()
|
||||||
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W4")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
ENDFOREACH ()
|
@@ -1,4 +1,6 @@
|
|||||||
#include <msgpack.hpp>
|
#include <msgpack.hpp>
|
||||||
|
#include <msgpack/fbuffer.hpp>
|
||||||
|
#include <msgpack/fbuffer.h>
|
||||||
#include <msgpack/zbuffer.hpp>
|
#include <msgpack/zbuffer.hpp>
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@@ -70,3 +72,49 @@ TEST(buffer, zbuffer)
|
|||||||
zbuf.flush();
|
zbuf.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST(buffer, fbuffer)
|
||||||
|
{
|
||||||
|
FILE* file = tmpfile();
|
||||||
|
EXPECT_TRUE( file != NULL );
|
||||||
|
|
||||||
|
msgpack::fbuffer fbuf(file);
|
||||||
|
EXPECT_EQ(file, fbuf.file());
|
||||||
|
|
||||||
|
fbuf.write("a", 1);
|
||||||
|
fbuf.write("a", 1);
|
||||||
|
fbuf.write("a", 1);
|
||||||
|
|
||||||
|
fflush(file);
|
||||||
|
rewind(file);
|
||||||
|
for (size_t i=0; i < 3; ++i) {
|
||||||
|
int ch = fgetc(file);
|
||||||
|
EXPECT_TRUE(ch != EOF);
|
||||||
|
EXPECT_EQ('a', static_cast<char>(ch));
|
||||||
|
}
|
||||||
|
EXPECT_EQ(EOF, fgetc(file));
|
||||||
|
fclose(file);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST(buffer, fbuffer_c)
|
||||||
|
{
|
||||||
|
FILE* file = tmpfile();
|
||||||
|
void* fbuf = (void*)file;
|
||||||
|
|
||||||
|
EXPECT_TRUE( file != NULL );
|
||||||
|
EXPECT_EQ(0, msgpack_fbuffer_write(fbuf, "a", 1));
|
||||||
|
EXPECT_EQ(0, msgpack_fbuffer_write(fbuf, "a", 1));
|
||||||
|
EXPECT_EQ(0, msgpack_fbuffer_write(fbuf, "a", 1));
|
||||||
|
|
||||||
|
fflush(file);
|
||||||
|
rewind(file);
|
||||||
|
for (size_t i=0; i < 3; ++i) {
|
||||||
|
int ch = fgetc(file);
|
||||||
|
EXPECT_TRUE(ch != EOF);
|
||||||
|
EXPECT_EQ('a', (char) ch);
|
||||||
|
}
|
||||||
|
EXPECT_EQ(EOF, fgetc(file));
|
||||||
|
fclose(file);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -7,6 +7,7 @@
|
|||||||
#include <deque>
|
#include <deque>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <list>
|
#include <list>
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
@@ -178,6 +179,57 @@ TEST(MSGPACK, simple_buffer_float)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
template<typename F, typename I>
|
||||||
|
struct TypePair {
|
||||||
|
typedef F float_type;
|
||||||
|
typedef I integer_type;
|
||||||
|
};
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
class IntegerToFloatingPointTest : public testing::Test {
|
||||||
|
};
|
||||||
|
TYPED_TEST_CASE_P(IntegerToFloatingPointTest);
|
||||||
|
|
||||||
|
TYPED_TEST_P(IntegerToFloatingPointTest, simple_buffer)
|
||||||
|
{
|
||||||
|
typedef typename TypeParam::float_type float_type;
|
||||||
|
typedef typename TypeParam::integer_type integer_type;
|
||||||
|
vector<integer_type> v;
|
||||||
|
v.push_back(0);
|
||||||
|
v.push_back(1);
|
||||||
|
if (numeric_limits<integer_type>::is_signed) v.push_back(-1);
|
||||||
|
else v.push_back(2);
|
||||||
|
for (unsigned int i = 0; i < kLoop; i++) {
|
||||||
|
v.push_back(rand() % 0x7FFFFF);
|
||||||
|
}
|
||||||
|
for (unsigned int i = 0; i < v.size() ; i++) {
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
integer_type val1 = v[i];
|
||||||
|
msgpack::pack(sbuf, val1);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj;
|
||||||
|
msgpack::unpack_return ret =
|
||||||
|
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &z, &obj);
|
||||||
|
EXPECT_EQ(msgpack::UNPACK_SUCCESS, ret);
|
||||||
|
float_type val2;
|
||||||
|
obj.convert(&val2);
|
||||||
|
EXPECT_TRUE(fabs(val2 - val1) <= kEPS);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
REGISTER_TYPED_TEST_CASE_P(IntegerToFloatingPointTest,
|
||||||
|
simple_buffer);
|
||||||
|
|
||||||
|
typedef testing::Types<TypePair<float, signed long long>,
|
||||||
|
TypePair<float, unsigned long long>,
|
||||||
|
TypePair<double, signed long long>,
|
||||||
|
TypePair<double, unsigned long long> > IntegerToFloatingPointTestTypes;
|
||||||
|
INSTANTIATE_TYPED_TEST_CASE_P(IntegerToFloatingPointTestInstance,
|
||||||
|
IntegerToFloatingPointTest,
|
||||||
|
IntegerToFloatingPointTestTypes);
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_double)
|
TEST(MSGPACK, simple_buffer_double)
|
||||||
{
|
{
|
||||||
vector<double> v;
|
vector<double> v;
|
||||||
@@ -452,10 +504,10 @@ TEST(MSGPACK_STL, simple_buffer_multiset)
|
|||||||
|
|
||||||
// TR1
|
// TR1
|
||||||
|
|
||||||
#ifdef HAVE_TR1_UNORDERED_MAP
|
#ifdef MSGPACK_HAS_STD_TR1_UNOURDERED_MAP
|
||||||
#include <tr1/unordered_map>
|
#include <tr1/unordered_map>
|
||||||
#include "msgpack/type/tr1/unordered_map.hpp"
|
#include "msgpack/type/tr1/unordered_map.hpp"
|
||||||
TEST(MSGPACK_TR1, simple_buffer_unordered_map)
|
TEST(MSGPACK_TR1, simple_buffer_tr1_unordered_map)
|
||||||
{
|
{
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
tr1::unordered_map<int, int> val1;
|
tr1::unordered_map<int, int> val1;
|
||||||
@@ -479,7 +531,7 @@ TEST(MSGPACK_TR1, simple_buffer_unordered_map)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(MSGPACK_TR1, simple_buffer_unordered_multimap)
|
TEST(MSGPACK_TR1, simple_buffer_tr1_unordered_multimap)
|
||||||
{
|
{
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
tr1::unordered_multimap<int, int> val1;
|
tr1::unordered_multimap<int, int> val1;
|
||||||
@@ -513,10 +565,10 @@ TEST(MSGPACK_TR1, simple_buffer_unordered_multimap)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_TR1_UNORDERED_SET
|
#ifdef MSGPACK_HAS_STD_TR1_UNOURDERED_SET
|
||||||
#include <tr1/unordered_set>
|
#include <tr1/unordered_set>
|
||||||
#include "msgpack/type/tr1/unordered_set.hpp"
|
#include "msgpack/type/tr1/unordered_set.hpp"
|
||||||
TEST(MSGPACK_TR1, simple_buffer_unordered_set)
|
TEST(MSGPACK_TR1, simple_buffer_tr1_unordered_set)
|
||||||
{
|
{
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
tr1::unordered_set<int> val1;
|
tr1::unordered_set<int> val1;
|
||||||
@@ -538,7 +590,7 @@ TEST(MSGPACK_TR1, simple_buffer_unordered_set)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(MSGPACK_TR1, simple_buffer_unordered_multiset)
|
TEST(MSGPACK_TR1, simple_buffer_tr1_unordered_multiset)
|
||||||
{
|
{
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
tr1::unordered_multiset<int> val1;
|
tr1::unordered_multiset<int> val1;
|
||||||
@@ -569,6 +621,123 @@ TEST(MSGPACK_TR1, simple_buffer_unordered_multiset)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef MSGPACK_HAS_STD_UNOURDERED_MAP
|
||||||
|
#include <unordered_map>
|
||||||
|
#include "msgpack/type/tr1/unordered_map.hpp"
|
||||||
|
TEST(MSGPACK_TR1, simple_buffer_unordered_map)
|
||||||
|
{
|
||||||
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
|
unordered_map<int, int> val1;
|
||||||
|
for (unsigned int i = 0; i < kElements; i++)
|
||||||
|
val1[rand()] = rand();
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, val1);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj;
|
||||||
|
msgpack::unpack_return ret =
|
||||||
|
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &z, &obj);
|
||||||
|
EXPECT_EQ(msgpack::UNPACK_SUCCESS, ret);
|
||||||
|
unordered_map<int, int> val2;
|
||||||
|
obj.convert(&val2);
|
||||||
|
EXPECT_EQ(val1.size(), val2.size());
|
||||||
|
unordered_map<int, int>::const_iterator it;
|
||||||
|
for (it = val1.begin(); it != val1.end(); ++it) {
|
||||||
|
EXPECT_TRUE(val2.find(it->first) != val2.end());
|
||||||
|
EXPECT_EQ(it->second, val2.find(it->first)->second);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(MSGPACK_TR1, simple_buffer_unordered_multimap)
|
||||||
|
{
|
||||||
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
|
unordered_multimap<int, int> val1;
|
||||||
|
for (unsigned int i = 0; i < kElements; i++) {
|
||||||
|
int i1 = rand();
|
||||||
|
val1.insert(make_pair(i1, rand()));
|
||||||
|
val1.insert(make_pair(i1, rand()));
|
||||||
|
}
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, val1);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj;
|
||||||
|
msgpack::unpack_return ret =
|
||||||
|
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &z, &obj);
|
||||||
|
EXPECT_EQ(msgpack::UNPACK_SUCCESS, ret);
|
||||||
|
unordered_multimap<int, int> val2;
|
||||||
|
obj.convert(&val2);
|
||||||
|
|
||||||
|
vector<pair<int, int> > v1, v2;
|
||||||
|
unordered_multimap<int, int>::const_iterator it;
|
||||||
|
for (it = val1.begin(); it != val1.end(); ++it)
|
||||||
|
v1.push_back(make_pair(it->first, it->second));
|
||||||
|
for (it = val2.begin(); it != val2.end(); ++it)
|
||||||
|
v2.push_back(make_pair(it->first, it->second));
|
||||||
|
EXPECT_EQ(val1.size(), val2.size());
|
||||||
|
EXPECT_EQ(v1.size(), v2.size());
|
||||||
|
sort(v1.begin(), v1.end());
|
||||||
|
sort(v2.begin(), v2.end());
|
||||||
|
EXPECT_TRUE(v1 == v2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MSGPACK_HAS_STD_UNOURDERED_SET
|
||||||
|
#include <unordered_set>
|
||||||
|
#include "msgpack/type/tr1/unordered_set.hpp"
|
||||||
|
TEST(MSGPACK_TR1, simple_buffer_unordered_set)
|
||||||
|
{
|
||||||
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
|
unordered_set<int> val1;
|
||||||
|
for (unsigned int i = 0; i < kElements; i++)
|
||||||
|
val1.insert(rand());
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, val1);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj;
|
||||||
|
msgpack::unpack_return ret =
|
||||||
|
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &z, &obj);
|
||||||
|
EXPECT_EQ(msgpack::UNPACK_SUCCESS, ret);
|
||||||
|
unordered_set<int> val2;
|
||||||
|
obj.convert(&val2);
|
||||||
|
EXPECT_EQ(val1.size(), val2.size());
|
||||||
|
unordered_set<int>::const_iterator it;
|
||||||
|
for (it = val1.begin(); it != val1.end(); ++it)
|
||||||
|
EXPECT_TRUE(val2.find(*it) != val2.end());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(MSGPACK_TR1, simple_buffer_unordered_multiset)
|
||||||
|
{
|
||||||
|
for (unsigned int k = 0; k < kLoop; k++) {
|
||||||
|
unordered_multiset<int> val1;
|
||||||
|
for (unsigned int i = 0; i < kElements; i++)
|
||||||
|
val1.insert(rand());
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, val1);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj;
|
||||||
|
msgpack::unpack_return ret =
|
||||||
|
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &z, &obj);
|
||||||
|
EXPECT_EQ(msgpack::UNPACK_SUCCESS, ret);
|
||||||
|
unordered_multiset<int> val2;
|
||||||
|
obj.convert(&val2);
|
||||||
|
|
||||||
|
vector<int> v1, v2;
|
||||||
|
unordered_multiset<int>::const_iterator it;
|
||||||
|
for (it = val1.begin(); it != val1.end(); ++it)
|
||||||
|
v1.push_back(*it);
|
||||||
|
for (it = val2.begin(); it != val2.end(); ++it)
|
||||||
|
v2.push_back(*it);
|
||||||
|
EXPECT_EQ(val1.size(), val2.size());
|
||||||
|
EXPECT_EQ(v1.size(), v2.size());
|
||||||
|
sort(v1.begin(), v1.end());
|
||||||
|
sort(v2.begin(), v2.end());
|
||||||
|
EXPECT_TRUE(v1 == v2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// User-Defined Structures
|
// User-Defined Structures
|
||||||
|
|
||||||
class TestClass
|
class TestClass
|
||||||
@@ -672,9 +841,11 @@ public:
|
|||||||
TestEnumType t2;
|
TestEnumType t2;
|
||||||
TestEnumType t3;
|
TestEnumType t3;
|
||||||
|
|
||||||
MSGPACK_DEFINE((int&)t1, (int&)t2, (int&)t3);
|
MSGPACK_DEFINE(t1, t2, t3);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
MSGPACK_ADD_ENUM(TestEnumMemberClass::TestEnumType);
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_enum_member)
|
TEST(MSGPACK_USER_DEFINED, simple_buffer_enum_member)
|
||||||
{
|
{
|
||||||
TestEnumMemberClass val1;
|
TestEnumMemberClass val1;
|
||||||
|
@@ -1,22 +1,27 @@
|
|||||||
#include <msgpack.hpp>
|
#include <msgpack.hpp>
|
||||||
|
#include <msgpack/type.hpp>
|
||||||
|
#include <vector>
|
||||||
|
#include <map>
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
struct myclass {
|
struct myclass {
|
||||||
myclass() : num(0), str("default") { }
|
myclass() : num(0), str("default") { }
|
||||||
|
|
||||||
myclass(int num, const std::string& str) :
|
myclass(int n, const std::string& s) :
|
||||||
num(0), str("default") { }
|
num(n), str(s) { }
|
||||||
|
|
||||||
~myclass() { }
|
~myclass() { }
|
||||||
|
|
||||||
int num;
|
int num;
|
||||||
std::string str;
|
std::string str;
|
||||||
|
std::vector<double> vec;
|
||||||
|
std::map<std::string, std::string> map;
|
||||||
|
|
||||||
MSGPACK_DEFINE(num, str);
|
MSGPACK_DEFINE(num, str, vec, map);
|
||||||
|
|
||||||
bool operator==(const myclass& o) const
|
bool operator==(const myclass& o) const
|
||||||
{
|
{
|
||||||
return num == o.num && str == o.str;
|
return num == o.num && str == o.str && vec == o.vec && map == o.map;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -28,7 +33,7 @@ std::ostream& operator<<(std::ostream& o, const myclass& m)
|
|||||||
|
|
||||||
TEST(object, convert)
|
TEST(object, convert)
|
||||||
{
|
{
|
||||||
myclass m1;
|
myclass m1(1, "custom");
|
||||||
|
|
||||||
msgpack::sbuffer sbuf;
|
msgpack::sbuffer sbuf;
|
||||||
msgpack::pack(sbuf, m1);
|
msgpack::pack(sbuf, m1);
|
||||||
@@ -49,7 +54,7 @@ TEST(object, convert)
|
|||||||
|
|
||||||
TEST(object, as)
|
TEST(object, as)
|
||||||
{
|
{
|
||||||
myclass m1;
|
myclass m1(1, "custom");
|
||||||
|
|
||||||
msgpack::sbuffer sbuf;
|
msgpack::sbuffer sbuf;
|
||||||
msgpack::pack(sbuf, m1);
|
msgpack::pack(sbuf, m1);
|
||||||
@@ -65,6 +70,37 @@ TEST(object, as)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST(object, cross_zone_copy)
|
||||||
|
{
|
||||||
|
myclass m1(1, "custom");
|
||||||
|
m1.vec.push_back(1.0);
|
||||||
|
m1.vec.push_back(0.1);
|
||||||
|
m1.map["one"] = "two";
|
||||||
|
|
||||||
|
msgpack::zone z1;
|
||||||
|
msgpack::object::with_zone obj1(&z1);
|
||||||
|
|
||||||
|
{
|
||||||
|
msgpack::zone z2;
|
||||||
|
msgpack::object::with_zone obj2(&z2);
|
||||||
|
obj2 << m1;
|
||||||
|
|
||||||
|
obj1 << obj2;
|
||||||
|
|
||||||
|
EXPECT_EQ(obj1.via.array.ptr[2].via.array.ptr[0].via.dec, 1.0);
|
||||||
|
EXPECT_EQ(obj1.via.array.ptr[3].via.map.ptr[0].val.via.raw.ptr[0], 't');
|
||||||
|
EXPECT_NE(
|
||||||
|
obj1.via.array.ptr[2].via.array.ptr,
|
||||||
|
obj2.via.array.ptr[2].via.array.ptr);
|
||||||
|
EXPECT_NE(
|
||||||
|
obj1.via.array.ptr[3].via.map.ptr[0].val.via.raw.ptr,
|
||||||
|
obj2.via.array.ptr[3].via.map.ptr[0].val.via.raw.ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
EXPECT_EQ(m1, obj1.as<myclass>());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
TEST(object, print)
|
TEST(object, print)
|
||||||
{
|
{
|
||||||
msgpack::object obj;
|
msgpack::object obj;
|
||||||
|
@@ -31,7 +31,7 @@ struct myclass {
|
|||||||
myclass() : num(0), str("default") { }
|
myclass() : num(0), str("default") { }
|
||||||
|
|
||||||
myclass(int num, const std::string& str) :
|
myclass(int num, const std::string& str) :
|
||||||
num(0), str("default") { }
|
num(num), str(str) { }
|
||||||
|
|
||||||
~myclass() { }
|
~myclass() { }
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user