mirror of
https://github.com/msgpack/msgpack-c.git
synced 2025-10-24 00:49:47 +02:00
Compare commits
1395 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
52d5591ded | ||
|
|
6ec09053b1 | ||
|
|
5401660b07 | ||
|
|
f3caa8e160 | ||
|
|
8921f9dcfc | ||
|
|
7bee573a72 | ||
|
|
5568abb6ab | ||
|
|
67486480ac | ||
|
|
0e3bb789b8 | ||
|
|
e1eabbfebf | ||
|
|
e416b534b8 | ||
|
|
212ef8eb2b | ||
|
|
7bf06a5885 | ||
|
|
1822523289 | ||
|
|
156a4403ab | ||
|
|
ad5da7f131 | ||
|
|
62be3f1212 | ||
|
|
8dbe25a51d | ||
|
|
7cfd4bb1d8 | ||
|
|
037a108c49 | ||
|
|
79a127a8b6 | ||
|
|
ace27f6238 | ||
|
|
cc2ded6338 | ||
|
|
13a746f6fa | ||
|
|
b0ff2802d2 | ||
|
|
4b0c90fc90 | ||
|
|
4b11fb32cd | ||
|
|
f707c6b47c | ||
|
|
081ee0e99a | ||
|
|
8eaa2e9e74 | ||
|
|
ac1eb6e1d3 | ||
|
|
343ceabe9a | ||
|
|
eb765d21f2 | ||
|
|
2d5c68055c | ||
|
|
de68fbd6d0 | ||
|
|
118cf7270c | ||
|
|
cf1487f8ba | ||
|
|
e4cd479bf3 | ||
|
|
8dae63e4c1 | ||
|
|
a3f350842c | ||
|
|
c1e9f92d7f | ||
|
|
582fe38e78 | ||
|
|
6443738f66 | ||
|
|
45eb2ad0c7 | ||
|
|
37593400c3 | ||
|
|
60648fc3a8 | ||
|
|
0482e4fcd1 | ||
|
|
82a10cba5c | ||
|
|
0d9a21ea08 | ||
|
|
f399ec8c30 | ||
|
|
8ad9ce059b | ||
|
|
a4aa14d1e2 | ||
|
|
f7f2d4b990 | ||
|
|
c675881f3b | ||
|
|
f6d0cd9a4b | ||
|
|
4ef5894856 | ||
|
|
07ddfa1430 | ||
|
|
252d66a4b2 | ||
|
|
b4eba4ba09 | ||
|
|
2266505eed | ||
|
|
46e2398e02 | ||
|
|
3662a17e81 | ||
|
|
66f221d088 | ||
|
|
9ed4e443fb | ||
|
|
15aec0493d | ||
|
|
d6a7bd1995 | ||
|
|
ff86d61799 | ||
|
|
97886c50e7 | ||
|
|
327b0db626 | ||
|
|
994144dac2 | ||
|
|
023f81ae9c | ||
|
|
83fac26762 | ||
|
|
213ba44b65 | ||
|
|
fa231139d7 | ||
|
|
5cd1c6bfa1 | ||
|
|
c4fb47c00d | ||
|
|
70e50d9679 | ||
|
|
978e6b9057 | ||
|
|
571f1a27a2 | ||
|
|
c3518c0666 | ||
|
|
64ac09c492 | ||
|
|
414da4e8c6 | ||
|
|
3eadb124fc | ||
|
|
fd9eb26688 | ||
|
|
6c59e5195a | ||
|
|
3bdf646cc6 | ||
|
|
2bbf10a324 | ||
|
|
737e6703df | ||
|
|
7f48ddc85e | ||
|
|
a84f444ce2 | ||
|
|
7e597779e4 | ||
|
|
bf8c830eef | ||
|
|
5f52ec5030 | ||
|
|
c71ce9eb49 | ||
|
|
f105b4bbb0 | ||
|
|
f64be3b2d0 | ||
|
|
abac9fe90a | ||
|
|
5798fa0e47 | ||
|
|
fe4af1125d | ||
|
|
ce96ca8bfc | ||
|
|
57732f0c1b | ||
|
|
7ccef5b787 | ||
|
|
1a116fb644 | ||
|
|
f79fd82953 | ||
|
|
b9a80697bc | ||
|
|
467822c97a | ||
|
|
7ab7eaf61b | ||
|
|
3ed6b673d4 | ||
|
|
469040be6b | ||
|
|
309e96087a | ||
|
|
2d61fdf865 | ||
|
|
6e560e345a | ||
|
|
8b796dc788 | ||
|
|
240b02174d | ||
|
|
38a380684e | ||
|
|
1a615af437 | ||
|
|
9162610682 | ||
|
|
c52a58b322 | ||
|
|
ac3433f5dd | ||
|
|
dab725624e | ||
|
|
037b1c22dc | ||
|
|
0de0b434b3 | ||
|
|
7eb3d2aa59 | ||
|
|
0827d08cd7 | ||
|
|
3d20ec6f21 | ||
|
|
bcdbf78542 | ||
|
|
a4af97b32c | ||
|
|
e00b299fe0 | ||
|
|
d6cc5494a9 | ||
|
|
96c688708c | ||
|
|
79e7a9810c | ||
|
|
a0ae0289dc | ||
|
|
31a3d34b49 | ||
|
|
1c54d804f5 | ||
|
|
111efdf50f | ||
|
|
dac8f6290d | ||
|
|
3bfd142660 | ||
|
|
d031162d96 | ||
|
|
8e24d9206a | ||
|
|
b78b49a7bd | ||
|
|
561e9ba105 | ||
|
|
6e84266043 | ||
|
|
151c92d08d | ||
|
|
1285470c21 | ||
|
|
837c5ecfc3 | ||
|
|
04aa309f24 | ||
|
|
69b2ea4002 | ||
|
|
8ddc219365 | ||
|
|
a9cf916b82 | ||
|
|
8455a2eb70 | ||
|
|
5c0f1db25c | ||
|
|
466986b519 | ||
|
|
a6aac482dd | ||
|
|
bb984d3445 | ||
|
|
f8e2766d28 | ||
|
|
2d5d12f9a6 | ||
|
|
11a2a1b8ec | ||
|
|
b5e66150e9 | ||
|
|
e21e3245db | ||
|
|
07e7ad6b7e | ||
|
|
44b524529d | ||
|
|
fc65bc0682 | ||
|
|
ca12e6d39d | ||
|
|
db8578a62b | ||
|
|
4a292193f2 | ||
|
|
1e7fbc0349 | ||
|
|
479d50bd93 | ||
|
|
982787865f | ||
|
|
bf4a57da34 | ||
|
|
2fcbe6116d | ||
|
|
4c00f448aa | ||
|
|
3ddeb08e6e | ||
|
|
0176dd760a | ||
|
|
d30548af3f | ||
|
|
ab12b2b2b9 | ||
|
|
7ce69a362f | ||
|
|
cc08146b1c | ||
|
|
6896cc602f | ||
|
|
d8f366daf2 | ||
|
|
ef649009e4 | ||
|
|
cd03ab62f8 | ||
|
|
44e41efa0c | ||
|
|
ecf4b09acd | ||
|
|
d6122b4a18 | ||
|
|
4fcb4777f3 | ||
|
|
03ed30ce03 | ||
|
|
6e810df2a4 | ||
|
|
847a7852e5 | ||
|
|
e265beef91 | ||
|
|
0335df55e1 | ||
|
|
dd4043a616 | ||
|
|
6a8412d6de | ||
|
|
7491c1996a | ||
|
|
0ab14b4138 | ||
|
|
6e77c6df11 | ||
|
|
bcc91d78e9 | ||
|
|
32b65dba47 | ||
|
|
aa75e6ecd3 | ||
|
|
dc679a2572 | ||
|
|
b6bc7f7ecb | ||
|
|
896dead7cc | ||
|
|
dfa277a9e0 | ||
|
|
501260eb54 | ||
|
|
370a9251f5 | ||
|
|
7737f1cb77 | ||
|
|
f72022037c | ||
|
|
865528f778 | ||
|
|
d54048eabe | ||
|
|
103a6c56e4 | ||
|
|
11f1d5fbbd | ||
|
|
7ebdb63131 | ||
|
|
a186725213 | ||
|
|
8615358515 | ||
|
|
86ad026f11 | ||
|
|
93d0f0bd00 | ||
|
|
a0f5392876 | ||
|
|
5896ff3746 | ||
|
|
d15e49cb73 | ||
|
|
2103c12e05 | ||
|
|
f0a12a23a1 | ||
|
|
30b946ee85 | ||
|
|
a388000d47 | ||
|
|
4c888294b5 | ||
|
|
68bf4acb4b | ||
|
|
2c2df64427 | ||
|
|
4d6e9d6c05 | ||
|
|
f969f6f39c | ||
|
|
8920c49597 | ||
|
|
e18102d16f | ||
|
|
ea23bf843e | ||
|
|
e217e72c22 | ||
|
|
0bc4b3f599 | ||
|
|
b2f5893669 | ||
|
|
9a1ccaf155 | ||
|
|
0201c21b9a | ||
|
|
dee68403df | ||
|
|
0a99b9f933 | ||
|
|
17e696fc0d | ||
|
|
b5b459cfca | ||
|
|
7822bc787d | ||
|
|
1f5d6b9cac | ||
|
|
ce21ab0ebf | ||
|
|
5af6d36341 | ||
|
|
15a0d61a64 | ||
|
|
66014eebc0 | ||
|
|
fd566afeb4 | ||
|
|
e4d32b176e | ||
|
|
b27c87c9ed | ||
|
|
3729f334a1 | ||
|
|
55bf279a7c | ||
|
|
78e8cbdfb5 | ||
|
|
dd083ca933 | ||
|
|
23d670f3bd | ||
|
|
6fab3594a2 | ||
|
|
421aeb5021 | ||
|
|
47f4ffe9f3 | ||
|
|
09325ed846 | ||
|
|
bfa428ab13 | ||
|
|
ecdeec9948 | ||
|
|
f11a811114 | ||
|
|
c203928fae | ||
|
|
59b111e026 | ||
|
|
2a694f8c20 | ||
|
|
0380215982 | ||
|
|
0e48f65a4b | ||
|
|
aa79fc2ff4 | ||
|
|
cc571b8bb1 | ||
|
|
b0df21295c | ||
|
|
0889e6117e | ||
|
|
212f025f00 | ||
|
|
f6a5402194 | ||
|
|
6a349d0b28 | ||
|
|
dac5c60608 | ||
|
|
bc33317b7e | ||
|
|
754b1682a5 | ||
|
|
cb9eed8ccc | ||
|
|
862905742f | ||
|
|
ba98315f65 | ||
|
|
124a871923 | ||
|
|
378f6afccd | ||
|
|
1320863cb3 | ||
|
|
a951ea90b8 | ||
|
|
3b7a2f8f32 | ||
|
|
038c3e3518 | ||
|
|
c08439ff41 | ||
|
|
59d994ea5f | ||
|
|
ed51d23335 | ||
|
|
2be892bfda | ||
|
|
723d900098 | ||
|
|
13404a7444 | ||
|
|
a20594dfdc | ||
|
|
bff4cadeff | ||
|
|
6515577dc3 | ||
|
|
beebccd323 | ||
|
|
d70c44b723 | ||
|
|
33d3192ca2 | ||
|
|
0d13931844 | ||
|
|
293c839a22 | ||
|
|
f187ae35d9 | ||
|
|
74013e7e7d | ||
|
|
e2026c0507 | ||
|
|
c375e14705 | ||
|
|
fade0644c7 | ||
|
|
5fedaf285b | ||
|
|
fe82444db1 | ||
|
|
f7692691ca | ||
|
|
7fba3484c5 | ||
|
|
561b6b583d | ||
|
|
7675c15fa9 | ||
|
|
99971abc9b | ||
|
|
b7a1ba9ba0 | ||
|
|
63c26cd58b | ||
|
|
f8fc03b482 | ||
|
|
b0b1a0e9a7 | ||
|
|
4d2a9c23af | ||
|
|
c41154989a | ||
|
|
541ece13c0 | ||
|
|
b6b2ef5e57 | ||
|
|
4ef69da25d | ||
|
|
9bd339baf8 | ||
|
|
616be1aa60 | ||
|
|
415b14335f | ||
|
|
1fb707f93f | ||
|
|
aa4ed82b66 | ||
|
|
7ce8abe5d6 | ||
|
|
27629a8dd6 | ||
|
|
521a4f4190 | ||
|
|
bad3801eae | ||
|
|
72b3064a67 | ||
|
|
7593e5ce0e | ||
|
|
8a08548f36 | ||
|
|
56b0ad6809 | ||
|
|
f8561fbfd5 | ||
|
|
e80cbd4437 | ||
|
|
da601e4589 | ||
|
|
36a87b6968 | ||
|
|
e0b42939ba | ||
|
|
7d731f83a4 | ||
|
|
40ad7da455 | ||
|
|
e0d1e5c722 | ||
|
|
5b3a168b86 | ||
|
|
11afd4820f | ||
|
|
ec5c1194fc | ||
|
|
7eccd1029a | ||
|
|
c2ca709d68 | ||
|
|
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 | ||
|
|
0c60cfc5c0 | ||
|
|
deb6b0e334 | ||
|
|
27777dcd31 | ||
|
|
bdb397e043 | ||
|
|
cb4d851761 | ||
|
|
17aa517e41 | ||
|
|
7ac16f4834 | ||
|
|
bf7fece440 | ||
|
|
c04ef9efe5 | ||
|
|
b774c07d19 | ||
|
|
229467cb29 | ||
|
|
949b472f7e | ||
|
|
be67d3e362 | ||
|
|
2c1a1fd4f8 | ||
|
|
3e2ae7cc78 | ||
|
|
505660e1fa | ||
|
|
09d90e1231 | ||
|
|
5a9f89ae1f | ||
|
|
6f56345dd8 | ||
|
|
edef040688 | ||
|
|
9fc196e750 | ||
|
|
dc1698eaf4 | ||
|
|
53ded063a0 | ||
|
|
8a2c50c374 | ||
|
|
f71148f3a6 | ||
|
|
172105828c | ||
|
|
6cca6cb20d | ||
|
|
b7336f817c | ||
|
|
88356b79be | ||
|
|
ce9e543882 | ||
|
|
3ff3ba83f4 | ||
|
|
edb525a030 | ||
|
|
ea5314f076 | ||
|
|
be8e53163b | ||
|
|
79151f517f | ||
|
|
e8ffe7ef96 | ||
|
|
b5a7b5e277 | ||
|
|
85b5e1088f | ||
|
|
680ddb1557 | ||
|
|
44fff522bd | ||
|
|
90815f0d27 | ||
|
|
f07950c60a | ||
|
|
f8c4125892 | ||
|
|
1f30cc203a | ||
|
|
764bfdcb9f | ||
|
|
f290814f64 | ||
|
|
3a2508545d | ||
|
|
79a06a338a | ||
|
|
509f27eee1 | ||
|
|
e511c32a36 | ||
|
|
b463d9b687 | ||
|
|
e96e20ccfd | ||
|
|
06ebdbfd37 | ||
|
|
df9fd047b4 | ||
|
|
85d65c59d2 | ||
|
|
754126644f | ||
|
|
220436f4f9 | ||
|
|
b62a6ae1d0 | ||
|
|
eae0532b8c | ||
|
|
d642487f99 | ||
|
|
320510506b | ||
|
|
b2839ac78b | ||
|
|
834d5a0e72 | ||
|
|
13ce808c47 | ||
|
|
980a6529c1 | ||
|
|
c92384fe68 | ||
|
|
9f563f87b9 | ||
|
|
44f37b8d1b | ||
|
|
5f41c1cf3f | ||
|
|
2a664b9ae6 | ||
|
|
5456814199 | ||
|
|
33ceaeb208 | ||
|
|
b33e60b3ae | ||
|
|
9dd0a6eb86 | ||
|
|
ed6faf4e65 | ||
|
|
df2ee5de49 | ||
|
|
36fef91a67 | ||
|
|
3399148d75 | ||
|
|
0eea92de66 | ||
|
|
92975bb21d | ||
|
|
bf18e04134 | ||
|
|
4a0d7f18fd | ||
|
|
65c360a2ca | ||
|
|
71919f7523 | ||
|
|
31a49db68b | ||
|
|
0d615442ba | ||
|
|
8f35dbc306 | ||
|
|
154bcbc4f7 | ||
|
|
c96a39d315 | ||
|
|
06ba74c366 | ||
|
|
8786a8e6e0 | ||
|
|
748236fef0 | ||
|
|
ae1b06f20b | ||
|
|
b8aa93ce30 | ||
|
|
49d40a42f1 | ||
|
|
1845f34b81 | ||
|
|
43903d446a | ||
|
|
256da2124b | ||
|
|
7869e96bac | ||
|
|
79b51a6e4b | ||
|
|
cad9f6d46e | ||
|
|
da2960880a | ||
|
|
0eacc58e29 | ||
|
|
3bec736aee | ||
|
|
3241ffd1b4 | ||
|
|
d0d7b266bc | ||
|
|
c24948258b | ||
|
|
d36666bd98 | ||
|
|
2794b1d310 | ||
|
|
f456fa03da | ||
|
|
356b7b43f8 | ||
|
|
92718e2140 | ||
|
|
4021160a64 | ||
|
|
6f043e3326 | ||
|
|
74b0b1da21 | ||
|
|
3a5f676687 | ||
|
|
4fa7cffc37 | ||
|
|
79b83e78a5 | ||
|
|
048a3835e7 | ||
|
|
4a4891036a | ||
|
|
ff00c83f15 | ||
|
|
79d31b7452 | ||
|
|
20cc6f7463 | ||
|
|
8acabaa135 | ||
|
|
ba7183a5b4 | ||
|
|
28f4338a6c | ||
|
|
800a93a859 | ||
|
|
2e969e3a0a | ||
|
|
3fb31f651d | ||
|
|
682d25b551 | ||
|
|
bcad8d4c4c | ||
|
|
96bab8e02e | ||
|
|
fa4a615d0f | ||
|
|
f1265c4fed | ||
|
|
df01cd9a09 | ||
|
|
255bac642d | ||
|
|
6d8c3bd13d | ||
|
|
75b8272710 | ||
|
|
2f80e154f2 | ||
|
|
cc0114c482 | ||
|
|
e5e2b9095c | ||
|
|
6977edc032 | ||
|
|
177cc55ee5 | ||
|
|
feb7ec03ba | ||
|
|
6630a643d3 | ||
|
|
d70e64a434 | ||
|
|
896ad51102 | ||
|
|
be6d6560a7 | ||
|
|
709d0cc33e | ||
|
|
bd73742552 | ||
|
|
ed4518e09a | ||
|
|
6c8301eae8 | ||
|
|
6e30d504e3 | ||
|
|
cee09a0261 | ||
|
|
76a72558b3 | ||
|
|
22124a33ce | ||
|
|
3731373de1 | ||
|
|
bbaf8c2f67 | ||
|
|
f50694cc96 | ||
|
|
4930ea7dab | ||
|
|
96bb4cf49d | ||
|
|
5e7563ac5b | ||
|
|
f199b80453 | ||
|
|
5de8eec206 | ||
|
|
076bd07f39 | ||
|
|
00e897503b | ||
|
|
2f3c47f385 | ||
|
|
2b28211701 | ||
|
|
46c794fc2e | ||
|
|
0408738b48 | ||
|
|
6cfea98501 | ||
|
|
33498d3673 | ||
|
|
ed3ead06fe | ||
|
|
eb8a338a0e | ||
|
|
23480bfe8a | ||
|
|
3384dbc92d | ||
|
|
8446549ed8 | ||
|
|
6a9f3ae71d | ||
|
|
94e5b0d78f | ||
|
|
0812eb1c04 | ||
|
|
8cb5ccad99 | ||
|
|
743d69ec0b | ||
|
|
f6de4c9479 | ||
|
|
fb59927d32 | ||
|
|
c58ce1a975 | ||
|
|
c6d9bbd7b0 | ||
|
|
08974f00ed | ||
|
|
60643f023f | ||
|
|
65ddd1a455 | ||
|
|
68a98d3dd0 | ||
|
|
ca9015452e | ||
|
|
05ac2603e6 | ||
|
|
8e923777b8 | ||
|
|
8949551c2e | ||
|
|
0b45e9442b | ||
|
|
1d1a9d7933 | ||
|
|
58c0fe0f91 | ||
|
|
b96b62f2ac | ||
|
|
43fc0a52a6 | ||
|
|
4f3d9a1ded | ||
|
|
b50ff920f0 | ||
|
|
983ae0c5a2 | ||
|
|
9d4db84987 | ||
|
|
1f372cf0cc | ||
|
|
c43d597aa9 | ||
|
|
dfaa281476 | ||
|
|
df14629a25 | ||
|
|
c1c25c455c | ||
|
|
e65197f386 | ||
|
|
ecbb8f8711 | ||
|
|
03aa736199 | ||
|
|
821b1f0384 | ||
|
|
233ad3aaff | ||
|
|
9c4812f4d4 | ||
|
|
337cc9fa78 | ||
|
|
dfe29a0329 | ||
|
|
85e90aa81e | ||
|
|
86d30fe571 | ||
|
|
173302267f | ||
|
|
8e3ea8d26c | ||
|
|
cb065563c2 | ||
|
|
27b89b237b | ||
|
|
21f0d0bfc4 | ||
|
|
d5e583b09e | ||
|
|
15fb9bbcb2 | ||
|
|
a03418ab12 | ||
|
|
035513844d | ||
|
|
193906b8ce | ||
|
|
d354f2e8c2 | ||
|
|
24a8ee436f | ||
|
|
6e5f9404b7 | ||
|
|
64fe90aabb | ||
|
|
7e31d487e0 | ||
|
|
ee16e2eb30 | ||
|
|
003fb3392f | ||
|
|
0e82278cd5 | ||
|
|
5b544248bc | ||
|
|
d4d7495c0a | ||
|
|
8325cce44c | ||
|
|
ee0debc5b3 | ||
|
|
8f1bd12a17 | ||
|
|
fccf1016e4 | ||
|
|
1b010a082b | ||
|
|
324f215316 | ||
|
|
ace4f1e7f0 | ||
|
|
5c5f16f148 | ||
|
|
f50855d5c0 | ||
|
|
86917b0ba7 | ||
|
|
7201fcbe0f | ||
|
|
83f1735fbb | ||
|
|
80fd8e70f0 | ||
|
|
698c1c2b7a | ||
|
|
5d3287f5aa | ||
|
|
6990fe6f51 | ||
|
|
0b81068368 | ||
|
|
5b1851ae22 | ||
|
|
0d5708a01d | ||
|
|
67ab510b5d | ||
|
|
d1264a1289 | ||
|
|
3b973021a1 | ||
|
|
182624895f | ||
|
|
548de3739c | ||
|
|
718a3efd64 | ||
|
|
76b8c3250b | ||
|
|
dafaa8bd8c | ||
|
|
9c9b2c25ea | ||
|
|
e89cd81022 | ||
|
|
5debbd2be8 | ||
|
|
fe26df5355 | ||
|
|
85778494e4 | ||
|
|
a94ce3c715 | ||
|
|
a440ff1117 | ||
|
|
8195137bc5 | ||
|
|
3e2bd25e4e | ||
|
|
ffd0c2f624 | ||
|
|
23333c98d7 | ||
|
|
5a12ab98c4 | ||
|
|
0b327a63fc | ||
|
|
15b28a245c | ||
|
|
6ef5684797 | ||
|
|
d439b1495b | ||
|
|
9e096a3f0e | ||
|
|
0acf6ec150 | ||
|
|
4b36340474 | ||
|
|
910e642a8b | ||
|
|
9f571146fb | ||
|
|
339725f73d | ||
|
|
aff964c58b | ||
|
|
0c07e745f8 | ||
|
|
419d2e9564 | ||
|
|
f936a307c6 | ||
|
|
4e4678edfa | ||
|
|
cb7a4b3116 | ||
|
|
5ca4c42a74 | ||
|
|
1238a7ca07 | ||
|
|
a9db60a73d | ||
|
|
bd32ac19d4 | ||
|
|
eaf9944e43 | ||
|
|
703fdbc01d | ||
|
|
2daa08b0e7 | ||
|
|
05d9d22d9e | ||
|
|
8b7894f9bd | ||
|
|
a71439607f | ||
|
|
aca0d7f969 | ||
|
|
310a8e4342 | ||
|
|
24fbe1ef5b | ||
|
|
33d8faa35d | ||
|
|
44be714f65 | ||
|
|
0df3da6b10 | ||
|
|
79197b6ec7 | ||
|
|
353b6b51cb | ||
|
|
bd9a2c0d3a | ||
|
|
53b0ee6536 | ||
|
|
78daac0f1b | ||
|
|
b970b9b9a8 | ||
|
|
0339db57f1 | ||
|
|
461b147897 | ||
|
|
a3cd13b399 | ||
|
|
eb5d326a1e | ||
|
|
cce6eb94e2 | ||
|
|
8311c72c69 | ||
|
|
9a059285d9 | ||
|
|
469ac7891d | ||
|
|
16264a5693 | ||
|
|
6eedb50f56 | ||
|
|
5f07215662 | ||
|
|
d3a02fb2ca | ||
|
|
2c823f1aaa | ||
|
|
706293aadc | ||
|
|
dfdceb4258 | ||
|
|
0014b7fdb9 | ||
|
|
3b28f1f8af | ||
|
|
c689d476ca | ||
|
|
cc534fd21f | ||
|
|
124efcf247 | ||
|
|
dd452b05e3 | ||
|
|
b5617f7df9 | ||
|
|
b73ca1ba3a | ||
|
|
39ad071c4f | ||
|
|
fa0b576a45 | ||
|
|
c2c7591987 | ||
|
|
3e939e3775 | ||
|
|
f6384e10bc | ||
|
|
c283842563 | ||
|
|
1135976225 | ||
|
|
76679d33df | ||
|
|
e9d44b90bc | ||
|
|
8a7a391166 | ||
|
|
d6c5a9eece | ||
|
|
56ad6915d0 | ||
|
|
466c260782 | ||
|
|
d8e2d1725a | ||
|
|
33b43d03ac | ||
|
|
517509db6e | ||
|
|
95f01a5976 | ||
|
|
d08d3bf56d | ||
|
|
587fd669e8 | ||
|
|
e3553b87fe | ||
|
|
a078d2360c | ||
|
|
2d3abf8e6e | ||
|
|
cacae0fb7d | ||
|
|
d7fc215c16 | ||
|
|
bb69aa18f2 | ||
|
|
e4f515166a | ||
|
|
f325acb0ea | ||
|
|
d1b6e65dd8 | ||
|
|
4688252bd4 | ||
|
|
b1df5d3ad7 | ||
|
|
09bad2938e | ||
|
|
bad69fd397 | ||
|
|
b4ae6bf82c | ||
|
|
eac0f83864 | ||
|
|
3f16f080ac | ||
|
|
5de2b974fb | ||
|
|
6a9cb51828 | ||
|
|
f1c294ca50 | ||
|
|
c320e44a23 | ||
|
|
ea36ef3107 | ||
|
|
fedc37d079 | ||
|
|
86ccfcc03c | ||
|
|
bc8d8ab65a | ||
|
|
a7a23d3bc8 | ||
|
|
82d33944e6 | ||
|
|
8a629ad6fb | ||
|
|
e1711ffcf2 | ||
|
|
063d51c662 | ||
|
|
d8e3575a46 | ||
|
|
6fa609be3f | ||
|
|
70982e204c | ||
|
|
2af7df5865 | ||
|
|
59610e81de | ||
|
|
cdfac703ef | ||
|
|
ad5ebd007e | ||
|
|
1bd347d997 | ||
|
|
147056073d | ||
|
|
1b3231e617 | ||
|
|
7ac4ad3e38 | ||
|
|
0a345cb12b | ||
|
|
19ff0dd17f | ||
|
|
e3bf8a404b | ||
|
|
dbb28d9a8f | ||
|
|
19fd4e755c | ||
|
|
77698cd924 | ||
|
|
945d279f28 | ||
|
|
645d296841 | ||
|
|
57446de875 | ||
|
|
3473800ab6 | ||
|
|
7e5c5153a8 | ||
|
|
1b8979f285 | ||
|
|
2aac51dd20 | ||
|
|
69e32d264c | ||
|
|
71ae75a5bf | ||
|
|
86043fd87e | ||
|
|
d8aaef4f04 | ||
|
|
7fc34b6369 | ||
|
|
92b346efa7 | ||
|
|
c790735b9f | ||
|
|
64711e615e | ||
|
|
2065affd45 | ||
|
|
4067c56b5d | ||
|
|
65515638aa | ||
|
|
371ba3ffe3 | ||
|
|
5395b62f2f | ||
|
|
3e164eab26 | ||
|
|
ad85533975 | ||
|
|
d6c2a97931 | ||
|
|
17def94ba4 | ||
|
|
cf254ea240 | ||
|
|
2d05110239 | ||
|
|
0017f4fce8 | ||
|
|
02f3dd947a | ||
|
|
ef0874feba | ||
|
|
14aa1420f0 | ||
|
|
c506cd97e0 | ||
|
|
3761aacb1d | ||
|
|
233f13aac5 | ||
|
|
0ced3ec2d2 | ||
|
|
5b786f65a4 | ||
|
|
770542c8c7 | ||
|
|
4f1207a38c | ||
|
|
2b65f81e23 | ||
|
|
c10eb2c17b | ||
|
|
3f5ac54bf5 | ||
|
|
790f9409b1 | ||
|
|
a3d831b723 | ||
|
|
b9483deea3 | ||
|
|
c211d2ac45 | ||
|
|
119a03dd5f | ||
|
|
f3fbb7e1f6 | ||
|
|
2be98e8467 | ||
|
|
91b1806e9d | ||
|
|
8548b3645a | ||
|
|
4bbfb3f9a3 | ||
|
|
98eec72522 | ||
|
|
562d50df4d | ||
|
|
f3ee5ab372 | ||
|
|
aa2a3e5b07 | ||
|
|
8467307239 | ||
|
|
90da951a6f | ||
|
|
59f81b331c | ||
|
|
77a7d3d26a | ||
|
|
4321b80999 | ||
|
|
4b93b06323 | ||
|
|
96fb2e4b7c | ||
|
|
3dc1048dfb | ||
|
|
28f4bd5a67 | ||
|
|
b01c270889 | ||
|
|
7c92f8a90b | ||
|
|
a4a04872a3 | ||
|
|
f2d13cd647 | ||
|
|
9346908485 | ||
|
|
b3a7ba14f7 | ||
|
|
524ef9553c | ||
|
|
a85f6e72fe | ||
|
|
1ae6a41336 | ||
|
|
3ec55791c6 | ||
|
|
a3accd28ea | ||
|
|
fc5bc84207 | ||
|
|
d8b4051d6d | ||
|
|
804a1cc22d | ||
|
|
cdd60e5f9c | ||
|
|
7c76f07384 | ||
|
|
a3b1ef9527 | ||
|
|
0bd4150a80 | ||
|
|
7f7f5253f2 | ||
|
|
2a0a847634 | ||
|
|
92ddb37ed3 | ||
|
|
01f944e6bd | ||
|
|
732c8d7350 | ||
|
|
21678aeef5 | ||
|
|
cda1ca35a4 | ||
|
|
923580d2cd | ||
|
|
190af1d32b | ||
|
|
bffe0443f9 | ||
|
|
29e99e229b | ||
|
|
2736b88dd5 | ||
|
|
e739c60e9f | ||
|
|
1c0afbc5c5 | ||
|
|
ee1ba5c0f2 | ||
|
|
02342ba540 | ||
|
|
12a130e9bc | ||
|
|
dfb97e7961 | ||
|
|
54e03a62bd | ||
|
|
ec9659ff25 | ||
|
|
0a41b253f3 | ||
|
|
002b86198c | ||
|
|
7161a235f1 | ||
|
|
391034a785 | ||
|
|
446a7fbd67 | ||
|
|
2ccb09434f | ||
|
|
7974060a40 | ||
|
|
e8abcc1765 | ||
|
|
1be1927a1f | ||
|
|
894ff71664 | ||
|
|
93bed9c5df | ||
|
|
34c008adce | ||
|
|
22ddd91b1f | ||
|
|
e121f34407 | ||
|
|
df8a3e870a | ||
|
|
13b6708a09 | ||
|
|
6aa196cf55 | ||
|
|
142493076a | ||
|
|
3d905a7a4f | ||
|
|
0a8a6ed168 | ||
|
|
68b6fa46e6 | ||
|
|
80f7c54e4d | ||
|
|
c0e2041006 | ||
|
|
f6d2cd7704 | ||
|
|
6d9a629b15 | ||
|
|
ead8edc7cd | ||
|
|
664eefdddb | ||
|
|
220d76c974 | ||
|
|
d973192b5e | ||
|
|
978bb5059f | ||
|
|
f59178bc33 | ||
|
|
53899cc492 | ||
|
|
6379d0fe0f | ||
|
|
a1c4d8696a | ||
|
|
7f42ed86f2 | ||
|
|
6bb8b4c994 | ||
|
|
afefbe4e56 | ||
|
|
5cd37e5505 | ||
|
|
d6a825981d | ||
|
|
a1c01c6722 | ||
|
|
8d182f1d79 | ||
|
|
29707bd2ea | ||
|
|
c2bf2a8174 | ||
|
|
b402849557 | ||
|
|
cb85dcfcb8 | ||
|
|
49379140c7 | ||
|
|
63f6c86b46 | ||
|
|
1865898cd4 | ||
|
|
8935ecfdb8 | ||
|
|
4902bed409 | ||
|
|
e6f6aba207 | ||
|
|
bab622de25 | ||
|
|
a86c1624a7 | ||
|
|
c707392a5a | ||
|
|
1f07721ec4 | ||
|
|
4767e45035 | ||
|
|
f2a64ed685 | ||
|
|
2c9966a0a3 | ||
|
|
953aa95c64 | ||
|
|
446266776e | ||
|
|
845af014dc | ||
|
|
7c8f8703a1 | ||
|
|
a0c18e4380 | ||
|
|
e8d8099563 | ||
|
|
2c9d90d463 | ||
|
|
130d2064d5 | ||
|
|
a10eb2a0d7 | ||
|
|
b71cc5d7ee | ||
|
|
8512f9eda1 | ||
|
|
80058083b8 | ||
|
|
d5a17a3c25 | ||
|
|
eab7c87781 | ||
|
|
d2962d8676 | ||
|
|
5e602fb575 | ||
|
|
599964ea5f | ||
|
|
562de7926b | ||
|
|
8eaed95e02 | ||
|
|
3cffd46008 | ||
|
|
e239bfda8a | ||
|
|
bd887b660d | ||
|
|
7c1e0ea95d | ||
|
|
afbddbfcda | ||
|
|
9eeb702ca5 | ||
|
|
4cb6d6995f | ||
|
|
fe7e7a8d07 | ||
|
|
f8ee79ab72 | ||
|
|
a11165830b | ||
|
|
11cde61eab | ||
|
|
cd862409cc | ||
|
|
7644555d6b | ||
|
|
07e68aa694 | ||
|
|
0ae206b1bb | ||
|
|
5bdac96375 | ||
|
|
f0e044ecd8 | ||
|
|
f32234291e | ||
|
|
83acd6529f | ||
|
|
6a60cb4dc0 | ||
|
|
1de03fbe18 | ||
|
|
0e0a2aa981 | ||
|
|
af73b9d11b | ||
|
|
859969241a | ||
|
|
6852a8ca9d | ||
|
|
c694f1a4a9 | ||
|
|
d36543b204 | ||
|
|
6981234736 | ||
|
|
10bf3ee9de | ||
|
|
9953218de1 | ||
|
|
50c74103aa | ||
|
|
c5e15123fd | ||
|
|
4adcdb5ba8 | ||
|
|
60b36ffaa3 | ||
|
|
d86104ed5d | ||
|
|
0f02ef20a9 | ||
|
|
0768cf17b6 | ||
|
|
197205853f | ||
|
|
bebcc24ab8 | ||
|
|
987248ccbb | ||
|
|
56ece4db0f | ||
|
|
c7f8b94ccd | ||
|
|
95b820305a | ||
|
|
599b200ca5 | ||
|
|
a9566b31be | ||
|
|
f30837d726 | ||
|
|
1242ffa4c6 | ||
|
|
37c0347c47 | ||
|
|
65befb84a0 | ||
|
|
a41f7ce3bd | ||
|
|
81ced6bf2a | ||
|
|
fa8033f998 | ||
|
|
19e3178d0c | ||
|
|
1e6262f24f | ||
|
|
beb2284440 | ||
|
|
0c4f0de13d | ||
|
|
0cd31a4b96 | ||
|
|
ef0a86e7cc | ||
|
|
b79c1345b9 | ||
|
|
5bb8b6f16c | ||
|
|
f6f675d1e1 | ||
|
|
9f684e7670 | ||
|
|
a998706452 | ||
|
|
5e19bc6f84 | ||
|
|
169f287970 | ||
|
|
c56926428c | ||
|
|
43eab5c4e5 | ||
|
|
c6424c2ce7 | ||
|
|
dfe19d308c | ||
|
|
b75db110dc | ||
|
|
9e50ba6ec6 | ||
|
|
aca2ba13c2 | ||
|
|
c5afe7a573 | ||
|
|
8b90968cb1 | ||
|
|
9281dba896 | ||
|
|
c7555f1c3c | ||
|
|
e781831032 | ||
|
|
8025895168 | ||
|
|
799935e44c | ||
|
|
209d8d058c | ||
|
|
0368a70dd7 | ||
|
|
c3603426de | ||
|
|
80db9971b5 | ||
|
|
e3e771708e | ||
|
|
b9bca2a19f | ||
|
|
ffae70a99a | ||
|
|
10ec1e48b0 | ||
|
|
84123f5445 | ||
|
|
25531d8393 | ||
|
|
adfadc542a | ||
|
|
7682e1cb57 | ||
|
|
1fe4109a42 | ||
|
|
b97baf4d47 | ||
|
|
f91728561f | ||
|
|
2b75d54ce1 | ||
|
|
cdc09a7d30 | ||
|
|
4cc6c3e535 | ||
|
|
8f43e033a4 | ||
|
|
918dbd1926 | ||
|
|
8fc86ce7fa | ||
|
|
bf0cb40586 | ||
|
|
a62aefe74b | ||
|
|
138d232149 | ||
|
|
8fa64e3ab2 | ||
|
|
8d0d2bd3fc | ||
|
|
2146f5f623 | ||
|
|
623df23570 | ||
|
|
4a15d8b6d2 | ||
|
|
af83a62474 | ||
|
|
a0705a6c67 | ||
|
|
712b8eec3d | ||
|
|
558e9c21ed | ||
|
|
23a7137e6a | ||
|
|
71a1cb0184 | ||
|
|
09b47cc536 | ||
|
|
b5c78de2dd | ||
|
|
a1bd14e516 | ||
|
|
9684c8664f | ||
|
|
3c75361e5a | ||
|
|
c44c9ab74d | ||
|
|
8cc9c871b7 | ||
|
|
31d211cded | ||
|
|
c42cba1d54 | ||
|
|
c87f7cb9ac | ||
|
|
421bee3871 | ||
|
|
2c7573a032 | ||
|
|
fe2a0f5089 | ||
|
|
59ba8dec4e | ||
|
|
ff0e1bbbc0 | ||
|
|
18c712cd99 | ||
|
|
8de1f764fd | ||
|
|
a91c1ec6d9 | ||
|
|
c8e351b31e | ||
|
|
b4c98584db | ||
|
|
1d17836b7d | ||
|
|
193a739749 | ||
|
|
48da2b8353 | ||
|
|
40dc9de6c9 | ||
|
|
d7469e4694 | ||
|
|
fdfabc9f88 | ||
|
|
5658ca5b90 | ||
|
|
8b79e6d3c7 | ||
|
|
8c67087a15 | ||
|
|
057f73a73e | ||
|
|
d3bb37d113 | ||
|
|
6c91b862c9 | ||
|
|
cba47b635a | ||
|
|
cd83388f8b | ||
|
|
02ae247536 | ||
|
|
1621a68191 | ||
|
|
2aef495d62 | ||
|
|
227c168b65 | ||
|
|
dcbcf5842f | ||
|
|
8a3ac6d9bd | ||
|
|
6cabad19d5 | ||
|
|
dad7a03d19 | ||
|
|
7b152640d9 | ||
|
|
78fddff34e | ||
|
|
78f542f6c0 | ||
|
|
f8a016edb5 | ||
|
|
f5453d38ec | ||
|
|
331bf0af21 | ||
|
|
9ac69337e8 | ||
|
|
ca0c844f32 | ||
|
|
e629e8784f | ||
|
|
e944c1ee93 | ||
|
|
02c882bda3 | ||
|
|
2c29377abf | ||
|
|
21992f1b9e | ||
|
|
8a3f090684 | ||
|
|
a4258505a9 | ||
|
|
ba4a971bfa | ||
|
|
6abc120279 | ||
|
|
64c36b7a8f | ||
|
|
64b9f0762c | ||
|
|
e799082e5c | ||
|
|
eab66a022e | ||
|
|
485915c27a | ||
|
|
45fb482ab4 | ||
|
|
167e2475d8 | ||
|
|
fe77251242 | ||
|
|
0c331d2887 | ||
|
|
39facd5dc6 | ||
|
|
a2bd5ae638 | ||
|
|
c57f616141 | ||
|
|
3af10a1d00 | ||
|
|
b3987e2402 | ||
|
|
71dd44f430 | ||
|
|
584462f9b9 | ||
|
|
ff5d5d7cbc | ||
|
|
370e92b1a6 | ||
|
|
2469768a85 | ||
|
|
acb8fa613e | ||
|
|
83b4b7d83d | ||
|
|
33a7d56042 | ||
|
|
20de730541 | ||
|
|
134c27c900 | ||
|
|
123ae024c6 | ||
|
|
34a29cd0a5 | ||
|
|
9fffa9800a | ||
|
|
8f7f23a0e5 | ||
|
|
358457f49d | ||
|
|
90e305d789 | ||
|
|
b471e52e28 | ||
|
|
9b5fc37399 | ||
|
|
537322e3b5 | ||
|
|
279121f87f | ||
|
|
a1b2b41cdc | ||
|
|
0cca90c21d | ||
|
|
ad052cb510 | ||
|
|
57f0598373 | ||
|
|
92d192277e | ||
|
|
2cdfbd8970 | ||
|
|
bc0c5f0cdc | ||
|
|
230ee3a03b | ||
|
|
ab0bf37d30 | ||
|
|
b1e66256ce | ||
|
|
fd80693420 | ||
|
|
f222f5ed9b | ||
|
|
59603b902a | ||
|
|
82a5dd6cf9 | ||
|
|
a97f9081a3 | ||
|
|
b3e0ad1303 | ||
|
|
251090406a | ||
|
|
9c3ed173b1 | ||
|
|
7cd41aeb72 | ||
|
|
8ecaf7ad4c | ||
|
|
d4049fe593 | ||
|
|
989b14b519 | ||
|
|
fb3e11408c | ||
|
|
3d3af3284e | ||
|
|
eabcf15790 | ||
|
|
684bca203a | ||
|
|
d42ecccf6f | ||
|
|
5a92c861e3 | ||
|
|
103b14ea3c | ||
|
|
e49f091b4e | ||
|
|
6056f93910 | ||
|
|
18fa2d1af4 | ||
|
|
062ed8a4c4 | ||
|
|
49f3872d04 | ||
|
|
d9b467098a | ||
|
|
7d1e51437e | ||
|
|
f5a7d444e2 | ||
|
|
a0071c2f9f | ||
|
|
98a5e43883 | ||
|
|
f40ebe5b43 | ||
|
|
d7d78d9a2b | ||
|
|
5a12d36a0a | ||
|
|
e61dc76ae1 | ||
|
|
0da22193bd | ||
|
|
d43921823e | ||
|
|
6b5b76b0c9 | ||
|
|
602971408b | ||
|
|
2f5d83f07d | ||
|
|
81b0c316cd | ||
|
|
6df86384ca | ||
|
|
3fbcde4bd7 | ||
|
|
293293c23c | ||
|
|
47185d757e | ||
|
|
94c3998507 | ||
|
|
5fa589691c | ||
|
|
26bc835c7e | ||
|
|
fc7da17fa2 | ||
|
|
dbebe9771b | ||
|
|
d0af8aa9f1 | ||
|
|
f8173e93f5 | ||
|
|
fa6ea6848f | ||
|
|
5982970e21 | ||
|
|
c43e5e0c95 | ||
|
|
b4fc79c38e | ||
|
|
b9cb270b8f | ||
|
|
1fe35d7efe | ||
|
|
ec8c19b1f0 | ||
|
|
c2525bcc05 | ||
|
|
985c31b378 | ||
|
|
135a9f5586 | ||
|
|
979ff80982 | ||
|
|
6cde9f3a9d | ||
|
|
5cad81bf4c | ||
|
|
18967162cf | ||
|
|
6ea75f3a9f | ||
|
|
f51123d009 | ||
|
|
be6376ee2d | ||
|
|
120a85a3e5 | ||
|
|
262fe96c29 | ||
|
|
1864df5ed0 | ||
|
|
09bae0a9e8 | ||
|
|
ebe41a24f1 | ||
|
|
f0f574a15b | ||
|
|
9420436c09 | ||
|
|
2b8f853b96 | ||
|
|
2c2bf60d0c | ||
|
|
62b82448d5 | ||
|
|
2f12e6c3d0 | ||
|
|
8ce23f8e3e | ||
|
|
dbe760d6e2 | ||
|
|
674c26d9c7 | ||
|
|
7b68b04efd | ||
|
|
e0b65bf196 | ||
|
|
77f5cb1f1f | ||
|
|
2a222737f8 | ||
|
|
77d48f9cee | ||
|
|
c77eac325e | ||
|
|
517ced2a54 | ||
|
|
70d2c47367 | ||
|
|
e57084f6df | ||
|
|
8783cf8ec3 | ||
|
|
2af7a7c6ac | ||
|
|
91a1f8d9e1 | ||
|
|
fc5e8ddca1 | ||
|
|
6352472c5f | ||
|
|
833ee6484c | ||
|
|
dda3d24bca | ||
|
|
f77d76a320 | ||
|
|
c51fabf6ed | ||
|
|
b10cb658ca | ||
|
|
68f60568ac | ||
|
|
9fbca83ac0 | ||
|
|
d19bfaa2cb | ||
|
|
53d5ddb345 | ||
|
|
0a5c2e7ab9 | ||
|
|
35802ba949 | ||
|
|
72160aac9a | ||
|
|
9df6916029 | ||
|
|
9bfa2354ff | ||
|
|
7d945d3c8e | ||
|
|
05e28752f1 | ||
|
|
01b6673528 | ||
|
|
4e85ebbf98 | ||
|
|
120e8bffd7 | ||
|
|
8335823748 | ||
|
|
c9fcf4020f | ||
|
|
b10a736744 | ||
|
|
60fbaf7612 | ||
|
|
d24193630e | ||
|
|
354af69f62 | ||
|
|
bccac610a4 | ||
|
|
5aa6209664 | ||
|
|
d693d92702 | ||
|
|
f2622e54e3 | ||
|
|
20fe9b6dde | ||
|
|
11f7aa4212 | ||
|
|
f53c351fd2 | ||
|
|
fb96617377 | ||
|
|
05b8c00ee7 | ||
|
|
58854fdae9 | ||
|
|
fd31ff772f | ||
|
|
ab8e0c9e31 | ||
|
|
abeed3be84 | ||
|
|
a65438c6fe | ||
|
|
c3f43fb0cf | ||
|
|
2807504a81 | ||
|
|
08b716c96d | ||
|
|
b4b1f0a2c9 | ||
|
|
228f742b2f | ||
|
|
a55affe4d5 | ||
|
|
a6ec726ed7 | ||
|
|
87835a4e60 | ||
|
|
1f18af4395 | ||
|
|
e79747a600 | ||
|
|
bd36ac2c0c | ||
|
|
c6186f2c01 | ||
|
|
d639f57470 | ||
|
|
99a2d28592 | ||
|
|
254ee80c16 | ||
|
|
e43f57fe1a | ||
|
|
f88c029a4c | ||
|
|
93c3cbeaef | ||
|
|
88c77b793f | ||
|
|
11286524a5 | ||
|
|
7c863c341e | ||
|
|
3416cf984e | ||
|
|
1784746e7e | ||
|
|
6c6df1adaf | ||
|
|
f91e1c17c0 | ||
|
|
58201b95f2 | ||
|
|
fcce8f6d51 | ||
|
|
f7bdda8828 | ||
|
|
df5a60fd5b | ||
|
|
5782ab7ccc | ||
|
|
72e3f98213 | ||
|
|
1b1433a664 | ||
|
|
568704ed22 | ||
|
|
05a7e4eb64 | ||
|
|
7a0acf2838 | ||
|
|
27787505e0 | ||
|
|
2c8048115d | ||
|
|
7df1780853 | ||
|
|
d5609f3207 | ||
|
|
cd10fbc1fe | ||
|
|
ca0b085d15 | ||
|
|
9a034234d8 | ||
|
|
66ef6c9e4c | ||
|
|
7df60b259b | ||
|
|
34b3bbc883 | ||
|
|
e02d20dd74 | ||
|
|
1a11608f1f | ||
|
|
9e2c9d7812 | ||
|
|
404a393315 | ||
|
|
c69092e110 | ||
|
|
ebc0eeac79 | ||
|
|
2b72f35c32 | ||
|
|
d8212ad620 | ||
|
|
1066bb38a8 |
51
.gitignore
vendored
Normal file
51
.gitignore
vendored
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
# Files generated by the bootstrap script.
|
||||||
|
/INSTALL
|
||||||
|
/AUTHORS
|
||||||
|
/ChangeLog
|
||||||
|
/NEWS
|
||||||
|
/README
|
||||||
|
/ac/
|
||||||
|
/aclocal.m4
|
||||||
|
/autom4te.cache/
|
||||||
|
/config.h.in
|
||||||
|
/configure
|
||||||
|
/msgpack_vc2008.sln
|
||||||
|
/msgpack_vc2008.vcproj
|
||||||
|
Makefile.in
|
||||||
|
|
||||||
|
# Files generated by the configure script.
|
||||||
|
|
||||||
|
/config.h
|
||||||
|
/config.log
|
||||||
|
/config.status
|
||||||
|
/libtool
|
||||||
|
/msgpack.pc
|
||||||
|
/src/msgpack/version.h
|
||||||
|
/src/msgpack/version.hpp
|
||||||
|
/stamp-h1
|
||||||
|
Makefile
|
||||||
|
.deps
|
||||||
|
.libs
|
||||||
|
|
||||||
|
# Files generated by make.
|
||||||
|
*.o
|
||||||
|
*.so
|
||||||
|
*.lo
|
||||||
|
*.la
|
||||||
|
|
||||||
|
# Files generated by make check.
|
||||||
|
# TODO: Replace these with something like /test/*_test
|
||||||
|
/test/buffer
|
||||||
|
/test/cases
|
||||||
|
/test/convert
|
||||||
|
/test/fixint
|
||||||
|
/test/fixint_c
|
||||||
|
/test/msgpack_test
|
||||||
|
/test/msgpackc_test
|
||||||
|
/test/object
|
||||||
|
/test/pack_unpack
|
||||||
|
/test/pack_unpack_c
|
||||||
|
/test/streaming
|
||||||
|
/test/streaming_c
|
||||||
|
/test/version
|
||||||
|
/test/zone
|
||||||
34
.travis.yml
Normal file
34
.travis.yml
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
language: cpp
|
||||||
|
cache:
|
||||||
|
- apt
|
||||||
|
compiler:
|
||||||
|
- clang
|
||||||
|
- gcc
|
||||||
|
before_install:
|
||||||
|
- sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
|
||||||
|
- sudo add-apt-repository -y ppa:h-rayflood/llvm
|
||||||
|
- sudo apt-get update -qq
|
||||||
|
- sudo apt-get update
|
||||||
|
- sudo apt-get install valgrind
|
||||||
|
install:
|
||||||
|
- sudo apt-get install -qq gcc-4.8-multilib g++-4.8-multilib
|
||||||
|
- sudo apt-get install --allow-unauthenticated -qq clang-3.4
|
||||||
|
- sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 90
|
||||||
|
- sudo apt-get install -y lib32gcc1
|
||||||
|
- sudo apt-get install -y libc6-i386
|
||||||
|
- sudo apt-get install -y lib32z1-dev
|
||||||
|
- sudo apt-get install -y lib32stdc++6
|
||||||
|
- wget https://googletest.googlecode.com/files/gtest-1.7.0.zip
|
||||||
|
- unzip gtest-1.7.0.zip && cd gtest-1.7.0 && sudo cp -r include/gtest /usr/local/include && g++ src/gtest-all.cc -I. -Iinclude -c && g++ src/gtest_main.cc -I. -Iinclude -c && ar -rv libgtest.a gtest-all.o && ar -rv libgtest_main.a gtest_main.o && sudo mv *.a /usr/local/lib && g++ -m32 src/gtest-all.cc -I. -Iinclude -c && g++ -m32 src/gtest_main.cc -I. -Iinclude -c && ar -rv libgtest.a gtest-all.o && ar -rv libgtest_main.a gtest_main.o && sudo mkdir /usr/local/lib32 && sudo mv *.a /usr/local/lib32 && cd ..
|
||||||
|
env:
|
||||||
|
- ACTION="ci/build_autotools.sh" VERSION="cpp11" ARCH="64" LIBPATH="/usr/local/lib"
|
||||||
|
- ACTION="ci/build_autotools.sh" VERSION="cpp11" ARCH="32" LIBPATH="/usr/local/lib32"
|
||||||
|
- ACTION="ci/build_autotools.sh" VERSION="cpp03" ARCH="64" LIBPATH="/usr/local/lib"
|
||||||
|
- ACTION="ci/build_autotools.sh" VERSION="cpp03" ARCH="32" LIBPATH="/usr/local/lib32"
|
||||||
|
- ACTION="ci/build_cmake.sh" VERSION="cpp11" ARCH="64" LIBPATH="/usr/local/lib"
|
||||||
|
- ACTION="ci/build_cmake.sh" VERSION="cpp11" ARCH="32" LIBPATH="/usr/local/lib32"
|
||||||
|
- ACTION="ci/build_cmake.sh" VERSION="cpp03" ARCH="64" LIBPATH="/usr/local/lib"
|
||||||
|
- ACTION="ci/build_cmake.sh" VERSION="cpp03" ARCH="32" LIBPATH="/usr/local/lib32"
|
||||||
|
|
||||||
|
script:
|
||||||
|
- git clean -xdf && CMAKE_LIBRARY_PATH=${LIBPATH} ${ACTION} ${VERSION} ${ARCH}
|
||||||
104
CHANGELOG.md
Normal file
104
CHANGELOG.md
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
2015-3-22 version 1.0.1:
|
||||||
|
* Fix compilation error on Mac 10.9 (#244)
|
||||||
|
* Fix typos in documents (#240)
|
||||||
|
* Update CHANGELOG.md for version 1.0.0 (#242)
|
||||||
|
* Fix erb templates for the next code generation (#239)
|
||||||
|
|
||||||
|
2015-03-10 version 1.0.0:
|
||||||
|
* Support msgpack v5 format (str, bin, and ext) https://github.com/msgpack/msgpack/blob/master/spec.md (#142)
|
||||||
|
* Support std::tuple, std::forward_list, std::array, std::unordered_set, std::unordered_map on C++11. tr1 unordered containers are still supported (#53, #130, #137, #154, #169)
|
||||||
|
* Update msgpack-c as a header-only library on C++ (#142)
|
||||||
|
* Move include directory (#142)
|
||||||
|
* Update the name of float format family on msgpack::object from 'dec' to 'f64' (#194)
|
||||||
|
* Remove existing elements on associative containers when unpacking (#127)
|
||||||
|
* Add an API versioning functionality https://github.com/msgpack/msgpack-c/wiki/cpp_versioning (#139)
|
||||||
|
* Add C++11 enum class support (#205)
|
||||||
|
* Map std::vector<char> and std::array<char> to BIN (#100)
|
||||||
|
* Map '\0' teminated char* and char const* to STR (#206)
|
||||||
|
* Add the new parameter on unpacking functions and classes to limit msgpack's bytestream size (https://github.com/msgpack/msgpack-c/wiki/cpp_unpacker#limit-size-of-elements) (#175)
|
||||||
|
* Add the copy or reference choosing function on unpack() and unpacker (https://github.com/msgpack/msgpack-c/wiki/cpp_unpacker#memory-management)
|
||||||
|
* Add the new unpack() overloads for C++11 https://github.com/msgpack/msgpack-c/wiki/cpp_unpacker (#128)
|
||||||
|
* Add a msgpack::object::with_zone (deep) copying function (#133, #163)
|
||||||
|
* Remove the compile-time defined limit of msgpack nest level on C++ (#218)
|
||||||
|
* Add the new unpack() overloads that use an existing zone (#201)
|
||||||
|
* Add the range-based for loop support on msgpack object array and map (#203)
|
||||||
|
* Add msgpack revision getter function for 'revision' (#237)
|
||||||
|
* Support EXT for C (#118, #129)
|
||||||
|
* Fix unpacking buffer allocation problem when malformed data is given (#160, #185)
|
||||||
|
* Add dll exporting function on MSVC (#162)
|
||||||
|
* Fix msgpack::zone::allocate_no_align(). Now it allocates the memory that is not aligned as expected (#171)
|
||||||
|
* Improve documents (https://github.com/msgpack/msgpack-c/wiki)
|
||||||
|
* Other bug fixes and refactoring: #62, #91, #95, #97, #107, #109, #113, #117, #119, #121, #122, #123, #126, #131, #136, #138, #140, #143, #145, #146, #150, #151, #152, #156, #157, #158, #161, #165, #170, #172, #179, #180, #181, #182, #183, #192, #195, #199, #200, #207, #211, #212, #219, #222, #224, #230, #231, #232, #233, #234, #235
|
||||||
|
|
||||||
|
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:
|
||||||
|
|
||||||
|
* Move to the new github repository msgpack/msgpack-c
|
||||||
|
* Support the new deserialization specification
|
||||||
|
* fixes the problem of unpack helpers for array and map with 32bit compilers (#37, #38)
|
||||||
|
* Other bug fixes and refactoring: #46, #41, #36, #35, #33, #32, #30, #29, #28, #27, #26, #25, #8, #3
|
||||||
|
* Update of documents: #23, #18, #17
|
||||||
|
|
||||||
|
2011-08-08 version 0.5.7:
|
||||||
|
|
||||||
|
* fixes compile error problem with llvm-gcc and Mac OS X Lion
|
||||||
|
|
||||||
|
2011-04-24 version 0.5.6:
|
||||||
|
|
||||||
|
* #42 fixes double-free problem on msgpack_unpacker_release_zone
|
||||||
|
|
||||||
|
2011-02-24 version 0.5.5:
|
||||||
|
|
||||||
|
* eliminates dependency of winsock2.h header
|
||||||
|
* fixes msgpack_vc.postbuild.bat file
|
||||||
|
* fixes some implicit cast warnings
|
||||||
|
|
||||||
|
2010-08-29 version 0.5.4:
|
||||||
|
|
||||||
|
* includes msgpack_vc2008.vcproj file in source package
|
||||||
|
* fixes type::fix_int types
|
||||||
|
|
||||||
|
2010-08-27 version 0.5.3:
|
||||||
|
|
||||||
|
* adds type::fix_{u,}int{8,16,32,64} types
|
||||||
|
* adds msgpack_pack_fix_{u,}int{8,16,32,64} functions
|
||||||
|
* adds packer<Stream>::pack_fix_{u,}int{8,16,32,64} functions
|
||||||
|
* fixes include paths
|
||||||
|
|
||||||
|
2010-07-14 version 0.5.2:
|
||||||
|
|
||||||
|
* type::raw::str(), operator==, operator!=, operator< and operator> are now const
|
||||||
|
* generates version.h using AC_OUTPUT macro in ./configure
|
||||||
|
|
||||||
|
2010-07-06 version 0.5.1:
|
||||||
|
|
||||||
|
* Add msgpack_vrefbuffer_new and msgpack_vrefbuffer_free
|
||||||
|
* Add msgpack_sbuffer_new and msgpack_sbuffer_free
|
||||||
|
* Add msgpack_unpacker_next and msgpack_unpack_next
|
||||||
|
* msgpack::unpack returns void
|
||||||
|
* Add MSGPACK_VERSION{,_MAJOR,_MINOR} macros to check header version
|
||||||
|
* Add msgpack_version{,_major,_minor} functions to check library version
|
||||||
|
* ./configure supports --disable-cxx option not to build C++ API
|
||||||
|
|
||||||
|
2010-04-29 version 0.5.0:
|
||||||
|
|
||||||
|
* msgpack_object_type is changed. MSGPACK_OBJECT_NIL is now 0x00.
|
||||||
|
* New safe streaming deserializer API.
|
||||||
|
* Add object::object(const T&) and object::operator=(const T&)
|
||||||
|
* Add operator==(object, const T&)
|
||||||
|
* MSGPACK_DEFINE macro defines msgpack_object(object* obj, zone* z)
|
||||||
|
* C++ programs doesn't need to link "msgpackc" library.
|
||||||
|
|
||||||
265
CMakeLists.txt
Normal file
265
CMakeLists.txt
Normal file
@@ -0,0 +1,265 @@
|
|||||||
|
CMAKE_MINIMUM_REQUIRED (VERSION 2.8.6)
|
||||||
|
PROJECT (msgpack)
|
||||||
|
|
||||||
|
FILE (READ ${CMAKE_CURRENT_SOURCE_DIR}/include/msgpack/version_master.h contents)
|
||||||
|
STRING (REGEX MATCH "#define MSGPACK_VERSION_MAJOR *([0-9a-zA-Z_]*)" NULL_OUT ${contents})
|
||||||
|
SET (VERSION_MAJOR ${CMAKE_MATCH_1})
|
||||||
|
STRING (REGEX MATCH "#define MSGPACK_VERSION_MINOR *([0-9a-zA-Z_]*)" NULL_OUT ${contents})
|
||||||
|
SET (VERSION_MINOR ${CMAKE_MATCH_1})
|
||||||
|
STRING (REGEX MATCH "#define MSGPACK_VERSION_REVISION *([0-9a-zA-Z_]*)" NULL_OUT ${contents})
|
||||||
|
SET (VERSION_REVISION ${CMAKE_MATCH_1})
|
||||||
|
SET (VERSION ${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_REVISION})
|
||||||
|
|
||||||
|
SET (prefix ${CMAKE_INSTALL_PREFIX})
|
||||||
|
SET (exec_prefix "\${prefix}")
|
||||||
|
SET (libdir "\${exec_prefix}/lib")
|
||||||
|
SET (includedir "\${prefix}/include")
|
||||||
|
|
||||||
|
OPTION (MSGPACK_CXX11 "Using c++11 compiler" OFF)
|
||||||
|
OPTION (MSGPACK_32BIT "32bit compile" OFF)
|
||||||
|
|
||||||
|
IF (MSGPACK_CXX11)
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
|
SET (CMAKE_CXX_FLAGS "-std=c++11 ${CMAKE_CXX_FLAGS}")
|
||||||
|
ELSEIF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
||||||
|
SET (CMAKE_CXX_FLAGS "-std=c++11 ${CMAKE_CXX_FLAGS}")
|
||||||
|
ELSEIF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
||||||
|
MESSAGE ( FATAL_ERROR "MSVC doesn't support C++11 yet.")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
IF (MSGPACK_32BIT)
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
|
SET (CMAKE_CXX_FLAGS "-m32 ${CMAKE_CXX_FLAGS}")
|
||||||
|
SET (CMAKE_C_FLAGS "-m32 ${CMAKE_C_FLAGS}")
|
||||||
|
SET (CMAKE_EXE_LINKER_FLAGS "-m32 ${CMAKE_EXE_LINKER_FLAGS}")
|
||||||
|
ELSEIF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
||||||
|
SET (CMAKE_CXX_FLAGS "-m32 ${CMAKE_CXX_FLAGS}")
|
||||||
|
SET (CMAKE_C_FLAGS "-m32 ${CMAKE_C_FLAGS}")
|
||||||
|
SET (CMAKE_EXE_LINKER_FLAGS "-m32 ${CMAKE_EXE_LINKER_FLAGS}")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
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_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
|
||||||
|
include/msgpack/pack_define.h
|
||||||
|
include/msgpack/pack_template.h
|
||||||
|
include/msgpack/unpack_define.h
|
||||||
|
include/msgpack/unpack_template.h
|
||||||
|
include/msgpack/util.h
|
||||||
|
include/msgpack/sysdep.h
|
||||||
|
include/msgpack/gcc_atomic.h
|
||||||
|
include/msgpack/sbuffer.h
|
||||||
|
include/msgpack/version.h
|
||||||
|
include/msgpack/vrefbuffer.h
|
||||||
|
include/msgpack/zbuffer.h
|
||||||
|
include/msgpack/fbuffer.h
|
||||||
|
include/msgpack/pack.h
|
||||||
|
include/msgpack/unpack.h
|
||||||
|
include/msgpack/object.h
|
||||||
|
include/msgpack/zone.h
|
||||||
|
)
|
||||||
|
|
||||||
|
IF (MSGPACK_ENABLE_CXX)
|
||||||
|
LIST (APPEND msgpack_HEADERS
|
||||||
|
include/msgpack.hpp
|
||||||
|
include/msgpack_fwd.hpp
|
||||||
|
include/msgpack/adaptor/bool.hpp
|
||||||
|
include/msgpack/adaptor/bool_fwd.hpp
|
||||||
|
include/msgpack/adaptor/char_ptr.hpp
|
||||||
|
include/msgpack/adaptor/char_ptr_fwd.hpp
|
||||||
|
include/msgpack/adaptor/check_container_size.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/array.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/array_fwd.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/array_char.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/array_char_fwd.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/forward_list.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/forward_list_fwd.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/tuple.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/tuple_fwd.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/unordered_map.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/unordered_map_fwd.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/unordered_set.hpp
|
||||||
|
include/msgpack/adaptor/cpp11/unordered_set_fwd.hpp
|
||||||
|
include/msgpack/adaptor/define.hpp
|
||||||
|
include/msgpack/adaptor/deque.hpp
|
||||||
|
include/msgpack/adaptor/deque_fwd.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp03_define.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp03_msgpack_tuple.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp03_msgpack_tuple_fwd.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp11_define.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp11_msgpack_tuple.hpp
|
||||||
|
include/msgpack/adaptor/detail/cpp11_msgpack_tuple_fwd.hpp
|
||||||
|
include/msgpack/adaptor/fixint.hpp
|
||||||
|
include/msgpack/adaptor/fixint_fwd.hpp
|
||||||
|
include/msgpack/adaptor/float.hpp
|
||||||
|
include/msgpack/adaptor/float_fwd.hpp
|
||||||
|
include/msgpack/adaptor/int.hpp
|
||||||
|
include/msgpack/adaptor/int_fwd.hpp
|
||||||
|
include/msgpack/adaptor/list.hpp
|
||||||
|
include/msgpack/adaptor/list_fwd.hpp
|
||||||
|
include/msgpack/adaptor/map.hpp
|
||||||
|
include/msgpack/adaptor/map_fwd.hpp
|
||||||
|
include/msgpack/adaptor/msgpack_tuple.hpp
|
||||||
|
include/msgpack/adaptor/msgpack_tuple_fwd.hpp
|
||||||
|
include/msgpack/adaptor/nil.hpp
|
||||||
|
include/msgpack/adaptor/nil_fwd.hpp
|
||||||
|
include/msgpack/adaptor/pair.hpp
|
||||||
|
include/msgpack/adaptor/pair_fwd.hpp
|
||||||
|
include/msgpack/adaptor/raw.hpp
|
||||||
|
include/msgpack/adaptor/raw_fwd.hpp
|
||||||
|
include/msgpack/adaptor/set.hpp
|
||||||
|
include/msgpack/adaptor/set_fwd.hpp
|
||||||
|
include/msgpack/adaptor/string.hpp
|
||||||
|
include/msgpack/adaptor/string_fwd.hpp
|
||||||
|
include/msgpack/adaptor/tr1/unordered_map.hpp
|
||||||
|
include/msgpack/adaptor/tr1/unordered_map_fwd.hpp
|
||||||
|
include/msgpack/adaptor/tr1/unordered_set.hpp
|
||||||
|
include/msgpack/adaptor/tr1/unordered_set_fwd.hpp
|
||||||
|
include/msgpack/adaptor/vector.hpp
|
||||||
|
include/msgpack/adaptor/vector_fwd.hpp
|
||||||
|
include/msgpack/adaptor/vector_bool.hpp
|
||||||
|
include/msgpack/adaptor/vector_bool_fwd.hpp
|
||||||
|
include/msgpack/adaptor/vector_char.hpp
|
||||||
|
include/msgpack/adaptor/vector_char_fwd.hpp
|
||||||
|
include/msgpack/cpp_config.hpp
|
||||||
|
include/msgpack/detail/cpp03_zone.hpp
|
||||||
|
include/msgpack/detail/cpp11_zone.hpp
|
||||||
|
include/msgpack/fbuffer.hpp
|
||||||
|
include/msgpack/object.hpp
|
||||||
|
include/msgpack/object_fwd.hpp
|
||||||
|
include/msgpack/pack.hpp
|
||||||
|
include/msgpack/sbuffer.hpp
|
||||||
|
include/msgpack/type.hpp
|
||||||
|
include/msgpack/unpack.hpp
|
||||||
|
include/msgpack/version.hpp
|
||||||
|
include/msgpack/versioning.hpp
|
||||||
|
include/msgpack/vrefbuffer.hpp
|
||||||
|
include/msgpack/zbuffer.hpp
|
||||||
|
include/msgpack/zone.hpp
|
||||||
|
)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
EXECUTE_PROCESS (
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_CURRENT_BINARY_DIR}/src/msgpack
|
||||||
|
)
|
||||||
|
|
||||||
|
CONFIGURE_FILE (
|
||||||
|
msgpack.pc.in
|
||||||
|
msgpack.pc
|
||||||
|
@ONLY
|
||||||
|
)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES (
|
||||||
|
./
|
||||||
|
include/
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/include/
|
||||||
|
)
|
||||||
|
|
||||||
|
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 4.0.0)
|
||||||
|
|
||||||
|
IF (MSGPACK_BUILD_TESTS)
|
||||||
|
ENABLE_TESTING ()
|
||||||
|
SET(CTEST_MEMORYCHECK_COMMAND "/usr/bin/valgrind")
|
||||||
|
INCLUDE(Dart)
|
||||||
|
SET(MEMORYCHECK_COMMAND_OPTIONS "--leak-check=full --error-exitcode=1")
|
||||||
|
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]" "/W3" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
|
||||||
|
ELSE ()
|
||||||
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W3")
|
||||||
|
ENDIF ()
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
IF ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC90" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC10")
|
||||||
|
SET_SOURCE_FILES_PROPERTIES(${msgpack_SOURCES} PROPERTIES LANGUAGE CXX)
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
|
IF (NOT DEFINED CMAKE_INSTALL_LIBDIR)
|
||||||
|
SET(CMAKE_INSTALL_LIBDIR lib)
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
INSTALL (TARGETS msgpack msgpack-static DESTINATION ${CMAKE_INSTALL_LIBDIR})
|
||||||
|
INSTALL (DIRECTORY include DESTINATION ${CMAKE_INSTALL_PREFIX})
|
||||||
|
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 ()
|
||||||
2
COPYING
2
COPYING
@@ -1,4 +1,4 @@
|
|||||||
Copyright (C) 2008-2009 FURUHASHI Sadayuki
|
Copyright (C) 2008-2010 FURUHASHI Sadayuki
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
|
|||||||
38
CROSSLANG.md
Normal file
38
CROSSLANG.md
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
MessagePack cross-language test cases
|
||||||
|
=====================================
|
||||||
|
|
||||||
|
## cases
|
||||||
|
|
||||||
|
Valid serialized data are stored in "cases.mpac" and "cases_compact.mpac".
|
||||||
|
These files describe same objects. And "cases.json" describes an array of the described objects.
|
||||||
|
|
||||||
|
Thus you can verify your implementations as comparing the objects.
|
||||||
|
|
||||||
|
|
||||||
|
## crosslang
|
||||||
|
|
||||||
|
The *crosslang* tool reads serialized data from stdin and writes re-serialize data to stdout.
|
||||||
|
|
||||||
|
There are C++ and Ruby implementation of crosslang tool. You can verify your implementation
|
||||||
|
as comparing that implementations.
|
||||||
|
|
||||||
|
### C++ version
|
||||||
|
|
||||||
|
$ cd ../cpp && ./configure && make && make install
|
||||||
|
or
|
||||||
|
$ port install msgpack # MacPorts
|
||||||
|
|
||||||
|
$ g++ -Wall crosslang.cc -lmsgpack -o crosslang
|
||||||
|
|
||||||
|
$ ./crosslang
|
||||||
|
Usage: ./crosslang [in-file] [out-file]
|
||||||
|
|
||||||
|
### Ruby version
|
||||||
|
|
||||||
|
$ gem install msgpack
|
||||||
|
or
|
||||||
|
$ port install rb_msgpack # MacPorts
|
||||||
|
|
||||||
|
$ ruby crosslang.rb
|
||||||
|
Usage: crosslang.rb [in-file] [out-file]
|
||||||
|
|
||||||
30
Makefile.am
30
Makefile.am
@@ -1,13 +1,21 @@
|
|||||||
if ENABLE_CXX
|
SUBDIRS = src test
|
||||||
SUBDIRS = c cpp
|
|
||||||
else
|
|
||||||
SUBDIRS = c
|
|
||||||
endif
|
|
||||||
|
|
||||||
nobase_include_HEADERS = \
|
DOC_FILES = \
|
||||||
msgpack/pack_define.h \
|
README.md \
|
||||||
msgpack/pack_template.h \
|
LICENSE \
|
||||||
msgpack/unpack_define.h \
|
NOTICE \
|
||||||
msgpack/unpack_template.h \
|
msgpack_vc8.vcproj \
|
||||||
msgpack/sysdep.h
|
msgpack_vc8.sln \
|
||||||
|
msgpack_vc.postbuild.bat
|
||||||
|
|
||||||
|
EXTRA_DIST = \
|
||||||
|
$(DOC_FILES) CMakeLists.txt test/CMakeLists.txt
|
||||||
|
|
||||||
|
pkgconfigdir = $(libdir)/pkgconfig
|
||||||
|
pkgconfig_DATA = msgpack.pc
|
||||||
|
|
||||||
|
doxygen:
|
||||||
|
./preprocess clean
|
||||||
|
cd src && $(MAKE) doxygen
|
||||||
|
./preprocess
|
||||||
|
|
||||||
|
|||||||
4
NOTICE
4
NOTICE
@@ -1,4 +0,0 @@
|
|||||||
MessagePack is developed by FURUHASHI Sadayuki, licensed under Apache License,
|
|
||||||
Version 2.0. The original software and related information is available at
|
|
||||||
http://msgpack.sourceforge.jp/.
|
|
||||||
|
|
||||||
194
QUICKSTART-C.md
Normal file
194
QUICKSTART-C.md
Normal file
@@ -0,0 +1,194 @@
|
|||||||
|
# Implementation Status
|
||||||
|
|
||||||
|
The serialization library is production-ready.
|
||||||
|
|
||||||
|
Currently, RPC implementation is not available.
|
||||||
|
|
||||||
|
# Install
|
||||||
|
|
||||||
|
|
||||||
|
## 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
|
||||||
|
```
|
||||||
|
|
||||||
|
## 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.
|
||||||
|
|
||||||
|
## Other UNIX-like platform with ./configure
|
||||||
|
|
||||||
|
On the other UNIX-like platforms, download source package from [Releases|http://msgpack.org/releases/cpp/] and run `./configure && make && make install`.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ wget http://msgpack.org/releases/cpp/msgpack-0.5.5.tar.gz
|
||||||
|
$ tar zxvf msgpack-0.5.5.tar.gz
|
||||||
|
$ cd msgpack-0.5.5
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
```
|
||||||
|
|
||||||
|
## Windows
|
||||||
|
|
||||||
|
On Windows, download source package from [here|https://sourceforge.net/projects/msgpack/files/] and extract it.
|
||||||
|
Then open `msgpack_vc8.vcproj` file and build it using batch build. It builds libraries on `lib/` folder and header files on `include/` folder.
|
||||||
|
|
||||||
|
You can build using command line as follows:
|
||||||
|
|
||||||
|
```
|
||||||
|
> vcbuild msgpack_vc2008.vcproj
|
||||||
|
> dir lib % DLL files are here
|
||||||
|
> dir include % header files are here
|
||||||
|
```
|
||||||
|
|
||||||
|
## Install from git repository
|
||||||
|
|
||||||
|
You need to install gcc (4.1.0 or higher), autotools.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ git clone git@github.com:msgpack/msgpack.git
|
||||||
|
$ cd msgpack/cpp
|
||||||
|
$ ./bootstrap
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
```
|
||||||
|
|
||||||
|
# Serialization QuickStart for C
|
||||||
|
|
||||||
|
## First program
|
||||||
|
|
||||||
|
Include `msgpack.h` header and link `msgpack` library to use MessagePack on your program.
|
||||||
|
|
||||||
|
```c
|
||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
|
||||||
|
/* creates buffer and serializer instance. */
|
||||||
|
msgpack_sbuffer* buffer = msgpack_sbuffer_new();
|
||||||
|
msgpack_packer* pk = msgpack_packer_new(buffer, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
/* serializes ["Hello", "MessagePack"]. */
|
||||||
|
msgpack_pack_array(pk, 2);
|
||||||
|
msgpack_pack_raw(pk, 5);
|
||||||
|
msgpack_pack_raw_body(pk, "Hello", 5);
|
||||||
|
msgpack_pack_raw(pk, 11);
|
||||||
|
msgpack_pack_raw_body(pk, "MessagePack", 11);
|
||||||
|
|
||||||
|
/* deserializes it. */
|
||||||
|
msgpack_unpacked msg;
|
||||||
|
msgpack_unpacked_init(&msg);
|
||||||
|
bool success = msgpack_unpack_next(&msg, buffer->data, buffer->size, NULL);
|
||||||
|
|
||||||
|
/* prints the deserialized object. */
|
||||||
|
msgpack_object obj = msg.data;
|
||||||
|
msgpack_object_print(stdout, obj); /*=> ["Hello", "MessagePack"] */
|
||||||
|
|
||||||
|
/* cleaning */
|
||||||
|
msgpack_sbuffer_free(buffer);
|
||||||
|
msgpack_packer_free(pk);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Simple program with a loop
|
||||||
|
|
||||||
|
```c
|
||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
|
||||||
|
/* creates buffer and serializer instance. */
|
||||||
|
msgpack_sbuffer* buffer = msgpack_sbuffer_new();
|
||||||
|
msgpack_packer* pk = msgpack_packer_new(buffer, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
int j;
|
||||||
|
|
||||||
|
for(j = 0; j<23; j++) {
|
||||||
|
/* NB: the buffer needs to be cleared on each iteration */
|
||||||
|
msgpack_sbuffer_clear(buffer);
|
||||||
|
|
||||||
|
/* serializes ["Hello", "MessagePack"]. */
|
||||||
|
msgpack_pack_array(pk, 3);
|
||||||
|
msgpack_pack_raw(pk, 5);
|
||||||
|
msgpack_pack_raw_body(pk, "Hello", 5);
|
||||||
|
msgpack_pack_raw(pk, 11);
|
||||||
|
msgpack_pack_raw_body(pk, "MessagePack", 11);
|
||||||
|
msgpack_pack_int(pk, j);
|
||||||
|
|
||||||
|
/* deserializes it. */
|
||||||
|
msgpack_unpacked msg;
|
||||||
|
msgpack_unpacked_init(&msg);
|
||||||
|
bool success = msgpack_unpack_next(&msg, buffer->data, buffer->size, NULL);
|
||||||
|
|
||||||
|
/* prints the deserialized object. */
|
||||||
|
msgpack_object obj = msg.data;
|
||||||
|
msgpack_object_print(stdout, obj); /*=> ["Hello", "MessagePack"] */
|
||||||
|
puts("");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* cleaning */
|
||||||
|
msgpack_sbuffer_free(buffer);
|
||||||
|
msgpack_packer_free(pk);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Streaming feature
|
||||||
|
|
||||||
|
```c
|
||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
/* serializes multiple objects using msgpack_packer. */
|
||||||
|
msgpack_sbuffer* buffer = msgpack_sbuffer_new();
|
||||||
|
msgpack_packer* pk = msgpack_packer_new(buffer, msgpack_sbuffer_write);
|
||||||
|
msgpack_pack_int(pk, 1);
|
||||||
|
msgpack_pack_int(pk, 2);
|
||||||
|
msgpack_pack_int(pk, 3);
|
||||||
|
|
||||||
|
/* deserializes these objects using msgpack_unpacker. */
|
||||||
|
msgpack_unpacker pac;
|
||||||
|
msgpack_unpacker_init(&pac, MSGPACK_UNPACKER_INIT_BUFFER_SIZE);
|
||||||
|
|
||||||
|
/* feeds the buffer. */
|
||||||
|
msgpack_unpacker_reserve_buffer(&pac, buffer->size);
|
||||||
|
memcpy(msgpack_unpacker_buffer(&pac), buffer->data, buffer->size);
|
||||||
|
msgpack_unpacker_buffer_consumed(&pac, buffer->size);
|
||||||
|
|
||||||
|
/* now starts streaming deserialization. */
|
||||||
|
msgpack_unpacked result;
|
||||||
|
msgpack_unpacked_init(&result);
|
||||||
|
|
||||||
|
while(msgpack_unpacker_next(&pac, &result)) {
|
||||||
|
msgpack_object_print(stdout, result.data);
|
||||||
|
puts("");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* results:
|
||||||
|
* $ gcc stream.cc -lmsgpack -o stream
|
||||||
|
* $ ./stream
|
||||||
|
* 1
|
||||||
|
* 2
|
||||||
|
* 3
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
```
|
||||||
159
QUICKSTART-CPP.md
Normal file
159
QUICKSTART-CPP.md
Normal file
@@ -0,0 +1,159 @@
|
|||||||
|
# Implementation Status
|
||||||
|
|
||||||
|
The serialization library is production-ready.
|
||||||
|
|
||||||
|
Currently, RPC implementation is in testing phase. Requires newer kernel, not running on RHEL5/CentOS5.
|
||||||
|
|
||||||
|
# Install
|
||||||
|
|
||||||
|
Same as QuickStart for C Language.
|
||||||
|
|
||||||
|
# Serialization QuickStart for C+\+
|
||||||
|
|
||||||
|
## First program
|
||||||
|
|
||||||
|
Include `msgpack.hpp` header and link `msgpack` library to use MessagePack on your program.
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
// serializes this object.
|
||||||
|
std::vector<std::string> vec;
|
||||||
|
vec.push_back("Hello");
|
||||||
|
vec.push_back("MessagePack");
|
||||||
|
|
||||||
|
// serialize it into simple buffer.
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, vec);
|
||||||
|
|
||||||
|
// deserialize it.
|
||||||
|
msgpack::unpacked msg;
|
||||||
|
msgpack::unpack(&msg, sbuf.data(), sbuf.size());
|
||||||
|
|
||||||
|
// print the deserialized object.
|
||||||
|
msgpack::object obj = msg.get();
|
||||||
|
std::cout << obj << std::endl; //=> ["Hello", "MessagePack"]
|
||||||
|
|
||||||
|
// convert it into statically typed object.
|
||||||
|
std::vector<std::string> rvec;
|
||||||
|
obj.convert(&rvec);
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Compile it as follows:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ g++ hello.cc -lmsgpack -o hello
|
||||||
|
$ ./hello
|
||||||
|
["Hello", "MessagePack"]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Streaming feature
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
// serializes multiple objects using msgpack::packer.
|
||||||
|
msgpack::sbuffer buffer;
|
||||||
|
|
||||||
|
msgpack::packer<msgpack::sbuffer> pk(&buffer);
|
||||||
|
pk.pack(std::string("Log message ... 1"));
|
||||||
|
pk.pack(std::string("Log message ... 2"));
|
||||||
|
pk.pack(std::string("Log message ... 3"));
|
||||||
|
|
||||||
|
// deserializes these objects using msgpack::unpacker.
|
||||||
|
msgpack::unpacker pac;
|
||||||
|
|
||||||
|
// feeds the buffer.
|
||||||
|
pac.reserve_buffer(buffer.size());
|
||||||
|
memcpy(pac.buffer(), buffer.data(), buffer.size());
|
||||||
|
pac.buffer_consumed(buffer.size());
|
||||||
|
|
||||||
|
// now starts streaming deserialization.
|
||||||
|
msgpack::unpacked result;
|
||||||
|
while(pac.next(&result)) {
|
||||||
|
std::cout << result.get() << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
// results:
|
||||||
|
// $ g++ stream.cc -lmsgpack -o stream
|
||||||
|
// $ ./stream
|
||||||
|
// "Log message ... 1"
|
||||||
|
// "Log message ... 2"
|
||||||
|
// "Log message ... 3"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Streaming into an array or map
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
// serializes multiple objects into one message containing an array using msgpack::packer.
|
||||||
|
msgpack::sbuffer buffer;
|
||||||
|
|
||||||
|
msgpack::packer<msgpack::sbuffer> pk(&buffer);
|
||||||
|
pk.pack_array(3);
|
||||||
|
pk.pack(std::string("Log message ... 1"));
|
||||||
|
pk.pack(std::string("Log message ... 2"));
|
||||||
|
pk.pack(std::string("Log message ... 3"));
|
||||||
|
|
||||||
|
// serializes multiple objects into one message containing a map using msgpack::packer.
|
||||||
|
msgpack::sbuffer buffer2;
|
||||||
|
|
||||||
|
msgpack::packer<msgpack::sbuffer> pk2(&buffer2);
|
||||||
|
pk2.pack_map(2);
|
||||||
|
pk2.pack(std::string("x"));
|
||||||
|
pk2.pack(3);
|
||||||
|
pk2.pack(std::string("y"));
|
||||||
|
pk2.pack(3.4321);
|
||||||
|
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## User-defined classes
|
||||||
|
|
||||||
|
You can use serialize/deserializes user-defined classes using `MSGPACK_DEFINE` macro.
|
||||||
|
|
||||||
|
```cpp
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
class myclass {
|
||||||
|
private:
|
||||||
|
std::string m_str;
|
||||||
|
std::vector<int> m_vec;
|
||||||
|
public:
|
||||||
|
MSGPACK_DEFINE(m_str, m_vec);
|
||||||
|
};
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
std::vector<myclass> vec;
|
||||||
|
// add some elements into vec...
|
||||||
|
|
||||||
|
// you can serialize myclass directly
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, vec);
|
||||||
|
|
||||||
|
msgpack::unpacked msg;
|
||||||
|
msgpack::unpack(&msg, sbuf.data(), sbuf.size());
|
||||||
|
|
||||||
|
msgpack::object obj = msg.get();
|
||||||
|
|
||||||
|
// you can convert object to myclass directly
|
||||||
|
std::vector<myclass> rvec;
|
||||||
|
obj.convert(&rvec);
|
||||||
|
}
|
||||||
|
```
|
||||||
70
README
70
README
@@ -1,70 +0,0 @@
|
|||||||
MessagePack
|
|
||||||
-----------
|
|
||||||
Binary-based efficient data interchange format.
|
|
||||||
|
|
||||||
|
|
||||||
*Requirements
|
|
||||||
|
|
||||||
MessagePack is only tested on Linux and Mac OS X, but it may run on other
|
|
||||||
UNIX-like platforms.
|
|
||||||
|
|
||||||
gcc >= 4.1 is required to build.
|
|
||||||
|
|
||||||
|
|
||||||
*Installation
|
|
||||||
|
|
||||||
Simply run ./configure && make && make install to install C and C++ binding.
|
|
||||||
|
|
||||||
$ ./configure
|
|
||||||
$ make
|
|
||||||
$ sudo make install
|
|
||||||
|
|
||||||
To install Ruby binding, run ./gengem.sh script on ruby/ directory and install
|
|
||||||
generated gem package.
|
|
||||||
|
|
||||||
$ cd ruby
|
|
||||||
$ ./gengem.sh
|
|
||||||
$ gem install gem/pkg/msgpack-*.gem
|
|
||||||
|
|
||||||
|
|
||||||
*Usage
|
|
||||||
|
|
||||||
C++:
|
|
||||||
include msgpack.hpp header and link libmsgpack library.
|
|
||||||
see example/simple.cc for example.
|
|
||||||
|
|
||||||
g++ simple.cc -lmsgpack
|
|
||||||
g++ stream.cc -lmsgpack -lpthread
|
|
||||||
|
|
||||||
|
|
||||||
C:
|
|
||||||
include msgpack.h header and link libmsgpackc library.
|
|
||||||
see example/simple.c for example.
|
|
||||||
|
|
||||||
gcc simple.c -lmsgpackc
|
|
||||||
|
|
||||||
|
|
||||||
Ruby:
|
|
||||||
require msgpack library.
|
|
||||||
see example/simple.rb for example.
|
|
||||||
|
|
||||||
ruby -rubygems simple.rb
|
|
||||||
|
|
||||||
|
|
||||||
API Document is available at http://msgpack.sourceforge.jp/.
|
|
||||||
|
|
||||||
|
|
||||||
Copyright (C) 2008-2009 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.
|
|
||||||
|
|
||||||
219
README.md
Normal file
219
README.md
Normal file
@@ -0,0 +1,219 @@
|
|||||||
|
`msgpack` for C/C++
|
||||||
|
===================
|
||||||
|
|
||||||
|
Version 1.0.1 [](https://travis-ci.org/msgpack/msgpack-c)
|
||||||
|
|
||||||
|
It's like JSON but small and fast.
|
||||||
|
|
||||||
|
Overview
|
||||||
|
--------
|
||||||
|
|
||||||
|
[MessagePack](http://msgpack.org/) is an efficient binary serialization
|
||||||
|
format, which lets you exchange data among multiple languages like JSON,
|
||||||
|
except that it's faster and smaller. Small integers are encoded into a
|
||||||
|
single byte while typical short strings require only one extra byte in
|
||||||
|
addition to the strings themselves.
|
||||||
|
|
||||||
|
Example
|
||||||
|
-------
|
||||||
|
|
||||||
|
In C:
|
||||||
|
|
||||||
|
```c
|
||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
/* msgpack::sbuffer is a simple buffer implementation. */
|
||||||
|
msgpack_sbuffer sbuf;
|
||||||
|
msgpack_sbuffer_init(&sbuf);
|
||||||
|
|
||||||
|
/* serialize values into the buffer using msgpack_sbuffer_write callback function. */
|
||||||
|
msgpack_packer pk;
|
||||||
|
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
msgpack_pack_array(&pk, 3);
|
||||||
|
msgpack_pack_int(&pk, 1);
|
||||||
|
msgpack_pack_true(&pk);
|
||||||
|
msgpack_pack_str(&pk, 7);
|
||||||
|
msgpack_pack_str_body(&pk, "example", 7);
|
||||||
|
|
||||||
|
/* deserialize the buffer into msgpack_object instance. */
|
||||||
|
/* deserialized object is valid during the msgpack_zone instance alive. */
|
||||||
|
msgpack_zone mempool;
|
||||||
|
msgpack_zone_init(&mempool, 2048);
|
||||||
|
|
||||||
|
msgpack_object deserialized;
|
||||||
|
msgpack_unpack(sbuf.data, sbuf.size, NULL, &mempool, &deserialized);
|
||||||
|
|
||||||
|
/* print the deserialized object. */
|
||||||
|
msgpack_object_print(stdout, deserialized);
|
||||||
|
puts("");
|
||||||
|
|
||||||
|
msgpack_zone_destroy(&mempool);
|
||||||
|
msgpack_sbuffer_destroy(&sbuf);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
See [`QUICKSTART-C.md`](./QUICKSTART-C.md) for more details.
|
||||||
|
|
||||||
|
In C++:
|
||||||
|
|
||||||
|
```c++
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
msgpack::type::tuple<int, bool, std::string> src(1, true, "example");
|
||||||
|
|
||||||
|
// serialize the object into the buffer.
|
||||||
|
// any classes that implements write(const char*,size_t) can be a buffer.
|
||||||
|
std::stringstream buffer;
|
||||||
|
msgpack::pack(buffer, src);
|
||||||
|
|
||||||
|
// send the buffer ...
|
||||||
|
buffer.seekg(0);
|
||||||
|
|
||||||
|
// deserialize the buffer into msgpack::object instance.
|
||||||
|
std::string str(buffer.str());
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
|
||||||
|
msgpack::unpack(result, str.data(), str.size());
|
||||||
|
|
||||||
|
// deserialized object is valid during the msgpack::unpacked instance alive.
|
||||||
|
msgpack::object deserialized = result.get();
|
||||||
|
|
||||||
|
// msgpack::object supports ostream.
|
||||||
|
std::cout << deserialized << std::endl;
|
||||||
|
|
||||||
|
// convert msgpack::object instance into the original type.
|
||||||
|
// if the type is mismatched, it throws msgpack::type_error exception.
|
||||||
|
msgpack::type::tuple<int, bool, std::string> dst;
|
||||||
|
deserialized.convert(&dst);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
See [`QUICKSTART-CPP.md`](./QUICKSTART-CPP.md) for more details.
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
### C++ Header Only Library
|
||||||
|
|
||||||
|
When you use msgpack on C++03 and C++11, you can just add
|
||||||
|
msgpack-c/include to your include path:
|
||||||
|
|
||||||
|
g++ -I msgpack-c/include your_source_file.cpp
|
||||||
|
|
||||||
|
If you want to use C version of msgpack, you need to build it. You can
|
||||||
|
also install the C and C++ versions of msgpack.
|
||||||
|
|
||||||
|
### Building and Installing
|
||||||
|
|
||||||
|
#### Install from git repository
|
||||||
|
|
||||||
|
##### Using autotools
|
||||||
|
|
||||||
|
You will need:
|
||||||
|
|
||||||
|
- `gcc >= 4.1.0` or `clang >= 3.3.0`
|
||||||
|
- `autoconf >= 2.60`
|
||||||
|
- `automake >= 1.10`
|
||||||
|
- `libtool >= 2.2.4`
|
||||||
|
|
||||||
|
The build steps below are for C and C++03. If compiling for C++11,
|
||||||
|
add `-std=c++11` to the environmental variable `CXXFLAGS` with
|
||||||
|
`export CXXFLAGS="$CXXFLAGS -std=c++11"` prior to following the
|
||||||
|
directions below.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c
|
||||||
|
$ cd msgpack-c
|
||||||
|
$ ./bootstrap
|
||||||
|
$ ./configure
|
||||||
|
$ make
|
||||||
|
```
|
||||||
|
|
||||||
|
You can install the resulting library like this:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ sudo make install
|
||||||
|
```
|
||||||
|
##### Using cmake
|
||||||
|
|
||||||
|
###### Using the Terminal (CLI)
|
||||||
|
|
||||||
|
You will need:
|
||||||
|
|
||||||
|
- `gcc >= 4.1.0`
|
||||||
|
- `cmake >= 2.8.0`
|
||||||
|
|
||||||
|
C and C++03:
|
||||||
|
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c.git
|
||||||
|
$ cd msgpack-c
|
||||||
|
$ cmake .
|
||||||
|
$ make
|
||||||
|
$ sudo make install
|
||||||
|
|
||||||
|
If you want to setup C++11 version of msgpack instead,
|
||||||
|
execute the following commands:
|
||||||
|
|
||||||
|
$ git clone https://github.com/msgpack/msgpack-c.git
|
||||||
|
$ cd msgpack-c
|
||||||
|
$ cmake -DMSGPACK_CXX11=ON .
|
||||||
|
$ sudo make install
|
||||||
|
|
||||||
|
##### GUI on 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/
|
||||||
|
|
||||||
|
1. Launch [cmake GUI client](http://www.cmake.org/cmake/resources/software.html).
|
||||||
|
|
||||||
|
2. Set 'Where is the source code:' text box and 'Where to build
|
||||||
|
the binaries:' text box.
|
||||||
|
|
||||||
|
3. Click 'Configure' button.
|
||||||
|
|
||||||
|
4. Choose your Visual Studio version.
|
||||||
|
|
||||||
|
5. Click 'Generate' button.
|
||||||
|
|
||||||
|
6. Open the created msgpack.sln on Visual Studio.
|
||||||
|
|
||||||
|
7. Build all.
|
||||||
|
|
||||||
|
### Documentation
|
||||||
|
|
||||||
|
You can get addtional information on the
|
||||||
|
[wiki](https://github.com/msgpack/msgpack-c/wiki/).
|
||||||
|
|
||||||
|
Contributing
|
||||||
|
------------
|
||||||
|
|
||||||
|
`msgpack-c` is developed on GitHub at [msgpack/msgpack-c](https://github.com/msgpack/msgpack-c).
|
||||||
|
To report an issue or send a pull request, use the
|
||||||
|
[issue tracker](https://github.com/msgpack/msgpack-c/issues).
|
||||||
|
|
||||||
|
Here's the list of [great contributors](https://github.com/msgpack/msgpack-c/graphs/contributors).
|
||||||
|
|
||||||
|
License
|
||||||
|
-------
|
||||||
|
|
||||||
|
`msgpack-c` is licensed under the Apache License Version 2.0. See
|
||||||
|
the [`LICENSE`](./LICENSE) file for details.
|
||||||
@@ -32,8 +32,12 @@ fi
|
|||||||
|
|
||||||
|
|
||||||
mkdir -p ac
|
mkdir -p ac
|
||||||
(cd cpp && ./preprocess.sh $@; cd ..)
|
test -f AUTHORS || touch AUTHORS
|
||||||
|
test -f COPYING || touch COPYING
|
||||||
|
test -f ChangeLog || touch ChangeLog
|
||||||
|
test -f NEWS || touch NEWS
|
||||||
|
test -f NOTICE || touch NOTICE
|
||||||
|
test -f README || cp -f README.md README
|
||||||
|
|
||||||
ACLOCAL="aclocal"
|
ACLOCAL="aclocal"
|
||||||
ACLOCAL_FILES="aclocal.m4"
|
ACLOCAL_FILES="aclocal.m4"
|
||||||
|
|||||||
@@ -1,28 +0,0 @@
|
|||||||
lib_LTLIBRARIES = libmsgpackc.la
|
|
||||||
|
|
||||||
libmsgpackc_la_SOURCES = \
|
|
||||||
unpack.c \
|
|
||||||
object.c \
|
|
||||||
vrefbuffer.c \
|
|
||||||
zone.c
|
|
||||||
|
|
||||||
nobase_include_HEADERS = \
|
|
||||||
msgpack.h \
|
|
||||||
msgpack/sbuffer.h \
|
|
||||||
msgpack/vrefbuffer.h \
|
|
||||||
msgpack/pack.h \
|
|
||||||
msgpack/unpack.h \
|
|
||||||
msgpack/object.h \
|
|
||||||
msgpack/zone.h
|
|
||||||
|
|
||||||
# -version-info CURRENT:REVISION:AGE
|
|
||||||
libmsgpackc_la_LDFLAGS = -version-info 2:0:0
|
|
||||||
|
|
||||||
check_PROGRAMS = \
|
|
||||||
msgpackc_test
|
|
||||||
|
|
||||||
msgpackc_test_SOURCES = test.cpp
|
|
||||||
msgpackc_test_CXXFLAGS = -I$(top_srcdir) -I$(top_srcdir)/c
|
|
||||||
msgpackc_test_LDFLAGS = libmsgpackc.la -lgtest_main
|
|
||||||
|
|
||||||
TESTS = $(check_PROGRAMS)
|
|
||||||
323
c/bench.c
323
c/bench.c
@@ -1,323 +0,0 @@
|
|||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/time.h>
|
|
||||||
|
|
||||||
#include <msgpack/pack.h>
|
|
||||||
#include <msgpack/unpack.h>
|
|
||||||
#include <yajl/yajl_parse.h>
|
|
||||||
#include <yajl/yajl_gen.h>
|
|
||||||
|
|
||||||
|
|
||||||
static struct timeval g_timer;
|
|
||||||
|
|
||||||
void reset_timer()
|
|
||||||
{
|
|
||||||
gettimeofday(&g_timer, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void show_timer(size_t bufsz)
|
|
||||||
{
|
|
||||||
struct timeval endtime;
|
|
||||||
gettimeofday(&endtime, NULL);
|
|
||||||
double sec = (endtime.tv_sec - g_timer.tv_sec)
|
|
||||||
+ (double)(endtime.tv_usec - g_timer.tv_usec) / 1000 / 1000;
|
|
||||||
printf("%f sec\n", sec);
|
|
||||||
printf("%f MB\n", ((double)bufsz)/1024/1024);
|
|
||||||
printf("%f Mbps\n", ((double)bufsz)*8/sec/1000/1000);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int reformat_null(void * ctx) { return 1; }
|
|
||||||
static int reformat_boolean(void * ctx, int boolean) { return 1; }
|
|
||||||
static int reformat_number(void * ctx, const char * s, unsigned int l) { return 1; }
|
|
||||||
static int reformat_string(void * ctx, const unsigned char * stringVal, unsigned int stringLen) { return 1; }
|
|
||||||
static int reformat_map_key(void * ctx, const unsigned char * stringVal, unsigned int stringLen) { return 1; }
|
|
||||||
static int reformat_start_map(void * ctx) { return 1; }
|
|
||||||
static int reformat_end_map(void * ctx) { return 1; }
|
|
||||||
static int reformat_start_array(void * ctx) { return 1; }
|
|
||||||
static int reformat_end_array(void * ctx) { return 1; }
|
|
||||||
|
|
||||||
|
|
||||||
static void* unpack_uint8(void* data, uint8_t d) { return NULL; }
|
|
||||||
static void* unpack_uint16(void* data, uint16_t d) { return NULL; }
|
|
||||||
static void* unpack_uint32(void* data, uint32_t d) { return NULL; }
|
|
||||||
static void* unpack_uint64(void* data, uint64_t d) { return NULL; }
|
|
||||||
static void* unpack_int8(void* data, int8_t d) { return NULL; }
|
|
||||||
static void* unpack_int16(void* data, int16_t d) { return NULL; }
|
|
||||||
static void* unpack_int32(void* data, int32_t d) { return NULL; }
|
|
||||||
static void* unpack_int64(void* data, int64_t d) { return NULL; }
|
|
||||||
static void* unpack_float(void* data, float d) { return NULL; }
|
|
||||||
static void* unpack_double(void* data, double d) { return NULL; }
|
|
||||||
static void* unpack_nil(void* data) { return NULL; }
|
|
||||||
static void* unpack_true(void* data) { return NULL; }
|
|
||||||
static void* unpack_false(void* data) { return NULL; }
|
|
||||||
static void* unpack_array(void* data, unsigned int n) { return NULL; }
|
|
||||||
static void unpack_array_item(void* data, void* c, void* o) { }
|
|
||||||
static void* unpack_map(void* data, unsigned int n) { return NULL; }
|
|
||||||
static void unpack_map_item(void* data, void* c, void* k, void* v) { }
|
|
||||||
static void* unpack_raw(void* data, const char* b, const char* p, unsigned int l) { /*printf("unpack raw %p %lu\n",p,l);*/ return NULL; }
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
size_t allocated;
|
|
||||||
size_t length;
|
|
||||||
char* buffer;
|
|
||||||
} pack_buffer;
|
|
||||||
|
|
||||||
static const size_t PACK_INITIAL_BUFFER_SIZE = 32*1024;
|
|
||||||
|
|
||||||
static void pack_buffer_init(pack_buffer* data)
|
|
||||||
{
|
|
||||||
data->buffer = malloc(PACK_INITIAL_BUFFER_SIZE);
|
|
||||||
data->length = 0;
|
|
||||||
data->allocated = PACK_INITIAL_BUFFER_SIZE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void pack_buffer_reset(pack_buffer* data)
|
|
||||||
{
|
|
||||||
data->buffer = realloc(data->buffer, PACK_INITIAL_BUFFER_SIZE);
|
|
||||||
data->allocated = PACK_INITIAL_BUFFER_SIZE;
|
|
||||||
data->length = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void pack_buffer_free(pack_buffer* data)
|
|
||||||
{
|
|
||||||
free(data->buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void pack_append_buffer(void* user, const char* b, unsigned int l)
|
|
||||||
{
|
|
||||||
pack_buffer* data = (pack_buffer*)user;
|
|
||||||
if(data->allocated - data->length < l) {
|
|
||||||
data->buffer = realloc(data->buffer, data->allocated*2);
|
|
||||||
data->allocated *= 2;
|
|
||||||
}
|
|
||||||
memcpy(data->buffer + data->length, b, l);
|
|
||||||
data->length += l;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static const unsigned int TASK_INT_NUM = 1<<24;
|
|
||||||
static const unsigned int TASK_STR_LEN = 1<<15;
|
|
||||||
//static const unsigned int TASK_INT_NUM = 1<<20;
|
|
||||||
//static const unsigned int TASK_STR_LEN = 1<<12;
|
|
||||||
static const char* TASK_STR_PTR;
|
|
||||||
|
|
||||||
|
|
||||||
void bench_json(void)
|
|
||||||
{
|
|
||||||
puts("== JSON ==");
|
|
||||||
|
|
||||||
|
|
||||||
yajl_gen_config gcfg = {0, NULL};
|
|
||||||
yajl_gen g = yajl_gen_alloc(&gcfg);
|
|
||||||
|
|
||||||
yajl_parser_config hcfg = { 0, 0 };
|
|
||||||
yajl_callbacks callbacks = {
|
|
||||||
reformat_null,
|
|
||||||
reformat_boolean,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
reformat_number,
|
|
||||||
reformat_string,
|
|
||||||
reformat_start_map,
|
|
||||||
reformat_map_key,
|
|
||||||
reformat_end_map,
|
|
||||||
reformat_start_array,
|
|
||||||
reformat_end_array
|
|
||||||
};
|
|
||||||
yajl_handle h = yajl_alloc(&callbacks, &hcfg, NULL);
|
|
||||||
|
|
||||||
|
|
||||||
const unsigned char * buf;
|
|
||||||
unsigned int len;
|
|
||||||
|
|
||||||
|
|
||||||
puts("generate integer");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
yajl_gen_array_open(g);
|
|
||||||
for(i=0; i < TASK_INT_NUM; ++i) {
|
|
||||||
yajl_gen_integer(g, i);
|
|
||||||
}
|
|
||||||
yajl_gen_array_close(g);
|
|
||||||
}
|
|
||||||
show_timer(len);
|
|
||||||
|
|
||||||
yajl_gen_get_buf(g, &buf, &len);
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("parse integer");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
yajl_status stat = yajl_parse(h, buf, len);
|
|
||||||
if (stat != yajl_status_ok && stat != yajl_status_insufficient_data) {
|
|
||||||
unsigned char * str = yajl_get_error(h, 1, buf, len);
|
|
||||||
fprintf(stderr, (const char *) str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(len);
|
|
||||||
|
|
||||||
|
|
||||||
//yajl_gen_clear(g);
|
|
||||||
yajl_gen_free(g);
|
|
||||||
g = yajl_gen_alloc(&gcfg);
|
|
||||||
yajl_free(h);
|
|
||||||
h = yajl_alloc(&callbacks, &hcfg, NULL);
|
|
||||||
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("generate string");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
yajl_gen_array_open(g);
|
|
||||||
for(i=0; i < TASK_STR_LEN; ++i) {
|
|
||||||
yajl_gen_string(g, (const unsigned char*)TASK_STR_PTR, i);
|
|
||||||
}
|
|
||||||
yajl_gen_array_close(g);
|
|
||||||
}
|
|
||||||
show_timer(len);
|
|
||||||
|
|
||||||
yajl_gen_get_buf(g, &buf, &len);
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("parse string");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
yajl_status stat = yajl_parse(h, buf, len);
|
|
||||||
if (stat != yajl_status_ok && stat != yajl_status_insufficient_data) {
|
|
||||||
unsigned char * str = yajl_get_error(h, 1, buf, len);
|
|
||||||
fprintf(stderr, (const char *) str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(len);
|
|
||||||
|
|
||||||
|
|
||||||
yajl_gen_free(g);
|
|
||||||
yajl_free(h);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void bench_msgpack(void)
|
|
||||||
{
|
|
||||||
puts("== MessagePack ==");
|
|
||||||
|
|
||||||
|
|
||||||
pack_buffer mpkbuf;
|
|
||||||
pack_buffer_init(&mpkbuf);
|
|
||||||
|
|
||||||
msgpack_pack_t* mpk = msgpack_pack_new(
|
|
||||||
&mpkbuf, pack_append_buffer);
|
|
||||||
|
|
||||||
msgpack_unpack_callback cb = {
|
|
||||||
unpack_uint8,
|
|
||||||
unpack_uint16,
|
|
||||||
unpack_uint32,
|
|
||||||
unpack_uint64,
|
|
||||||
unpack_int8,
|
|
||||||
unpack_int16,
|
|
||||||
unpack_int32,
|
|
||||||
unpack_int64,
|
|
||||||
unpack_float,
|
|
||||||
unpack_double,
|
|
||||||
unpack_nil,
|
|
||||||
unpack_true,
|
|
||||||
unpack_false,
|
|
||||||
unpack_array,
|
|
||||||
unpack_array_item,
|
|
||||||
unpack_map,
|
|
||||||
unpack_map_item,
|
|
||||||
unpack_raw,
|
|
||||||
};
|
|
||||||
msgpack_unpack_t* mupk = msgpack_unpack_new(NULL, &cb);
|
|
||||||
|
|
||||||
|
|
||||||
size_t len;
|
|
||||||
const char* buf;
|
|
||||||
|
|
||||||
|
|
||||||
puts("pack integer");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
msgpack_pack_array(mpk, TASK_INT_NUM);
|
|
||||||
for(i=0; i < TASK_INT_NUM; ++i) {
|
|
||||||
msgpack_pack_unsigned_int(mpk, i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(mpkbuf.length);
|
|
||||||
|
|
||||||
len = mpkbuf.length;
|
|
||||||
buf = mpkbuf.buffer;
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("unpack integer");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
size_t off = 0;
|
|
||||||
int ret = msgpack_unpack_execute(mupk, buf, len, &off);
|
|
||||||
if(ret < 0) {
|
|
||||||
fprintf(stderr, "Parse error.\n");
|
|
||||||
} else if(ret == 0) {
|
|
||||||
fprintf(stderr, "Not finished.\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(mpkbuf.length);
|
|
||||||
|
|
||||||
|
|
||||||
pack_buffer_reset(&mpkbuf);
|
|
||||||
msgpack_unpack_reset(mupk);
|
|
||||||
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("pack string");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
msgpack_pack_array(mpk, TASK_STR_LEN);
|
|
||||||
for(i=0; i < TASK_STR_LEN; ++i) {
|
|
||||||
msgpack_pack_raw(mpk, i);
|
|
||||||
msgpack_pack_raw_body(mpk, TASK_STR_PTR, i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(mpkbuf.length);
|
|
||||||
|
|
||||||
len = mpkbuf.length;
|
|
||||||
buf = mpkbuf.buffer;
|
|
||||||
|
|
||||||
puts("----");
|
|
||||||
puts("unpack string");
|
|
||||||
reset_timer();
|
|
||||||
{
|
|
||||||
size_t off = 0;
|
|
||||||
int ret = msgpack_unpack_execute(mupk, buf, len, &off);
|
|
||||||
if(ret < 0) {
|
|
||||||
fprintf(stderr, "Parse error.\n");
|
|
||||||
} else if(ret == 0) {
|
|
||||||
fprintf(stderr, "Not finished.\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
show_timer(mpkbuf.length);
|
|
||||||
|
|
||||||
|
|
||||||
msgpack_unpack_free(mupk);
|
|
||||||
msgpack_pack_free(mpk);
|
|
||||||
pack_buffer_free(&mpkbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
|
||||||
{
|
|
||||||
char* str = malloc(TASK_STR_LEN);
|
|
||||||
memset(str, 'a', TASK_STR_LEN);
|
|
||||||
TASK_STR_PTR = str;
|
|
||||||
|
|
||||||
bench_msgpack();
|
|
||||||
bench_json();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
|
|
||||||
CFLAGS += -Wall -g -I. -I.. -O4
|
|
||||||
LDFLAGS += -lyajl
|
|
||||||
|
|
||||||
all: bench
|
|
||||||
|
|
||||||
bench: bench.o pack.o unpack.o pack.h unpack.h
|
|
||||||
$(CC) bench.o pack.o unpack.o $(CFLAGS) $(LDFLAGS) -o $@
|
|
||||||
|
|
||||||
171
c/object.c
171
c/object.c
@@ -1,171 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C dynamic typing routine
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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.
|
|
||||||
*/
|
|
||||||
#include "msgpack/object.h"
|
|
||||||
#include "msgpack/pack.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#ifndef _MSC_VER
|
|
||||||
#include <inttypes.h>
|
|
||||||
#else
|
|
||||||
#ifndef PRIu64
|
|
||||||
#define PRIu64 "I64u"
|
|
||||||
#endif
|
|
||||||
#ifndef PRIi64
|
|
||||||
#define PRIi64 "I64d"
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
int msgpack_pack_object(msgpack_packer* pk, msgpack_object d)
|
|
||||||
{
|
|
||||||
switch(d.type) {
|
|
||||||
case MSGPACK_OBJECT_NIL:
|
|
||||||
return msgpack_pack_nil(pk);
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_BOOLEAN:
|
|
||||||
if(d.via.boolean) {
|
|
||||||
return msgpack_pack_true(pk);
|
|
||||||
} else {
|
|
||||||
return msgpack_pack_false(pk);
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_POSITIVE_INTEGER:
|
|
||||||
return msgpack_pack_uint64(pk, d.via.u64);
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_NEGATIVE_INTEGER:
|
|
||||||
return msgpack_pack_int64(pk, d.via.i64);
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_DOUBLE:
|
|
||||||
return msgpack_pack_double(pk, d.via.dec);
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_RAW:
|
|
||||||
{
|
|
||||||
int ret = msgpack_pack_raw(pk, d.via.raw.size);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
return msgpack_pack_raw_body(pk, d.via.raw.ptr, d.via.raw.size);
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_ARRAY:
|
|
||||||
{
|
|
||||||
int ret = msgpack_pack_array(pk, d.via.array.size);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
|
|
||||||
msgpack_object* o = d.via.array.ptr;
|
|
||||||
msgpack_object* const oend = d.via.array.ptr + d.via.array.size;
|
|
||||||
for(; o != oend; ++o) {
|
|
||||||
ret = msgpack_pack_object(pk, *o);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_MAP:
|
|
||||||
{
|
|
||||||
int ret = msgpack_pack_map(pk, d.via.map.size);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
|
|
||||||
msgpack_object_kv* kv = d.via.map.ptr;
|
|
||||||
msgpack_object_kv* const kvend = d.via.map.ptr + d.via.map.size;
|
|
||||||
for(; kv != kvend; ++kv) {
|
|
||||||
ret = msgpack_pack_object(pk, kv->key);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
ret = msgpack_pack_object(pk, kv->val);
|
|
||||||
if(ret < 0) { return ret; }
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void msgpack_object_print(FILE* out, msgpack_object o)
|
|
||||||
{
|
|
||||||
switch(o.type) {
|
|
||||||
case MSGPACK_OBJECT_NIL:
|
|
||||||
fprintf(out, "nil");
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_BOOLEAN:
|
|
||||||
fprintf(out, (o.via.boolean ? "true" : "false"));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_POSITIVE_INTEGER:
|
|
||||||
fprintf(out, "%"PRIu64, o.via.u64);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_NEGATIVE_INTEGER:
|
|
||||||
fprintf(out, "%"PRIi64, o.via.i64);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_DOUBLE:
|
|
||||||
fprintf(out, "%f", o.via.dec);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_RAW:
|
|
||||||
fprintf(out, "\"");
|
|
||||||
fwrite(o.via.raw.ptr, o.via.raw.size, 1, out);
|
|
||||||
fprintf(out, "\"");
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_ARRAY:
|
|
||||||
fprintf(out, "[");
|
|
||||||
if(o.via.array.size != 0) {
|
|
||||||
msgpack_object* p = o.via.array.ptr;
|
|
||||||
msgpack_object_print(out, *p);
|
|
||||||
++p;
|
|
||||||
msgpack_object* const pend = o.via.array.ptr + o.via.array.size;
|
|
||||||
for(; p < pend; ++p) {
|
|
||||||
fprintf(out, ", ");
|
|
||||||
msgpack_object_print(out, *p);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fprintf(out, "]");
|
|
||||||
break;
|
|
||||||
// FIXME loop optimiziation
|
|
||||||
|
|
||||||
case MSGPACK_OBJECT_MAP:
|
|
||||||
fprintf(out, "{");
|
|
||||||
if(o.via.map.size != 0) {
|
|
||||||
msgpack_object_kv* p = o.via.map.ptr;
|
|
||||||
msgpack_object_print(out, p->key);
|
|
||||||
fprintf(out, "=>");
|
|
||||||
msgpack_object_print(out, p->val);
|
|
||||||
++p;
|
|
||||||
msgpack_object_kv* const pend = o.via.map.ptr + o.via.map.size;
|
|
||||||
for(; p < pend; ++p) {
|
|
||||||
fprintf(out, ", ");
|
|
||||||
msgpack_object_print(out, p->key);
|
|
||||||
fprintf(out, "=>");
|
|
||||||
msgpack_object_print(out, p->val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fprintf(out, "}");
|
|
||||||
break;
|
|
||||||
// FIXME loop optimiziation
|
|
||||||
|
|
||||||
default:
|
|
||||||
// FIXME
|
|
||||||
fprintf(out, "#<UNKNOWN %hu %"PRIu64">", o.type, o.via.u64);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
89
c/object.h
89
c/object.h
@@ -1,89 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C dynamic typing routine
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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_OBJECT_H__
|
|
||||||
#define MSGPACK_OBJECT_H__
|
|
||||||
|
|
||||||
#include "msgpack/zone.h"
|
|
||||||
#include "msgpack/sysdep.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
MSGPACK_OBJECT_NIL = 0x01,
|
|
||||||
MSGPACK_OBJECT_BOOLEAN = 0x02,
|
|
||||||
MSGPACK_OBJECT_POSITIVE_INTEGER = 0x03,
|
|
||||||
MSGPACK_OBJECT_NEGATIVE_INTEGER = 0x04,
|
|
||||||
MSGPACK_OBJECT_DOUBLE = 0x05,
|
|
||||||
MSGPACK_OBJECT_RAW = 0x06,
|
|
||||||
MSGPACK_OBJECT_ARRAY = 0x07,
|
|
||||||
MSGPACK_OBJECT_MAP = 0x08,
|
|
||||||
} msgpack_object_type;
|
|
||||||
|
|
||||||
|
|
||||||
struct msgpack_object;
|
|
||||||
struct msgpack_object_kv;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
uint32_t size;
|
|
||||||
struct msgpack_object* ptr;
|
|
||||||
} msgpack_object_array;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
uint32_t size;
|
|
||||||
struct msgpack_object_kv* ptr;
|
|
||||||
} msgpack_object_map;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
uint32_t size;
|
|
||||||
const char* ptr;
|
|
||||||
} msgpack_object_raw;
|
|
||||||
|
|
||||||
typedef union {
|
|
||||||
bool boolean;
|
|
||||||
uint64_t u64;
|
|
||||||
int64_t i64;
|
|
||||||
double dec;
|
|
||||||
msgpack_object_array array;
|
|
||||||
msgpack_object_map map;
|
|
||||||
msgpack_object_raw raw;
|
|
||||||
} msgpack_object_union;
|
|
||||||
|
|
||||||
typedef struct msgpack_object {
|
|
||||||
msgpack_object_type type;
|
|
||||||
msgpack_object_union via;
|
|
||||||
} msgpack_object;
|
|
||||||
|
|
||||||
typedef struct msgpack_object_kv {
|
|
||||||
msgpack_object key;
|
|
||||||
msgpack_object val;
|
|
||||||
} msgpack_object_kv;
|
|
||||||
|
|
||||||
|
|
||||||
void msgpack_object_print(FILE* out, msgpack_object o);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* msgpack/object.h */
|
|
||||||
|
|
||||||
85
c/sbuffer.h
85
c/sbuffer.h
@@ -1,85 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C simple buffer implementation
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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_SBUFFER_H__
|
|
||||||
#define MSGPACK_SBUFFER_H__
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#ifndef MSGPACK_SBUFFER_INIT_SIZE
|
|
||||||
#define MSGPACK_SBUFFER_INIT_SIZE 2048
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct msgpack_sbuffer {
|
|
||||||
size_t size;
|
|
||||||
char* data;
|
|
||||||
size_t alloc;
|
|
||||||
} msgpack_sbuffer;
|
|
||||||
|
|
||||||
static inline void msgpack_sbuffer_init(msgpack_sbuffer* sbuf)
|
|
||||||
{
|
|
||||||
memset(sbuf, 0, sizeof(msgpack_sbuffer));
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void msgpack_sbuffer_destroy(msgpack_sbuffer* sbuf)
|
|
||||||
{
|
|
||||||
free(sbuf->data);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int msgpack_sbuffer_write(void* data, const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
msgpack_sbuffer* sbuf = (msgpack_sbuffer*)data;
|
|
||||||
|
|
||||||
if(sbuf->alloc - sbuf->size < len) {
|
|
||||||
size_t nsize = (sbuf->alloc) ?
|
|
||||||
sbuf->alloc * 2 : MSGPACK_SBUFFER_INIT_SIZE;
|
|
||||||
|
|
||||||
while(nsize < sbuf->size + len) { nsize *= 2; }
|
|
||||||
|
|
||||||
void* tmp = realloc(sbuf->data, nsize);
|
|
||||||
if(!tmp) { return -1; }
|
|
||||||
|
|
||||||
sbuf->data = (char*)tmp;
|
|
||||||
sbuf->alloc = nsize;
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(sbuf->data + sbuf->size, buf, len);
|
|
||||||
sbuf->size += len;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline char* msgpack_sbuffer_release(msgpack_sbuffer* sbuf)
|
|
||||||
{
|
|
||||||
char* tmp = sbuf->data;
|
|
||||||
sbuf->size = 0;
|
|
||||||
sbuf->data = NULL;
|
|
||||||
sbuf->alloc = 0;
|
|
||||||
return tmp;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* msgpack/sbuffer.h */
|
|
||||||
|
|
||||||
424
c/test.cpp
424
c/test.cpp
@@ -1,424 +0,0 @@
|
|||||||
#include "msgpack.h"
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
#include <vector>
|
|
||||||
#include <limits>
|
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
const unsigned int kLoop = 10000;
|
|
||||||
const double kEPS = 1e-10;
|
|
||||||
|
|
||||||
#define GEN_TEST_SIGNED(test_type, func_type) \
|
|
||||||
do { \
|
|
||||||
vector<test_type> v; \
|
|
||||||
v.push_back(0); \
|
|
||||||
v.push_back(1); \
|
|
||||||
v.push_back(-1); \
|
|
||||||
v.push_back(numeric_limits<test_type>::min()); \
|
|
||||||
v.push_back(numeric_limits<test_type>::max()); \
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) \
|
|
||||||
v.push_back(rand()); \
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) { \
|
|
||||||
test_type val = v[i]; \
|
|
||||||
msgpack_sbuffer sbuf; \
|
|
||||||
msgpack_sbuffer_init(&sbuf); \
|
|
||||||
msgpack_packer pk; \
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write); \
|
|
||||||
msgpack_pack_##func_type(&pk, val); \
|
|
||||||
msgpack_zone z; \
|
|
||||||
msgpack_zone_init(&z, 2048); \
|
|
||||||
msgpack_object obj; \
|
|
||||||
msgpack_unpack_return ret = \
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj); \
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret); \
|
|
||||||
if (val < 0) { \
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, obj.type); \
|
|
||||||
EXPECT_EQ(val, obj.via.i64); \
|
|
||||||
} else { \
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, obj.type); \
|
|
||||||
EXPECT_EQ(val, obj.via.u64); \
|
|
||||||
} \
|
|
||||||
msgpack_zone_destroy(&z); \
|
|
||||||
msgpack_sbuffer_destroy(&sbuf); \
|
|
||||||
} \
|
|
||||||
} while(0)
|
|
||||||
|
|
||||||
#define GEN_TEST_UNSIGNED(test_type, func_type) \
|
|
||||||
do { \
|
|
||||||
vector<test_type> v; \
|
|
||||||
v.push_back(0); \
|
|
||||||
v.push_back(1); \
|
|
||||||
v.push_back(2); \
|
|
||||||
v.push_back(numeric_limits<test_type>::min()); \
|
|
||||||
v.push_back(numeric_limits<test_type>::max()); \
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) \
|
|
||||||
v.push_back(rand()); \
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) { \
|
|
||||||
test_type val = v[i]; \
|
|
||||||
msgpack_sbuffer sbuf; \
|
|
||||||
msgpack_sbuffer_init(&sbuf); \
|
|
||||||
msgpack_packer pk; \
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write); \
|
|
||||||
msgpack_pack_##func_type(&pk, val); \
|
|
||||||
msgpack_zone z; \
|
|
||||||
msgpack_zone_init(&z, 2048); \
|
|
||||||
msgpack_object obj; \
|
|
||||||
msgpack_unpack_return ret = \
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj); \
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret); \
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, obj.type); \
|
|
||||||
EXPECT_EQ(val, obj.via.u64); \
|
|
||||||
msgpack_zone_destroy(&z); \
|
|
||||||
msgpack_sbuffer_destroy(&sbuf); \
|
|
||||||
} \
|
|
||||||
} while(0)
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(short, short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(int, int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(long, long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(long long, long_long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_unsigned_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(unsigned short, unsigned_short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_unsigned_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(unsigned int, unsigned_int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_unsigned_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(unsigned long, unsigned_long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_unsigned_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(unsigned long long, unsigned_long_long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_uint8)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(uint8_t, uint8);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_uint16)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(uint16_t, uint16);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_uint32)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(uint32_t, uint32);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_uint64)
|
|
||||||
{
|
|
||||||
GEN_TEST_UNSIGNED(uint64_t, uint64);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_int8)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(int8_t, int8);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_int16)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(int16_t, int16);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_int32)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(int32_t, int32);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_int64)
|
|
||||||
{
|
|
||||||
GEN_TEST_SIGNED(int64_t, int64);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_float)
|
|
||||||
{
|
|
||||||
vector<float> v;
|
|
||||||
v.push_back(0.0);
|
|
||||||
v.push_back(1.0);
|
|
||||||
v.push_back(-1.0);
|
|
||||||
v.push_back(numeric_limits<float>::min());
|
|
||||||
v.push_back(numeric_limits<float>::max());
|
|
||||||
v.push_back(nanf("tag"));
|
|
||||||
v.push_back(1.0/0.0); // inf
|
|
||||||
v.push_back(-(1.0/0.0)); // -inf
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) {
|
|
||||||
v.push_back(drand48());
|
|
||||||
v.push_back(-drand48());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) {
|
|
||||||
float val = v[i];
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_float(&pk, val);
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret =
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_DOUBLE, obj.type);
|
|
||||||
if (isnan(val))
|
|
||||||
EXPECT_TRUE(isnan(obj.via.dec));
|
|
||||||
else if (isinf(val))
|
|
||||||
EXPECT_TRUE(isinf(obj.via.dec));
|
|
||||||
else
|
|
||||||
EXPECT_TRUE(fabs(obj.via.dec - val) <= kEPS);
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_double)
|
|
||||||
{
|
|
||||||
vector<double> v;
|
|
||||||
v.push_back(0.0);
|
|
||||||
v.push_back(-0.0);
|
|
||||||
v.push_back(1.0);
|
|
||||||
v.push_back(-1.0);
|
|
||||||
v.push_back(numeric_limits<double>::min());
|
|
||||||
v.push_back(numeric_limits<double>::max());
|
|
||||||
v.push_back(nan("tag"));
|
|
||||||
v.push_back(1.0/0.0); // inf
|
|
||||||
v.push_back(-(1.0/0.0)); // -inf
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) {
|
|
||||||
v.push_back(drand48());
|
|
||||||
v.push_back(-drand48());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) {
|
|
||||||
double val = v[i];
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_double(&pk, val);
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret =
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_DOUBLE, obj.type);
|
|
||||||
if (isnan(val))
|
|
||||||
EXPECT_TRUE(isnan(obj.via.dec));
|
|
||||||
else if (isinf(val))
|
|
||||||
EXPECT_TRUE(isinf(obj.via.dec));
|
|
||||||
else
|
|
||||||
EXPECT_TRUE(fabs(obj.via.dec - val) <= kEPS);
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_nil)
|
|
||||||
{
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_nil(&pk);
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret =
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_NIL, obj.type);
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_true)
|
|
||||||
{
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_true(&pk);
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret =
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, obj.type);
|
|
||||||
EXPECT_EQ(true, obj.via.boolean);
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_false)
|
|
||||||
{
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_false(&pk);
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret =
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, obj.type);
|
|
||||||
EXPECT_EQ(false, obj.via.boolean);
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_array)
|
|
||||||
{
|
|
||||||
unsigned int array_size = 5;
|
|
||||||
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_array(&pk, array_size);
|
|
||||||
msgpack_pack_nil(&pk);
|
|
||||||
msgpack_pack_true(&pk);
|
|
||||||
msgpack_pack_false(&pk);
|
|
||||||
msgpack_pack_int(&pk, 10);
|
|
||||||
msgpack_pack_int(&pk, -10);
|
|
||||||
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret;
|
|
||||||
ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_ARRAY, obj.type);
|
|
||||||
EXPECT_EQ(array_size, obj.via.array.size);
|
|
||||||
|
|
||||||
for (unsigned int i = 0; i < obj.via.array.size; i++) {
|
|
||||||
msgpack_object o = obj.via.array.ptr[i];
|
|
||||||
switch (i) {
|
|
||||||
case 0:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_NIL, o.type);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, o.type);
|
|
||||||
EXPECT_EQ(true, o.via.boolean);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, o.type);
|
|
||||||
EXPECT_EQ(false, o.via.boolean);
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, o.type);
|
|
||||||
EXPECT_EQ(10, o.via.u64);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, o.type);
|
|
||||||
EXPECT_EQ(-10, o.via.i64);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_map)
|
|
||||||
{
|
|
||||||
unsigned int map_size = 2;
|
|
||||||
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_map(&pk, map_size);
|
|
||||||
msgpack_pack_true(&pk);
|
|
||||||
msgpack_pack_false(&pk);
|
|
||||||
msgpack_pack_int(&pk, 10);
|
|
||||||
msgpack_pack_int(&pk, -10);
|
|
||||||
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret;
|
|
||||||
ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_MAP, obj.type);
|
|
||||||
EXPECT_EQ(map_size, obj.via.map.size);
|
|
||||||
|
|
||||||
for (unsigned int i = 0; i < map_size; i++) {
|
|
||||||
msgpack_object key = obj.via.map.ptr[i].key;
|
|
||||||
msgpack_object val = obj.via.map.ptr[i].val;
|
|
||||||
switch (i) {
|
|
||||||
case 0:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, key.type);
|
|
||||||
EXPECT_EQ(true, key.via.boolean);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, val.type);
|
|
||||||
EXPECT_EQ(false, val.via.boolean);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, key.type);
|
|
||||||
EXPECT_EQ(10, key.via.u64);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, val.type);
|
|
||||||
EXPECT_EQ(-10, val.via.i64);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACKC, simple_buffer_raw)
|
|
||||||
{
|
|
||||||
unsigned int raw_size = 7;
|
|
||||||
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
msgpack_pack_raw(&pk, raw_size);
|
|
||||||
msgpack_pack_raw_body(&pk, "fr", 2);
|
|
||||||
msgpack_pack_raw_body(&pk, "syuki", 5);
|
|
||||||
// invalid data
|
|
||||||
msgpack_pack_raw_body(&pk, "", 0);
|
|
||||||
msgpack_pack_raw_body(&pk, "kzk", 0);
|
|
||||||
|
|
||||||
msgpack_zone z;
|
|
||||||
msgpack_zone_init(&z, 2048);
|
|
||||||
msgpack_object obj;
|
|
||||||
msgpack_unpack_return ret;
|
|
||||||
ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
|
|
||||||
EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
|
|
||||||
EXPECT_EQ(MSGPACK_OBJECT_RAW, obj.type);
|
|
||||||
EXPECT_EQ(raw_size, obj.via.raw.size);
|
|
||||||
EXPECT_EQ(0, memcmp("frsyuki", obj.via.raw.ptr, raw_size));
|
|
||||||
|
|
||||||
msgpack_zone_destroy(&z);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
}
|
|
||||||
399
c/unpack.c
399
c/unpack.c
@@ -1,399 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C unpacking routine
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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.
|
|
||||||
*/
|
|
||||||
#include "msgpack/unpack.h"
|
|
||||||
#include "msgpack/unpack_define.h"
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
msgpack_zone* z;
|
|
||||||
bool referenced;
|
|
||||||
} unpack_user;
|
|
||||||
|
|
||||||
|
|
||||||
#define msgpack_unpack_struct(name) \
|
|
||||||
struct template ## name
|
|
||||||
|
|
||||||
#define msgpack_unpack_func(ret, name) \
|
|
||||||
ret template ## name
|
|
||||||
|
|
||||||
#define msgpack_unpack_callback(name) \
|
|
||||||
template_callback ## name
|
|
||||||
|
|
||||||
#define msgpack_unpack_object msgpack_object
|
|
||||||
|
|
||||||
#define msgpack_unpack_user unpack_user
|
|
||||||
|
|
||||||
|
|
||||||
struct template_context;
|
|
||||||
typedef struct template_context template_context;
|
|
||||||
|
|
||||||
static void template_init(template_context* ctx);
|
|
||||||
|
|
||||||
static msgpack_object template_data(template_context* ctx);
|
|
||||||
|
|
||||||
static int template_execute(template_context* ctx,
|
|
||||||
const char* data, size_t len, size_t* off);
|
|
||||||
|
|
||||||
|
|
||||||
static inline msgpack_object template_callback_root(unpack_user* u)
|
|
||||||
{ msgpack_object o; return 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; }
|
|
||||||
|
|
||||||
static inline int template_callback_uint16(unpack_user* u, uint16_t d, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_uint32(unpack_user* u, uint32_t d, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = d; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_uint64(unpack_user* u, uint64_t d, msgpack_object* o)
|
|
||||||
{ 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)
|
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = 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)
|
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = 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)
|
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = 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)
|
|
||||||
{ if(d >= 0) { o->type = MSGPACK_OBJECT_POSITIVE_INTEGER; o->via.u64 = 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)
|
|
||||||
{ o->type = MSGPACK_OBJECT_DOUBLE; o->via.dec = d; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_double(unpack_user* u, double d, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_DOUBLE; o->via.dec = d; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_nil(unpack_user* u, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_NIL; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_true(unpack_user* u, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_BOOLEAN; o->via.boolean = true; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_false(unpack_user* u, msgpack_object* o)
|
|
||||||
{ o->type = MSGPACK_OBJECT_BOOLEAN; o->via.boolean = false; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_array(unpack_user* u, unsigned int n, msgpack_object* o)
|
|
||||||
{
|
|
||||||
o->type = MSGPACK_OBJECT_ARRAY;
|
|
||||||
o->via.array.size = 0;
|
|
||||||
o->via.array.ptr = (msgpack_object*)msgpack_zone_malloc(u->z, n*sizeof(msgpack_object));
|
|
||||||
if(o->via.array.ptr == NULL) { return -1; }
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int template_callback_array_item(unpack_user* u, msgpack_object* c, msgpack_object o)
|
|
||||||
{ c->via.array.ptr[c->via.array.size++] = o; return 0; }
|
|
||||||
|
|
||||||
static inline int template_callback_map(unpack_user* u, unsigned int n, msgpack_object* o)
|
|
||||||
{
|
|
||||||
o->type = MSGPACK_OBJECT_MAP;
|
|
||||||
o->via.map.size = 0;
|
|
||||||
o->via.map.ptr = (msgpack_object_kv*)msgpack_zone_malloc(u->z, n*sizeof(msgpack_object_kv));
|
|
||||||
if(o->via.map.ptr == NULL) { return -1; }
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int template_callback_map_item(unpack_user* u, msgpack_object* c, msgpack_object k, msgpack_object v)
|
|
||||||
{
|
|
||||||
c->via.map.ptr[c->via.map.size].key = k;
|
|
||||||
c->via.map.ptr[c->via.map.size].val = v;
|
|
||||||
++c->via.map.size;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int template_callback_raw(unpack_user* u, const char* b, const char* p, unsigned int l, msgpack_object* o)
|
|
||||||
{
|
|
||||||
o->type = MSGPACK_OBJECT_RAW;
|
|
||||||
o->via.raw.ptr = p;
|
|
||||||
o->via.raw.size = l;
|
|
||||||
u->referenced = true;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "msgpack/unpack_template.h"
|
|
||||||
|
|
||||||
|
|
||||||
#define CTX_CAST(m) ((template_context*)(m))
|
|
||||||
#define CTX_REFERENCED(mpac) CTX_CAST((mpac)->ctx)->user.referenced
|
|
||||||
|
|
||||||
#define COUNTER_SIZE (sizeof(_msgpack_atomic_counter_t))
|
|
||||||
|
|
||||||
|
|
||||||
static inline void init_count(void* buffer)
|
|
||||||
{
|
|
||||||
*(volatile _msgpack_atomic_counter_t*)buffer = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void decl_count(void* buffer)
|
|
||||||
{
|
|
||||||
// atomic if(--*(_msgpack_atomic_counter_t*)buffer == 0) { free(buffer); }
|
|
||||||
if(_msgpack_sync_decr_and_fetch((volatile _msgpack_atomic_counter_t*)buffer) == 0) {
|
|
||||||
free(buffer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void incr_count(void* buffer)
|
|
||||||
{
|
|
||||||
// atomic ++*(_msgpack_atomic_counter_t*)buffer;
|
|
||||||
_msgpack_sync_incr_and_fetch((volatile _msgpack_atomic_counter_t*)buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline _msgpack_atomic_counter_t get_count(void* buffer)
|
|
||||||
{
|
|
||||||
return *(volatile _msgpack_atomic_counter_t*)buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool msgpack_unpacker_init(msgpack_unpacker* mpac, size_t initial_buffer_size)
|
|
||||||
{
|
|
||||||
if(initial_buffer_size < COUNTER_SIZE) {
|
|
||||||
initial_buffer_size = COUNTER_SIZE;
|
|
||||||
}
|
|
||||||
|
|
||||||
char* buffer = (char*)malloc(initial_buffer_size);
|
|
||||||
if(buffer == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void* ctx = malloc(sizeof(template_context));
|
|
||||||
if(ctx == NULL) {
|
|
||||||
free(buffer);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone* z = msgpack_zone_new(MSGPACK_ZONE_CHUNK_SIZE);
|
|
||||||
if(z == NULL) {
|
|
||||||
free(ctx);
|
|
||||||
free(buffer);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
mpac->buffer = buffer;
|
|
||||||
mpac->used = COUNTER_SIZE;
|
|
||||||
mpac->free = initial_buffer_size - mpac->used;
|
|
||||||
mpac->off = COUNTER_SIZE;
|
|
||||||
mpac->parsed = 0;
|
|
||||||
mpac->initial_buffer_size = initial_buffer_size;
|
|
||||||
mpac->z = z;
|
|
||||||
mpac->ctx = ctx;
|
|
||||||
|
|
||||||
init_count(mpac->buffer);
|
|
||||||
|
|
||||||
template_init(CTX_CAST(mpac->ctx));
|
|
||||||
CTX_CAST(mpac->ctx)->user.z = mpac->z;
|
|
||||||
CTX_CAST(mpac->ctx)->user.referenced = false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpacker_destroy(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
msgpack_zone_free(mpac->z);
|
|
||||||
free(mpac->ctx);
|
|
||||||
decl_count(mpac->buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
msgpack_unpacker* msgpack_unpacker_new(size_t initial_buffer_size)
|
|
||||||
{
|
|
||||||
msgpack_unpacker* mpac = (msgpack_unpacker*)malloc(sizeof(msgpack_unpacker));
|
|
||||||
if(mpac == NULL) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!msgpack_unpacker_init(mpac, initial_buffer_size)) {
|
|
||||||
free(mpac);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return mpac;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpacker_free(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
msgpack_unpacker_destroy(mpac);
|
|
||||||
free(mpac);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool msgpack_unpacker_expand_buffer(msgpack_unpacker* mpac, size_t size)
|
|
||||||
{
|
|
||||||
if(mpac->used == mpac->off && get_count(mpac->buffer) == 1
|
|
||||||
&& !CTX_REFERENCED(mpac)) {
|
|
||||||
// rewind buffer
|
|
||||||
mpac->free += mpac->used - COUNTER_SIZE;
|
|
||||||
mpac->used = COUNTER_SIZE;
|
|
||||||
mpac->off = COUNTER_SIZE;
|
|
||||||
|
|
||||||
if(mpac->free >= size) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(mpac->off == COUNTER_SIZE) {
|
|
||||||
size_t next_size = (mpac->used + mpac->free) * 2; // include COUNTER_SIZE
|
|
||||||
while(next_size < size + mpac->used) {
|
|
||||||
next_size *= 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
char* tmp = (char*)realloc(mpac->buffer, next_size);
|
|
||||||
if(tmp == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
mpac->buffer = tmp;
|
|
||||||
mpac->free = next_size - mpac->used;
|
|
||||||
|
|
||||||
} else {
|
|
||||||
size_t next_size = mpac->initial_buffer_size; // include COUNTER_SIZE
|
|
||||||
size_t not_parsed = mpac->used - mpac->off;
|
|
||||||
while(next_size < size + not_parsed + COUNTER_SIZE) {
|
|
||||||
next_size *= 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
char* tmp = (char*)malloc(next_size);
|
|
||||||
if(tmp == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
init_count(tmp);
|
|
||||||
|
|
||||||
memcpy(tmp+COUNTER_SIZE, mpac->buffer+mpac->off, not_parsed);
|
|
||||||
|
|
||||||
if(CTX_REFERENCED(mpac)) {
|
|
||||||
if(!msgpack_zone_push_finalizer(mpac->z, decl_count, mpac->buffer)) {
|
|
||||||
free(tmp);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
CTX_REFERENCED(mpac) = false;
|
|
||||||
} else {
|
|
||||||
decl_count(mpac->buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
mpac->buffer = tmp;
|
|
||||||
mpac->used = not_parsed + COUNTER_SIZE;
|
|
||||||
mpac->free = next_size - mpac->used;
|
|
||||||
mpac->off = COUNTER_SIZE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
int msgpack_unpacker_execute(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
size_t off = mpac->off;
|
|
||||||
int ret = template_execute(CTX_CAST(mpac->ctx),
|
|
||||||
mpac->buffer, mpac->used, &mpac->off);
|
|
||||||
if(mpac->off > off) {
|
|
||||||
mpac->parsed += mpac->off - off;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_object msgpack_unpacker_data(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
return template_data(CTX_CAST(mpac->ctx));
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone* msgpack_unpacker_release_zone(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
if(!msgpack_unpacker_flush_zone(mpac)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone* r = msgpack_zone_new(MSGPACK_ZONE_CHUNK_SIZE);
|
|
||||||
if(r == NULL) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone* old = mpac->z;
|
|
||||||
mpac->z = r;
|
|
||||||
|
|
||||||
return old;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpacker_reset_zone(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
msgpack_zone_clear(mpac->z);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool msgpack_unpacker_flush_zone(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
if(CTX_REFERENCED(mpac)) {
|
|
||||||
if(!msgpack_zone_push_finalizer(mpac->z, decl_count, mpac->buffer)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
CTX_REFERENCED(mpac) = false;
|
|
||||||
|
|
||||||
incr_count(mpac->buffer);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpacker_reset(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
template_init(CTX_CAST(mpac->ctx));
|
|
||||||
// don't reset referenced flag
|
|
||||||
mpac->parsed = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
msgpack_unpack_return
|
|
||||||
msgpack_unpack(const char* data, size_t len, size_t* off,
|
|
||||||
msgpack_zone* z, msgpack_object* result)
|
|
||||||
{
|
|
||||||
template_context ctx;
|
|
||||||
template_init(&ctx);
|
|
||||||
|
|
||||||
ctx.user.z = z;
|
|
||||||
ctx.user.referenced = false;
|
|
||||||
|
|
||||||
size_t noff = 0;
|
|
||||||
if(off != NULL) { noff = *off; }
|
|
||||||
|
|
||||||
int ret = template_execute(&ctx, data, len, &noff);
|
|
||||||
if(ret < 0) {
|
|
||||||
return MSGPACK_UNPACK_PARSE_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(off != NULL) { *off = noff; }
|
|
||||||
|
|
||||||
if(ret == 0) {
|
|
||||||
return MSGPACK_UNPACK_CONTINUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
*result = template_data(&ctx);
|
|
||||||
|
|
||||||
if(noff < len) {
|
|
||||||
return MSGPACK_UNPACK_EXTRA_BYTES;
|
|
||||||
}
|
|
||||||
|
|
||||||
return MSGPACK_UNPACK_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
123
c/unpack.h
123
c/unpack.h
@@ -1,123 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C unpacking routine
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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_UNPACKER_H__
|
|
||||||
#define MSGPACK_UNPACKER_H__
|
|
||||||
|
|
||||||
#include "msgpack/zone.h"
|
|
||||||
#include "msgpack/object.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct msgpack_unpacker {
|
|
||||||
char* buffer;
|
|
||||||
size_t used;
|
|
||||||
size_t free;
|
|
||||||
size_t off;
|
|
||||||
size_t parsed;
|
|
||||||
msgpack_zone* z;
|
|
||||||
size_t initial_buffer_size;
|
|
||||||
void* ctx;
|
|
||||||
} msgpack_unpacker;
|
|
||||||
|
|
||||||
|
|
||||||
bool msgpack_unpacker_init(msgpack_unpacker* mpac, size_t initial_buffer_size);
|
|
||||||
void msgpack_unpacker_destroy(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
msgpack_unpacker* msgpack_unpacker_new(size_t initial_buffer_size);
|
|
||||||
void msgpack_unpacker_free(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
static inline bool msgpack_unpacker_reserve_buffer(msgpack_unpacker* mpac, size_t size);
|
|
||||||
static inline char* msgpack_unpacker_buffer(msgpack_unpacker* mpac);
|
|
||||||
static inline size_t msgpack_unpacker_buffer_capacity(const msgpack_unpacker* mpac);
|
|
||||||
static inline void msgpack_unpacker_buffer_consumed(msgpack_unpacker* mpac, size_t size);
|
|
||||||
|
|
||||||
|
|
||||||
int msgpack_unpacker_execute(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
msgpack_object msgpack_unpacker_data(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
msgpack_zone* msgpack_unpacker_release_zone(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
void msgpack_unpacker_reset_zone(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
void msgpack_unpacker_reset(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
static inline size_t msgpack_unpacker_message_size(const msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
MSGPACK_UNPACK_SUCCESS = 2,
|
|
||||||
MSGPACK_UNPACK_EXTRA_BYTES = 1,
|
|
||||||
MSGPACK_UNPACK_CONTINUE = 0,
|
|
||||||
MSGPACK_UNPACK_PARSE_ERROR = -1,
|
|
||||||
} msgpack_unpack_return;
|
|
||||||
|
|
||||||
msgpack_unpack_return
|
|
||||||
msgpack_unpack(const char* data, size_t len, size_t* off,
|
|
||||||
msgpack_zone* z, msgpack_object* result);
|
|
||||||
|
|
||||||
|
|
||||||
static inline size_t msgpack_unpacker_parsed_size(const msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
bool msgpack_unpacker_flush_zone(msgpack_unpacker* mpac);
|
|
||||||
|
|
||||||
bool msgpack_unpacker_expand_buffer(msgpack_unpacker* mpac, size_t size);
|
|
||||||
|
|
||||||
bool msgpack_unpacker_reserve_buffer(msgpack_unpacker* mpac, size_t size)
|
|
||||||
{
|
|
||||||
if(mpac->free >= size) { return true; }
|
|
||||||
return msgpack_unpacker_expand_buffer(mpac, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
char* msgpack_unpacker_buffer(msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
return mpac->buffer + mpac->used;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t msgpack_unpacker_buffer_capacity(const msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
return mpac->free;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpacker_buffer_consumed(msgpack_unpacker* mpac, size_t size)
|
|
||||||
{
|
|
||||||
mpac->used += size;
|
|
||||||
mpac->free -= size;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t msgpack_unpacker_message_size(const msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
return mpac->parsed - mpac->off + mpac->used;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t msgpack_unpacker_parsed_size(const msgpack_unpacker* mpac)
|
|
||||||
{
|
|
||||||
return mpac->parsed;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* msgpack/unpack.h */
|
|
||||||
|
|
||||||
202
c/vrefbuffer.c
202
c/vrefbuffer.c
@@ -1,202 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C zero-copy buffer implementation
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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.
|
|
||||||
*/
|
|
||||||
#include "msgpack/vrefbuffer.h"
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
struct msgpack_vrefbuffer_chunk {
|
|
||||||
struct msgpack_vrefbuffer_chunk* next;
|
|
||||||
/* data ... */
|
|
||||||
};
|
|
||||||
|
|
||||||
bool msgpack_vrefbuffer_init(msgpack_vrefbuffer* vbuf,
|
|
||||||
size_t ref_size, size_t chunk_size)
|
|
||||||
{
|
|
||||||
vbuf->chunk_size = chunk_size;
|
|
||||||
vbuf->ref_size = ref_size;
|
|
||||||
|
|
||||||
// glibcは72バイト以下のmallocが高速
|
|
||||||
size_t nfirst = (sizeof(struct iovec) < 72/2) ?
|
|
||||||
72 / sizeof(struct iovec) : 8;
|
|
||||||
|
|
||||||
struct iovec* array = (struct iovec*)malloc(
|
|
||||||
sizeof(struct iovec) * nfirst);
|
|
||||||
if(array == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
vbuf->tail = array;
|
|
||||||
vbuf->end = array + nfirst;
|
|
||||||
vbuf->array = array;
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_chunk* chunk = (msgpack_vrefbuffer_chunk*)malloc(
|
|
||||||
sizeof(msgpack_vrefbuffer_chunk) + chunk_size);
|
|
||||||
if(chunk == NULL) {
|
|
||||||
free(array);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_inner_buffer* const ib = &vbuf->inner_buffer;
|
|
||||||
|
|
||||||
ib->free = chunk_size;
|
|
||||||
ib->ptr = ((char*)chunk) + sizeof(msgpack_vrefbuffer_chunk);
|
|
||||||
ib->head = chunk;
|
|
||||||
chunk->next = NULL;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_vrefbuffer_destroy(msgpack_vrefbuffer* vbuf)
|
|
||||||
{
|
|
||||||
msgpack_vrefbuffer_chunk* c = vbuf->inner_buffer.head;
|
|
||||||
while(true) {
|
|
||||||
msgpack_vrefbuffer_chunk* n = c->next;
|
|
||||||
free(c);
|
|
||||||
if(n != NULL) {
|
|
||||||
c = n;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
free(vbuf->array);
|
|
||||||
}
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_append_ref(msgpack_vrefbuffer* vbuf,
|
|
||||||
const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
if(vbuf->tail == vbuf->end) {
|
|
||||||
const size_t nused = vbuf->tail - vbuf->array;
|
|
||||||
const size_t nnext = nused * 2;
|
|
||||||
|
|
||||||
struct iovec* nvec = (struct iovec*)realloc(
|
|
||||||
vbuf->array, sizeof(struct iovec)*nnext);
|
|
||||||
if(nvec == NULL) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
vbuf->array = nvec;
|
|
||||||
vbuf->end = nvec + nnext;
|
|
||||||
vbuf->tail = nvec + nused;
|
|
||||||
}
|
|
||||||
|
|
||||||
vbuf->tail->iov_base = (char*)buf;
|
|
||||||
vbuf->tail->iov_len = len;
|
|
||||||
++vbuf->tail;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_append_copy(msgpack_vrefbuffer* vbuf,
|
|
||||||
const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
msgpack_vrefbuffer_inner_buffer* const ib = &vbuf->inner_buffer;
|
|
||||||
|
|
||||||
if(ib->free < len) {
|
|
||||||
size_t sz = vbuf->chunk_size;
|
|
||||||
if(sz < len) {
|
|
||||||
sz = len;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_chunk* chunk = (msgpack_vrefbuffer_chunk*)malloc(
|
|
||||||
sizeof(msgpack_vrefbuffer_chunk) + sz);
|
|
||||||
if(chunk == NULL) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
chunk->next = ib->head;
|
|
||||||
ib->head = chunk;
|
|
||||||
ib->free = sz;
|
|
||||||
ib->ptr = ((char*)chunk) + sizeof(msgpack_vrefbuffer_chunk);
|
|
||||||
}
|
|
||||||
|
|
||||||
char* m = ib->ptr;
|
|
||||||
memcpy(m, buf, len);
|
|
||||||
ib->free -= len;
|
|
||||||
ib->ptr += len;
|
|
||||||
|
|
||||||
if(vbuf->tail != vbuf->array && m ==
|
|
||||||
(const char*)((vbuf->tail-1)->iov_base) + (vbuf->tail-1)->iov_len) {
|
|
||||||
(vbuf->tail-1)->iov_len += len;
|
|
||||||
return 0;
|
|
||||||
} else {
|
|
||||||
return msgpack_vrefbuffer_append_ref(vbuf, m, len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_migrate(msgpack_vrefbuffer* vbuf, msgpack_vrefbuffer* to)
|
|
||||||
{
|
|
||||||
size_t sz = vbuf->chunk_size;
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_chunk* empty = (msgpack_vrefbuffer_chunk*)malloc(
|
|
||||||
sizeof(msgpack_vrefbuffer_chunk) + sz);
|
|
||||||
if(empty == NULL) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
empty->next = NULL;
|
|
||||||
|
|
||||||
|
|
||||||
const size_t nused = vbuf->tail - vbuf->array;
|
|
||||||
if(to->tail + nused < vbuf->end) {
|
|
||||||
const size_t tosize = to->tail - to->array;
|
|
||||||
const size_t reqsize = nused + tosize;
|
|
||||||
size_t nnext = (to->end - to->array) * 2;
|
|
||||||
while(nnext < reqsize) {
|
|
||||||
nnext *= 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct iovec* nvec = (struct iovec*)realloc(
|
|
||||||
to->array, sizeof(struct iovec)*nnext);
|
|
||||||
if(nvec == NULL) {
|
|
||||||
free(empty);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
to->array = nvec;
|
|
||||||
to->end = nvec + nnext;
|
|
||||||
to->tail = nvec + tosize;
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(to->tail, vbuf->array, sizeof(struct iovec)*nused);
|
|
||||||
|
|
||||||
to->tail += nused;
|
|
||||||
vbuf->tail = vbuf->array;
|
|
||||||
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_inner_buffer* const ib = &vbuf->inner_buffer;
|
|
||||||
msgpack_vrefbuffer_inner_buffer* const toib = &to->inner_buffer;
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_chunk* last = ib->head;
|
|
||||||
while(last->next != NULL) {
|
|
||||||
last = last->next;
|
|
||||||
}
|
|
||||||
last->next = toib->head;
|
|
||||||
toib->head = ib->head;
|
|
||||||
|
|
||||||
if(toib->free < ib->free) {
|
|
||||||
toib->free = ib->free;
|
|
||||||
toib->ptr = ib->ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
ib->head = empty;
|
|
||||||
ib->free = sz;
|
|
||||||
ib->ptr = ((char*)empty) + sizeof(msgpack_vrefbuffer_chunk);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
110
c/vrefbuffer.h
110
c/vrefbuffer.h
@@ -1,110 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C zero-copy buffer implementation
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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_VREFBUFFER_H__
|
|
||||||
#define MSGPACK_VREFBUFFER_H__
|
|
||||||
|
|
||||||
#include "msgpack/zone.h"
|
|
||||||
|
|
||||||
#ifndef _WIN32
|
|
||||||
#include <sys/uio.h>
|
|
||||||
#else
|
|
||||||
struct iovec {
|
|
||||||
void *iov_base;
|
|
||||||
size_t iov_len;
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef MSGPACK_VREFBUFFER_REF_SIZE
|
|
||||||
#define MSGPACK_VREFBUFFER_REF_SIZE 32
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef MSGPACK_VREFBUFFER_CHUNK_SIZE
|
|
||||||
#define MSGPACK_VREFBUFFER_CHUNK_SIZE 8192
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct msgpack_vrefbuffer_chunk;
|
|
||||||
typedef struct msgpack_vrefbuffer_chunk msgpack_vrefbuffer_chunk;
|
|
||||||
|
|
||||||
typedef struct msgpack_vrefbuffer_inner_buffer {
|
|
||||||
size_t free;
|
|
||||||
char* ptr;
|
|
||||||
msgpack_vrefbuffer_chunk* head;
|
|
||||||
} msgpack_vrefbuffer_inner_buffer;
|
|
||||||
|
|
||||||
typedef struct msgpack_vrefbuffer {
|
|
||||||
struct iovec* tail;
|
|
||||||
struct iovec* end;
|
|
||||||
struct iovec* array;
|
|
||||||
|
|
||||||
size_t chunk_size;
|
|
||||||
size_t ref_size;
|
|
||||||
|
|
||||||
msgpack_vrefbuffer_inner_buffer inner_buffer;
|
|
||||||
} msgpack_vrefbuffer;
|
|
||||||
|
|
||||||
|
|
||||||
bool msgpack_vrefbuffer_init(msgpack_vrefbuffer* vbuf,
|
|
||||||
size_t ref_size, size_t chunk_size);
|
|
||||||
void msgpack_vrefbuffer_destroy(msgpack_vrefbuffer* vbuf);
|
|
||||||
|
|
||||||
static inline int msgpack_vrefbuffer_write(void* data, const char* buf, unsigned int len);
|
|
||||||
|
|
||||||
static inline const struct iovec* msgpack_vrefbuffer_vec(const msgpack_vrefbuffer* vref);
|
|
||||||
static inline size_t msgpack_vrefbuffer_veclen(const msgpack_vrefbuffer* vref);
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_append_copy(msgpack_vrefbuffer* vbuf,
|
|
||||||
const char* buf, unsigned int len);
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_append_ref(msgpack_vrefbuffer* vbuf,
|
|
||||||
const char* buf, unsigned int len);
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_migrate(msgpack_vrefbuffer* vbuf, msgpack_vrefbuffer* to);
|
|
||||||
|
|
||||||
int msgpack_vrefbuffer_write(void* data, const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
msgpack_vrefbuffer* vbuf = (msgpack_vrefbuffer*)data;
|
|
||||||
|
|
||||||
if(len < vbuf->ref_size) {
|
|
||||||
return msgpack_vrefbuffer_append_copy(vbuf, buf, len);
|
|
||||||
} else {
|
|
||||||
return msgpack_vrefbuffer_append_ref(vbuf, buf, len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const struct iovec* msgpack_vrefbuffer_vec(const msgpack_vrefbuffer* vref)
|
|
||||||
{
|
|
||||||
return vref->array;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t msgpack_vrefbuffer_veclen(const msgpack_vrefbuffer* vref)
|
|
||||||
{
|
|
||||||
return vref->tail - vref->array;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* msgpack/vrefbuffer.h */
|
|
||||||
|
|
||||||
224
c/zone.c
224
c/zone.c
@@ -1,224 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C memory pool implementation
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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.
|
|
||||||
*/
|
|
||||||
#include "msgpack/zone.h"
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
struct msgpack_zone_chunk {
|
|
||||||
struct msgpack_zone_chunk* next;
|
|
||||||
/* data ... */
|
|
||||||
};
|
|
||||||
|
|
||||||
static inline bool init_chunk_list(msgpack_zone_chunk_list* cl, size_t chunk_size)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk* chunk = (msgpack_zone_chunk*)malloc(
|
|
||||||
sizeof(msgpack_zone_chunk) + chunk_size);
|
|
||||||
if(chunk == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
cl->head = chunk;
|
|
||||||
cl->free = chunk_size;
|
|
||||||
cl->ptr = ((char*)chunk) + sizeof(msgpack_zone_chunk);
|
|
||||||
chunk->next = NULL;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void destroy_chunk_list(msgpack_zone_chunk_list* cl)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk* c = cl->head;
|
|
||||||
while(true) {
|
|
||||||
msgpack_zone_chunk* n = c->next;
|
|
||||||
free(c);
|
|
||||||
if(n != NULL) {
|
|
||||||
c = n;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void clear_chunk_list(msgpack_zone_chunk_list* cl, size_t chunk_size)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk* c = cl->head;
|
|
||||||
while(true) {
|
|
||||||
msgpack_zone_chunk* n = c->next;
|
|
||||||
if(n != NULL) {
|
|
||||||
free(c);
|
|
||||||
c = n;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cl->head->next = NULL;
|
|
||||||
cl->free = chunk_size;
|
|
||||||
cl->ptr = ((char*)cl->head) + sizeof(msgpack_zone_chunk);
|
|
||||||
}
|
|
||||||
|
|
||||||
void* msgpack_zone_malloc_expand(msgpack_zone* zone, size_t size)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk_list* const cl = &zone->chunk_list;
|
|
||||||
|
|
||||||
size_t sz = zone->chunk_size;
|
|
||||||
|
|
||||||
while(sz < size) {
|
|
||||||
sz *= 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone_chunk* chunk = (msgpack_zone_chunk*)malloc(
|
|
||||||
sizeof(msgpack_zone_chunk) + sz);
|
|
||||||
|
|
||||||
char* ptr = ((char*)chunk) + sizeof(msgpack_zone_chunk);
|
|
||||||
|
|
||||||
chunk->next = cl->head;
|
|
||||||
cl->head = chunk;
|
|
||||||
cl->free = sz - size;
|
|
||||||
cl->ptr = ptr + size;
|
|
||||||
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static inline void init_finalizer_array(msgpack_zone_finalizer_array* fa)
|
|
||||||
{
|
|
||||||
fa->tail = NULL;
|
|
||||||
fa->end = NULL;
|
|
||||||
fa->array = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void call_finalizer_array(msgpack_zone_finalizer_array* fa)
|
|
||||||
{
|
|
||||||
// 逆順に呼び出し
|
|
||||||
msgpack_zone_finalizer* fin = fa->tail;
|
|
||||||
for(; fin != fa->array; --fin) {
|
|
||||||
(*(fin-1)->func)((fin-1)->data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void destroy_finalizer_array(msgpack_zone_finalizer_array* fa)
|
|
||||||
{
|
|
||||||
call_finalizer_array(fa);
|
|
||||||
free(fa->array);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void clear_finalizer_array(msgpack_zone_finalizer_array* fa)
|
|
||||||
{
|
|
||||||
call_finalizer_array(fa);
|
|
||||||
fa->tail = fa->array;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool msgpack_zone_push_finalizer_expand(msgpack_zone* zone,
|
|
||||||
void (*func)(void* data), void* data)
|
|
||||||
{
|
|
||||||
msgpack_zone_finalizer_array* const fa = &zone->finalizer_array;
|
|
||||||
|
|
||||||
const size_t nused = fa->end - fa->array;
|
|
||||||
|
|
||||||
size_t nnext;
|
|
||||||
if(nused == 0) {
|
|
||||||
// 初回の呼び出し:fa->tail == fa->end == fa->array == NULL
|
|
||||||
|
|
||||||
// glibcは72バイト以下のmallocが高速
|
|
||||||
nnext = (sizeof(msgpack_zone_finalizer) < 72/2) ?
|
|
||||||
72 / sizeof(msgpack_zone_finalizer) : 8;
|
|
||||||
|
|
||||||
} else {
|
|
||||||
nnext = nused * 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone_finalizer* tmp =
|
|
||||||
(msgpack_zone_finalizer*)realloc(fa->array,
|
|
||||||
sizeof(msgpack_zone_finalizer) * nnext);
|
|
||||||
if(tmp == NULL) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
fa->array = tmp;
|
|
||||||
fa->end = tmp + nnext;
|
|
||||||
fa->tail = tmp + nused;
|
|
||||||
|
|
||||||
fa->tail->func = func;
|
|
||||||
fa->tail->data = data;
|
|
||||||
|
|
||||||
++fa->tail;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool msgpack_zone_is_empty(msgpack_zone* zone)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk_list* const cl = &zone->chunk_list;
|
|
||||||
msgpack_zone_finalizer_array* const fa = &zone->finalizer_array;
|
|
||||||
return cl->free == zone->chunk_size && cl->head->next == NULL &&
|
|
||||||
fa->tail == fa->array;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void msgpack_zone_destroy(msgpack_zone* zone)
|
|
||||||
{
|
|
||||||
destroy_finalizer_array(&zone->finalizer_array);
|
|
||||||
destroy_chunk_list(&zone->chunk_list);
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_zone_clear(msgpack_zone* zone)
|
|
||||||
{
|
|
||||||
clear_finalizer_array(&zone->finalizer_array);
|
|
||||||
clear_chunk_list(&zone->chunk_list, zone->chunk_size);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool msgpack_zone_init(msgpack_zone* zone, size_t chunk_size)
|
|
||||||
{
|
|
||||||
zone->chunk_size = chunk_size;
|
|
||||||
|
|
||||||
if(!init_chunk_list(&zone->chunk_list, chunk_size)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
init_finalizer_array(&zone->finalizer_array);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
msgpack_zone* msgpack_zone_new(size_t chunk_size)
|
|
||||||
{
|
|
||||||
msgpack_zone* zone = (msgpack_zone*)malloc(
|
|
||||||
sizeof(msgpack_zone) + chunk_size);
|
|
||||||
if(zone == NULL) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
zone->chunk_size = chunk_size;
|
|
||||||
|
|
||||||
if(!init_chunk_list(&zone->chunk_list, chunk_size)) {
|
|
||||||
free(zone);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
init_finalizer_array(&zone->finalizer_array);
|
|
||||||
|
|
||||||
return zone;
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_zone_free(msgpack_zone* zone)
|
|
||||||
{
|
|
||||||
msgpack_zone_destroy(zone);
|
|
||||||
free(zone);
|
|
||||||
}
|
|
||||||
|
|
||||||
132
c/zone.h
132
c/zone.h
@@ -1,132 +0,0 @@
|
|||||||
/*
|
|
||||||
* MessagePack for C memory pool implementation
|
|
||||||
*
|
|
||||||
* Copyright (C) 2008-2009 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_H__
|
|
||||||
#define MSGPACK_ZONE_H__
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct msgpack_zone_finalizer {
|
|
||||||
void (*func)(void* data);
|
|
||||||
void* data;
|
|
||||||
} msgpack_zone_finalizer;
|
|
||||||
|
|
||||||
typedef struct msgpack_zone_finalizer_array {
|
|
||||||
msgpack_zone_finalizer* tail;
|
|
||||||
msgpack_zone_finalizer* end;
|
|
||||||
msgpack_zone_finalizer* array;
|
|
||||||
} msgpack_zone_finalizer_array;
|
|
||||||
|
|
||||||
struct msgpack_zone_chunk;
|
|
||||||
typedef struct msgpack_zone_chunk msgpack_zone_chunk;
|
|
||||||
|
|
||||||
typedef struct msgpack_zone_chunk_list {
|
|
||||||
size_t free;
|
|
||||||
char* ptr;
|
|
||||||
msgpack_zone_chunk* head;
|
|
||||||
} msgpack_zone_chunk_list;
|
|
||||||
|
|
||||||
typedef struct msgpack_zone {
|
|
||||||
msgpack_zone_chunk_list chunk_list;
|
|
||||||
msgpack_zone_finalizer_array finalizer_array;
|
|
||||||
size_t chunk_size;
|
|
||||||
} msgpack_zone;
|
|
||||||
|
|
||||||
#ifndef MSGPACK_ZONE_CHUNK_SIZE
|
|
||||||
#define MSGPACK_ZONE_CHUNK_SIZE 8192
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool msgpack_zone_init(msgpack_zone* zone, size_t chunk_size);
|
|
||||||
void msgpack_zone_destroy(msgpack_zone* zone);
|
|
||||||
|
|
||||||
msgpack_zone* msgpack_zone_new(size_t chunk_size);
|
|
||||||
void msgpack_zone_free(msgpack_zone* zone);
|
|
||||||
|
|
||||||
static inline void* msgpack_zone_malloc(msgpack_zone* zone, size_t size);
|
|
||||||
static inline void* msgpack_zone_malloc_no_align(msgpack_zone* zone, size_t size);
|
|
||||||
|
|
||||||
static inline bool msgpack_zone_push_finalizer(msgpack_zone* zone,
|
|
||||||
void (*func)(void* data), void* data);
|
|
||||||
|
|
||||||
bool msgpack_zone_is_empty(msgpack_zone* zone);
|
|
||||||
|
|
||||||
void msgpack_zone_clear(msgpack_zone* zone);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef MSGPACK_ZONE_ALIGN
|
|
||||||
#define MSGPACK_ZONE_ALIGN sizeof(int)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void* msgpack_zone_malloc_expand(msgpack_zone* zone, size_t size);
|
|
||||||
|
|
||||||
void* msgpack_zone_malloc_no_align(msgpack_zone* zone, size_t size)
|
|
||||||
{
|
|
||||||
msgpack_zone_chunk_list* cl = &zone->chunk_list;
|
|
||||||
|
|
||||||
if(zone->chunk_list.free < size) {
|
|
||||||
return msgpack_zone_malloc_expand(zone, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
char* ptr = cl->ptr;
|
|
||||||
cl->free -= size;
|
|
||||||
cl->ptr += size;
|
|
||||||
|
|
||||||
return ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
void* msgpack_zone_malloc(msgpack_zone* zone, size_t size)
|
|
||||||
{
|
|
||||||
return msgpack_zone_malloc_no_align(zone,
|
|
||||||
((size)+((MSGPACK_ZONE_ALIGN)-1)) & ~((MSGPACK_ZONE_ALIGN)-1));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool msgpack_zone_push_finalizer_expand(msgpack_zone* zone,
|
|
||||||
void (*func)(void* data), void* data);
|
|
||||||
|
|
||||||
bool msgpack_zone_push_finalizer(msgpack_zone* zone,
|
|
||||||
void (*func)(void* data), void* data)
|
|
||||||
{
|
|
||||||
msgpack_zone_finalizer_array* const fa = &zone->finalizer_array;
|
|
||||||
msgpack_zone_finalizer* fin = fa->tail;
|
|
||||||
|
|
||||||
if(fin == fa->end) {
|
|
||||||
return msgpack_zone_push_finalizer_expand(zone, func, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
fin->func = func;
|
|
||||||
fin->data = data;
|
|
||||||
|
|
||||||
++fa->tail;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* msgpack/zone.h */
|
|
||||||
|
|
||||||
1
cases.json
Normal file
1
cases.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
[false,true,null,0,0,0,0,0,0,0,0,0,-1,-1,-1,-1,-1,127,127,255,65535,4294967295,-32,-32,-128,-32768,-2147483648,0.0,-0.0,1.0,-1.0,"a","a","a","","","",[0],[0],[0],[],[],[],{},{},{},{"a":97},{"a":97},{"a":97},[[]],[["a"]]]
|
||||||
99
cases_gen.rb
Normal file
99
cases_gen.rb
Normal file
@@ -0,0 +1,99 @@
|
|||||||
|
#
|
||||||
|
# MessagePack format test case
|
||||||
|
#
|
||||||
|
begin
|
||||||
|
require 'rubygems'
|
||||||
|
rescue LoadError
|
||||||
|
end
|
||||||
|
require 'msgpack'
|
||||||
|
require 'json'
|
||||||
|
|
||||||
|
source = <<EOF
|
||||||
|
c2 # false
|
||||||
|
c3 # true
|
||||||
|
c0 # nil
|
||||||
|
00 # 0 Positive FixNum
|
||||||
|
cc 00 # 0 uint8
|
||||||
|
cd 00 00 # 0 uint16
|
||||||
|
ce 00 00 00 00 # 0 uint32
|
||||||
|
cf 00 00 00 00 00 00 00 00 # 0 uint64
|
||||||
|
d0 00 # 0 int8
|
||||||
|
d1 00 00 # 0 int16
|
||||||
|
d2 00 00 00 00 # 0 int32
|
||||||
|
d3 00 00 00 00 00 00 00 00 # 0 int64
|
||||||
|
ff # -1 Negative FixNum
|
||||||
|
d0 ff # -1 int8
|
||||||
|
d1 ff ff # -1 int16
|
||||||
|
d2 ff ff ff ff # -1 int32
|
||||||
|
d3 ff ff ff ff ff ff ff ff # -1 int64
|
||||||
|
7f # 127 Positive FixNum
|
||||||
|
cc 7f # 127 uint8
|
||||||
|
cd 00 ff # 255 uint16
|
||||||
|
ce 00 00 ff ff # 65535 uint32
|
||||||
|
cf 00 00 00 00 ff ff ff ff # 4294967295 uint64
|
||||||
|
e0 # -32 Negative FixNum
|
||||||
|
d0 e0 # -32 int8
|
||||||
|
d1 ff 80 # -128 int16
|
||||||
|
d2 ff ff 80 00 # -32768 int32
|
||||||
|
d3 ff ff ff ff 80 00 00 00 # -2147483648 int64
|
||||||
|
#ca 00 00 00 00 # 0.0 float
|
||||||
|
cb 00 00 00 00 00 00 00 00 # 0.0 double
|
||||||
|
#ca 80 00 00 00 # -0.0 float
|
||||||
|
cb 80 00 00 00 00 00 00 00 # -0.0 double
|
||||||
|
cb 3f f0 00 00 00 00 00 00 # 1.0 double
|
||||||
|
cb bf f0 00 00 00 00 00 00 # -1.0 double
|
||||||
|
a1 61 # "a" FixRaw
|
||||||
|
da 00 01 61 # "a" raw 16
|
||||||
|
db 00 00 00 01 61 # "a" raw 32
|
||||||
|
a0 # "" FixRaw
|
||||||
|
da 00 00 # "" raw 16
|
||||||
|
db 00 00 00 00 # "" raw 32
|
||||||
|
91 00 # [0] FixArray
|
||||||
|
dc 00 01 00 # [0] array 16
|
||||||
|
dd 00 00 00 01 00 # [0] array 32
|
||||||
|
90 # [] FixArray
|
||||||
|
dc 00 00 # [] array 16
|
||||||
|
dd 00 00 00 00 # [] array 32
|
||||||
|
80 # {} FixMap
|
||||||
|
de 00 00 # {} map 16
|
||||||
|
df 00 00 00 00 # {} map 32
|
||||||
|
81 a1 61 61 # {"a"=>97} FixMap
|
||||||
|
de 00 01 a1 61 61 # {"a"=>97} map 16
|
||||||
|
df 00 00 00 01 a1 61 61 # {"a"=>97} map 32
|
||||||
|
91 90 # [[]]
|
||||||
|
91 91 a1 61 # [["a"]]
|
||||||
|
EOF
|
||||||
|
|
||||||
|
source.gsub!(/\#.+$/,'')
|
||||||
|
bytes = source.strip.split(/\s+/).map {|x| x.to_i(16) }.pack('C*')
|
||||||
|
|
||||||
|
objs = []
|
||||||
|
compact_bytes = ""
|
||||||
|
|
||||||
|
pac = MessagePack::Unpacker.new
|
||||||
|
pac.feed(bytes)
|
||||||
|
pac.each {|obj|
|
||||||
|
p obj
|
||||||
|
objs << obj
|
||||||
|
compact_bytes << obj.to_msgpack
|
||||||
|
}
|
||||||
|
|
||||||
|
json = objs.to_json
|
||||||
|
|
||||||
|
# self check
|
||||||
|
cpac = MessagePack::Unpacker.new
|
||||||
|
cpac.feed(compact_bytes)
|
||||||
|
cpac.each {|cobj|
|
||||||
|
obj = objs.shift
|
||||||
|
if obj != cobj
|
||||||
|
puts "** SELF CHECK FAILED **"
|
||||||
|
puts "expected: #{obj.inspect}"
|
||||||
|
puts "actual: #{cobj.inspect}"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
|
File.open("cases.mpac","w") {|f| f.write(bytes) }
|
||||||
|
File.open("cases_compact.mpac","w") {|f| f.write(compact_bytes) }
|
||||||
|
File.open("cases.json","w") {|f| f.write(json) }
|
||||||
|
|
||||||
57
ci/build_autotools.sh
Executable file
57
ci/build_autotools.sh
Executable file
@@ -0,0 +1,57 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
./bootstrap
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $1 = "cpp11" ]
|
||||||
|
then
|
||||||
|
if [ $2 = "32" ]
|
||||||
|
then
|
||||||
|
./configure CFLAGS="-m32" CXXFLAGS="-std=c++11 -m32"
|
||||||
|
else
|
||||||
|
./configure CXXFLAGS="-std=c++11"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ $2 = "32" ]
|
||||||
|
then
|
||||||
|
./configure CFLAGS="-m32" CXXFLAGS="-m32"
|
||||||
|
else
|
||||||
|
./configure
|
||||||
|
fi
|
||||||
|
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
|
||||||
83
ci/build_cmake.sh
Executable file
83
ci/build_cmake.sh
Executable file
@@ -0,0 +1,83 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
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
|
||||||
|
if [ $2 = "32" ]
|
||||||
|
then
|
||||||
|
cmake -DMSGPACK_CXX11=ON -DMSGPACK_32BIT=ON ..
|
||||||
|
else
|
||||||
|
cmake -DMSGPACK_CXX11=ON ..
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ $2 = "32" ]
|
||||||
|
then
|
||||||
|
cmake -DMSGPACK_32BIT=ON ..
|
||||||
|
else
|
||||||
|
cmake ..
|
||||||
|
fi
|
||||||
|
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
|
||||||
|
|
||||||
|
if [ $2 != "32" ]
|
||||||
|
then
|
||||||
|
ctest -T memcheck | tee memcheck.log
|
||||||
|
|
||||||
|
ret=${PIPESTATUS[0]}
|
||||||
|
if [ $ret -ne 0 ]
|
||||||
|
then
|
||||||
|
exit $ret
|
||||||
|
fi
|
||||||
|
cat memcheck.log | grep "Memory Leak" > /dev/null
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -eq 0 ]
|
||||||
|
then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
||||||
105
configure.in
105
configure.in
@@ -1,39 +1,98 @@
|
|||||||
AC_INIT(msgpack/unpack_template.h)
|
AC_INIT(msgpack, m4_esyscmd([cat include/msgpack/version_master.h | tr -d "\n" | sed -e 's/#define MSGPACK_VERSION_MAJOR[[:space:]]*\([[:alnum:]]*\)/\1./g' -e 's/#define MSGPACK_VERSION_MINOR[[:space:]]*\([[:alnum:]]*\)/\1./g' -e 's/#define MSGPACK_VERSION_REVISION[[:space:]]*\([[:alnum:]]*\)/\1/g' | tr -d "\n"]))
|
||||||
AC_CONFIG_AUX_DIR(ac)
|
AC_CONFIG_AUX_DIR(ac)
|
||||||
AM_INIT_AUTOMAKE(msgpack, 0.4.0)
|
AM_INIT_AUTOMAKE
|
||||||
AC_CONFIG_HEADER(config.h)
|
AC_CONFIG_HEADER(config.h)
|
||||||
|
|
||||||
AC_SUBST(CFLAGS)
|
AC_SUBST(CFLAGS)
|
||||||
if test "" = "$CFLAGS"; then
|
CFLAGS="-O3 -Wall $CFLAGS"
|
||||||
CFLAGS="-g -O4"
|
|
||||||
fi
|
AC_SUBST(CXXFLAGS)
|
||||||
|
CXXFLAGS="-O3 -Wall $CXXFLAGS"
|
||||||
|
|
||||||
|
|
||||||
AC_PROG_CC
|
AC_PROG_CC
|
||||||
|
|
||||||
CFLAGS="-O4 -Wall $CFLAGS -I.."
|
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([if C++ API is enabled])
|
||||||
AC_MSG_CHECKING([if c++ api is enabled])
|
|
||||||
AC_ARG_ENABLE(cxx,
|
AC_ARG_ENABLE(cxx,
|
||||||
AS_HELP_STRING([--disable-cxx],
|
AS_HELP_STRING([--disable-cxx],
|
||||||
[don't build c++ api.]) )
|
[don't build C++ API]) ) #'
|
||||||
AC_MSG_RESULT($enable_cxx)
|
AC_MSG_RESULT([$enable_cxx])
|
||||||
if test "$enable_cxx" != "no"; then
|
if test "$enable_cxx" != "no"; then
|
||||||
AC_SUBST(CXXFLAGS)
|
AC_PROG_CXX
|
||||||
if test "" = "$CXXFLAGS"; then
|
AM_PROG_CC_C_O
|
||||||
CXXFLAGS="-g -O4"
|
fi
|
||||||
|
AM_CONDITIONAL(ENABLE_CXX, test "$enable_cxx" != "no")
|
||||||
|
|
||||||
|
|
||||||
|
AC_PROG_LIBTOOL
|
||||||
|
AM_PROG_AS
|
||||||
|
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([if debug option is enabled])
|
||||||
|
AC_ARG_ENABLE(debug,
|
||||||
|
AS_HELP_STRING([--disable-debug],
|
||||||
|
[disable assert macros and omit -g option]) )
|
||||||
|
AC_MSG_RESULT([$enable_debug])
|
||||||
|
if test "$enable_debug" != "no"; then
|
||||||
|
CXXFLAGS="$CXXFLAGS -g"
|
||||||
|
CFLAGS="$CFLAGS -g"
|
||||||
|
else
|
||||||
|
CXXFLAGS="$CXXFLAGS -DNDEBUG"
|
||||||
|
CFLAGS="$CFLAGS -DNDEBUG"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
AC_CACHE_CHECK([for __sync_* atomic operations], msgpack_cv_atomic_ops, [
|
||||||
|
AC_TRY_LINK([
|
||||||
|
int atomic_sub(int i) { return __sync_sub_and_fetch(&i, 1); }
|
||||||
|
int atomic_add(int i) { return __sync_add_and_fetch(&i, 1); }
|
||||||
|
], [atomic_sub(1); atomic_add(1);], msgpack_cv_atomic_ops="yes")
|
||||||
|
])
|
||||||
|
if test "$msgpack_cv_atomic_ops" != "yes"; then
|
||||||
|
if test "$enable_cxx" = "no"; then
|
||||||
|
AC_MSG_ERROR([__sync_* atomic operations are not found. Try to enable C++ support.
|
||||||
|
If you are using gcc >= 4.1 and the default target CPU architecture is "i386", try to
|
||||||
|
add CFLAGS="-march=i686" and CXXFLAGS="-march=i686" options to ./configure as follows:
|
||||||
|
|
||||||
|
$ ./configure CFLAGS="-march=i686" CXXFLAGS="-march=i686"
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_LANG_PUSH([C++])
|
||||||
|
AC_CACHE_CHECK([for __gnu_cxx::__exchange_and_add], msgpack_cv_gcc_cxx_atomic_ops, [
|
||||||
|
AC_TRY_LINK([
|
||||||
|
#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; }
|
||||||
|
], [atomic_sub(1); atomic_add(1);], msgpack_cv_gcc_cxx_atomic_ops="yes")
|
||||||
|
])
|
||||||
|
AC_LANG_POP([C++])
|
||||||
|
|
||||||
|
if test "$msgpack_cv_gcc_cxx_atomic_ops" != "yes"; then
|
||||||
|
AC_MSG_ERROR([__sync_* atomic operations nor __gnu_cxx::__exchange_and_add are not found.
|
||||||
|
|
||||||
|
If you are using gcc >= 4.1 and the default target CPU architecture is "i386", try to
|
||||||
|
add CFLAGS="-march=i686" and CXXFLAGS="-march=i686" options to ./configure as follows:
|
||||||
|
|
||||||
|
$ ./configure CFLAGS="-march=i686" CXXFLAGS="-march=i686"
|
||||||
|
])
|
||||||
|
|
||||||
|
else
|
||||||
|
enable_gcc_cxx_atomic=yes
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# FIXME
|
AM_CONDITIONAL(ENABLE_GCC_CXX_ATOMIC, test "$enable_gcc_cxx_atomic" = "yes")
|
||||||
AC_PROG_CXX
|
|
||||||
|
|
||||||
CXXFLAGS="-O4 -Wall $CXXFLAGS -I.. -I../c"
|
major=`echo $VERSION | sed 's/\([[0-9]]*\)\.\([[0-9]]*\).\([[0-9]]*\).*/\1/'`
|
||||||
|
minor=`echo $VERSION | sed 's/\([[0-9]]*\)\.\([[0-9]]*\).\([[0-9]]*\).*/\2/'`
|
||||||
|
revision=`echo $VERSION | sed 's/\([[0-9]]*\)\.\([[0-9]]*\).\([[0-9]]*\).*/\3/'`
|
||||||
|
AC_SUBST(VERSION_MAJOR, $major)
|
||||||
|
AC_SUBST(VERSION_MINOR, $minor)
|
||||||
|
AC_SUBST(VERSION_REVISION, $revision)
|
||||||
|
|
||||||
|
|
||||||
AM_CONDITIONAL(ENABLE_CXX, test "$enable_cxx" != "no")
|
AC_OUTPUT([Makefile
|
||||||
|
msgpack.pc
|
||||||
AC_PROG_LIBTOOL
|
src/Makefile
|
||||||
|
test/Makefile])
|
||||||
AC_OUTPUT([Makefile c/Makefile cpp/Makefile])
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,44 +0,0 @@
|
|||||||
lib_LTLIBRARIES = libmsgpack.la
|
|
||||||
|
|
||||||
libmsgpack_la_SOURCES = \
|
|
||||||
object.cpp
|
|
||||||
|
|
||||||
nobase_include_HEADERS = \
|
|
||||||
msgpack.hpp \
|
|
||||||
msgpack/sbuffer.hpp \
|
|
||||||
msgpack/vrefbuffer.hpp \
|
|
||||||
msgpack/pack.hpp \
|
|
||||||
msgpack/unpack.hpp \
|
|
||||||
msgpack/object.hpp \
|
|
||||||
msgpack/zone.hpp \
|
|
||||||
msgpack/type.hpp \
|
|
||||||
msgpack/type/bool.hpp \
|
|
||||||
msgpack/type/float.hpp \
|
|
||||||
msgpack/type/int.hpp \
|
|
||||||
msgpack/type/list.hpp \
|
|
||||||
msgpack/type/deque.hpp \
|
|
||||||
msgpack/type/map.hpp \
|
|
||||||
msgpack/type/nil.hpp \
|
|
||||||
msgpack/type/pair.hpp \
|
|
||||||
msgpack/type/raw.hpp \
|
|
||||||
msgpack/type/set.hpp \
|
|
||||||
msgpack/type/string.hpp \
|
|
||||||
msgpack/type/vector.hpp \
|
|
||||||
msgpack/type/tuple.hpp \
|
|
||||||
msgpack/type/define.hpp \
|
|
||||||
msgpack/type/tr1/unordered_map.hpp \
|
|
||||||
msgpack/type/tr1/unordered_set.hpp
|
|
||||||
|
|
||||||
libmsgpack_la_LIBADD = -L../c -lmsgpackc
|
|
||||||
|
|
||||||
# -version-info CURRENT:REVISION:AGE
|
|
||||||
libmsgpack_la_LDFLAGS = -version-info 2:0:0
|
|
||||||
|
|
||||||
check_PROGRAMS = \
|
|
||||||
msgpack_test
|
|
||||||
|
|
||||||
msgpack_test_SOURCES = test.cpp
|
|
||||||
msgpack_test_CXXFLAGS = -I$(top_srcdir) -I$(top_srcdir)/c -I$(top_srcdir)/cpp
|
|
||||||
msgpack_test_LDFLAGS = libmsgpack.la -lgtest_main
|
|
||||||
|
|
||||||
TESTS = $(check_PROGRAMS)
|
|
||||||
188
cpp/bench.cpp
188
cpp/bench.cpp
@@ -1,188 +0,0 @@
|
|||||||
#include <msgpack/unpack.hpp>
|
|
||||||
#include <msgpack/pack.hpp>
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/time.h>
|
|
||||||
#include <iostream>
|
|
||||||
#include <stdexcept>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
static const unsigned int TASK_INT_NUM = 1<<24;
|
|
||||||
static const unsigned int TASK_STR_LEN = 1<<15;
|
|
||||||
//static const unsigned int TASK_INT_NUM = 1<<22;
|
|
||||||
//static const unsigned int TASK_STR_LEN = 1<<13;
|
|
||||||
static const char* TASK_STR_PTR;
|
|
||||||
|
|
||||||
|
|
||||||
class simple_timer {
|
|
||||||
public:
|
|
||||||
void reset() { gettimeofday(&m_timeval, NULL); }
|
|
||||||
void show_stat(size_t bufsz)
|
|
||||||
{
|
|
||||||
struct timeval endtime;
|
|
||||||
gettimeofday(&endtime, NULL);
|
|
||||||
double sec = (endtime.tv_sec - m_timeval.tv_sec)
|
|
||||||
+ (double)(endtime.tv_usec - m_timeval.tv_usec) / 1000 / 1000;
|
|
||||||
std::cout << sec << " sec" << std::endl;
|
|
||||||
std::cout << (double(bufsz)/1024/1024) << " MB" << std::endl;
|
|
||||||
std::cout << (bufsz/sec/1000/1000*8) << " Mbps" << std::endl;
|
|
||||||
}
|
|
||||||
private:
|
|
||||||
timeval m_timeval;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class simple_buffer {
|
|
||||||
public:
|
|
||||||
static const size_t DEFAULT_INITIAL_SIZE = 32*1024;//512*1024*1024*2;
|
|
||||||
|
|
||||||
simple_buffer(size_t initial_size = DEFAULT_INITIAL_SIZE) :
|
|
||||||
m_storage((char*)malloc(initial_size)),
|
|
||||||
m_allocated(initial_size),
|
|
||||||
m_used(0)
|
|
||||||
{
|
|
||||||
if(!m_storage) { throw std::bad_alloc(); }
|
|
||||||
}
|
|
||||||
|
|
||||||
~simple_buffer()
|
|
||||||
{
|
|
||||||
free(m_storage);
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
inline void write(const char* buf, size_t len)
|
|
||||||
{
|
|
||||||
if(m_allocated - m_used < len) {
|
|
||||||
expand_buffer(len);
|
|
||||||
}
|
|
||||||
memcpy(m_storage + m_used, buf, len);
|
|
||||||
m_used += len;
|
|
||||||
}
|
|
||||||
|
|
||||||
void clear()
|
|
||||||
{
|
|
||||||
m_used = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
void expand_buffer(size_t req)
|
|
||||||
{
|
|
||||||
size_t nsize = m_allocated * 2;
|
|
||||||
size_t at_least = m_used + req;
|
|
||||||
while(nsize < at_least) { nsize *= 2; }
|
|
||||||
char* tmp = (char*)realloc(m_storage, nsize);
|
|
||||||
if(!tmp) { throw std::bad_alloc(); }
|
|
||||||
m_storage = tmp;
|
|
||||||
m_allocated = nsize;
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
size_t size() const { return m_used; }
|
|
||||||
const char* data() const { return m_storage; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
char* m_storage;
|
|
||||||
size_t m_allocated;
|
|
||||||
size_t m_used;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
void bench_msgpack_int()
|
|
||||||
{
|
|
||||||
simple_buffer buf;
|
|
||||||
simple_timer timer;
|
|
||||||
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "pack integer" << std::endl;
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
{
|
|
||||||
msgpack::packer<simple_buffer> pk(buf);
|
|
||||||
pk.pack_array(TASK_INT_NUM);
|
|
||||||
for(unsigned int i=0; i < TASK_INT_NUM; ++i) {
|
|
||||||
pk.pack_unsigned_int(i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
|
|
||||||
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "unpack integer" << std::endl;
|
|
||||||
|
|
||||||
msgpack::zone z;
|
|
||||||
msgpack::object obj;
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
{
|
|
||||||
obj = msgpack::unpack(buf.data(), buf.size(), z);
|
|
||||||
}
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
|
|
||||||
/*
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "dynamic pack integer" << std::endl;
|
|
||||||
|
|
||||||
buf.clear();
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
msgpack::pack(buf, obj);
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
void bench_msgpack_str()
|
|
||||||
{
|
|
||||||
simple_buffer buf;
|
|
||||||
simple_timer timer;
|
|
||||||
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "pack string" << std::endl;
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
{
|
|
||||||
msgpack::packer<simple_buffer> pk(buf);
|
|
||||||
pk.pack_array(TASK_STR_LEN);
|
|
||||||
for(unsigned int i=0; i < TASK_STR_LEN; ++i) {
|
|
||||||
pk.pack_raw(i);
|
|
||||||
pk.pack_raw_body(TASK_STR_PTR, i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
|
|
||||||
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "unpack string" << std::endl;
|
|
||||||
|
|
||||||
msgpack::zone z;
|
|
||||||
msgpack::object obj;
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
{
|
|
||||||
obj = msgpack::unpack(buf.data(), buf.size(), z);
|
|
||||||
}
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
std::cout << "----" << std::endl;
|
|
||||||
std::cout << "dynamic pack string" << std::endl;
|
|
||||||
|
|
||||||
buf.clear();
|
|
||||||
|
|
||||||
timer.reset();
|
|
||||||
msgpack::pack(buf, obj);
|
|
||||||
timer.show_stat(buf.size());
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
char* str = (char*)malloc(TASK_STR_LEN);
|
|
||||||
memset(str, 'a', TASK_STR_LEN);
|
|
||||||
TASK_STR_PTR = str;
|
|
||||||
|
|
||||||
bench_msgpack_int();
|
|
||||||
bench_msgpack_str();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
|
|
||||||
CXXFLAGS += -Wall -g -I. -I.. -O4
|
|
||||||
LDFLAGS +=
|
|
||||||
|
|
||||||
all: bench
|
|
||||||
|
|
||||||
bench: bench.o unpack.o zone.o object.o pack.hpp unpack.hpp zone.hpp object.hpp
|
|
||||||
$(CXX) bench.o unpack.o zone.o object.o $(CXXFLAGS) $(LDFLAGS) -o $@
|
|
||||||
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
.
|
|
||||||
138
cpp/object.cpp
138
cpp/object.cpp
@@ -1,138 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ dynamic typed objects
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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.
|
|
||||||
//
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
std::ostream& operator<< (std::ostream& s, const object o)
|
|
||||||
{
|
|
||||||
switch(o.type) {
|
|
||||||
case type::NIL:
|
|
||||||
s << "nil";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::BOOLEAN:
|
|
||||||
s << (o.via.boolean ? "true" : "false");
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::POSITIVE_INTEGER:
|
|
||||||
s << o.via.u64;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::NEGATIVE_INTEGER:
|
|
||||||
s << o.via.i64;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::DOUBLE:
|
|
||||||
s << o.via.dec;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::RAW:
|
|
||||||
(s << '"').write(o.via.raw.ptr, o.via.raw.size) << '"';
|
|
||||||
break;
|
|
||||||
|
|
||||||
case type::ARRAY:
|
|
||||||
s << "[";
|
|
||||||
if(o.via.array.size != 0) {
|
|
||||||
object* p(o.via.array.ptr);
|
|
||||||
s << *p;
|
|
||||||
++p;
|
|
||||||
for(object* const pend(o.via.array.ptr + o.via.array.size);
|
|
||||||
p < pend; ++p) {
|
|
||||||
s << ", " << *p;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
s << "]";
|
|
||||||
break;
|
|
||||||
// FIXME loop optimiziation
|
|
||||||
|
|
||||||
case type::MAP:
|
|
||||||
s << "{";
|
|
||||||
if(o.via.map.size != 0) {
|
|
||||||
object_kv* p(o.via.map.ptr);
|
|
||||||
s << p->key << "=>" << p->val;
|
|
||||||
++p;
|
|
||||||
for(object_kv* const pend(o.via.map.ptr + o.via.map.size);
|
|
||||||
p < pend; ++p) {
|
|
||||||
s << ", " << p->key << "=>" << p->val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
s << "}";
|
|
||||||
break;
|
|
||||||
// FIXME loop optimiziation
|
|
||||||
|
|
||||||
default:
|
|
||||||
// FIXME
|
|
||||||
s << "#<UNKNOWN " << (uint16_t)o.type << ">";
|
|
||||||
}
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool operator==(const object x, const object y)
|
|
||||||
{
|
|
||||||
if(x.type != y.type) { return false; }
|
|
||||||
|
|
||||||
switch(x.type) {
|
|
||||||
case type::NIL:
|
|
||||||
return true;
|
|
||||||
|
|
||||||
case type::BOOLEAN:
|
|
||||||
return x.via.boolean == y.via.boolean;
|
|
||||||
|
|
||||||
case type::POSITIVE_INTEGER:
|
|
||||||
return x.via.u64 == y.via.u64;
|
|
||||||
|
|
||||||
case type::NEGATIVE_INTEGER:
|
|
||||||
return x.via.i64 == y.via.i64;
|
|
||||||
|
|
||||||
case type::RAW:
|
|
||||||
return x.via.raw.size == y.via.raw.size &&
|
|
||||||
memcmp(x.via.raw.ptr, y.via.raw.ptr, x.via.raw.size) == 0;
|
|
||||||
|
|
||||||
case type::ARRAY:
|
|
||||||
if(x.via.array.size != y.via.array.size) { return false; }
|
|
||||||
for(object* px(x.via.array.ptr),
|
|
||||||
* const pxend(x.via.array.ptr + x.via.array.size),
|
|
||||||
* py(y.via.array.ptr);
|
|
||||||
px < pxend; ++px, ++py) {
|
|
||||||
if(*px != *py) { return false; }
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
// FIXME loop optimiziation
|
|
||||||
|
|
||||||
case type::MAP:
|
|
||||||
if(x.via.map.size != y.via.map.size) { return false; }
|
|
||||||
for(object_kv* px(x.via.map.ptr),
|
|
||||||
* const pxend(x.via.map.ptr + x.via.map.size),
|
|
||||||
* py(y.via.map.ptr);
|
|
||||||
px < pxend; ++px, ++py) {
|
|
||||||
if(px->key != py->key || px->val != py->val) { return false; }
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
329
cpp/object.hpp
329
cpp/object.hpp
@@ -1,329 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_OBJECT_HPP__
|
|
||||||
#define MSGPACK_OBJECT_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.h"
|
|
||||||
#include "msgpack/pack.hpp"
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdexcept>
|
|
||||||
#include <typeinfo>
|
|
||||||
#include <limits>
|
|
||||||
#include <ostream>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
class type_error : public std::bad_cast { };
|
|
||||||
|
|
||||||
|
|
||||||
namespace type {
|
|
||||||
enum object_type {
|
|
||||||
NIL = 0x01,
|
|
||||||
BOOLEAN = 0x02,
|
|
||||||
POSITIVE_INTEGER = 0x03,
|
|
||||||
NEGATIVE_INTEGER = 0x04,
|
|
||||||
DOUBLE = 0x05,
|
|
||||||
RAW = 0x06,
|
|
||||||
ARRAY = 0x07,
|
|
||||||
MAP = 0x08,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
struct object;
|
|
||||||
struct object_kv;
|
|
||||||
|
|
||||||
struct object_array {
|
|
||||||
uint32_t size;
|
|
||||||
object* ptr;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct object_map {
|
|
||||||
uint32_t size;
|
|
||||||
object_kv* ptr;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct object_raw {
|
|
||||||
uint32_t size;
|
|
||||||
const char* ptr;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct object {
|
|
||||||
union union_type {
|
|
||||||
bool boolean;
|
|
||||||
uint64_t u64;
|
|
||||||
int64_t i64;
|
|
||||||
double dec;
|
|
||||||
object_array array;
|
|
||||||
object_map map;
|
|
||||||
object_raw raw;
|
|
||||||
object_raw ref; // obsolete
|
|
||||||
};
|
|
||||||
|
|
||||||
type::object_type type;
|
|
||||||
union_type via;
|
|
||||||
|
|
||||||
bool is_nil() const { return type == type::NIL; }
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
T as() const;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
void convert(T* v) const;
|
|
||||||
|
|
||||||
object();
|
|
||||||
object(msgpack_object obj);
|
|
||||||
operator msgpack_object();
|
|
||||||
|
|
||||||
private:
|
|
||||||
struct implicit_type;
|
|
||||||
|
|
||||||
public:
|
|
||||||
implicit_type convert() const;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct object_kv {
|
|
||||||
object key;
|
|
||||||
object val;
|
|
||||||
};
|
|
||||||
|
|
||||||
bool operator==(const object x, const object y);
|
|
||||||
bool operator!=(const object x, const object y);
|
|
||||||
|
|
||||||
std::ostream& operator<< (std::ostream& s, const object o);
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
packer<Stream>& operator<< (packer<Stream>& o, const T& v);
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
T& operator>> (object o, T& v);
|
|
||||||
|
|
||||||
|
|
||||||
struct object::implicit_type {
|
|
||||||
implicit_type(object o) : obj(o) { }
|
|
||||||
~implicit_type() { }
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
operator T() { return obj.as<T>(); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
object obj;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
template <typename Type>
|
|
||||||
class define : public Type {
|
|
||||||
public:
|
|
||||||
typedef Type msgpack_type;
|
|
||||||
typedef define<Type> define_type;
|
|
||||||
|
|
||||||
define() {}
|
|
||||||
define(const msgpack_type& v) : msgpack_type(v) {}
|
|
||||||
|
|
||||||
template <typename Packer>
|
|
||||||
void msgpack_pack(Packer& o) const
|
|
||||||
{
|
|
||||||
o << static_cast<const msgpack_type&>(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpack(object o)
|
|
||||||
{
|
|
||||||
o >> static_cast<msgpack_type&>(*this);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
template <typename T>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack(const T& v)
|
|
||||||
{
|
|
||||||
*this << v;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline object& operator>> (object o, object& v)
|
|
||||||
{
|
|
||||||
v = o;
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline T& operator>> (object o, T& v)
|
|
||||||
{
|
|
||||||
v.msgpack_unpack(o.convert());
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const T& v)
|
|
||||||
{
|
|
||||||
v.msgpack_pack(o);
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline bool operator!=(const object x, const object y)
|
|
||||||
{ return !(x == y); }
|
|
||||||
|
|
||||||
|
|
||||||
inline object::object() { }
|
|
||||||
|
|
||||||
inline object::object(msgpack_object obj)
|
|
||||||
{
|
|
||||||
// FIXME beter way?
|
|
||||||
::memcpy(this, &obj, sizeof(obj));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline object::operator msgpack_object()
|
|
||||||
{
|
|
||||||
// FIXME beter way?
|
|
||||||
msgpack_object obj;
|
|
||||||
::memcpy(&obj, this, sizeof(obj));
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline object::implicit_type object::convert() const
|
|
||||||
{
|
|
||||||
return implicit_type(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline void object::convert(T* v) const
|
|
||||||
{
|
|
||||||
*this >> *v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline T object::as() const
|
|
||||||
{
|
|
||||||
T v;
|
|
||||||
convert(&v);
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
template <typename T>
|
|
||||||
inline void convert(T& v, object o)
|
|
||||||
{
|
|
||||||
o.convert(&v);
|
|
||||||
}
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline void pack(packer<Stream>& o, const T& v)
|
|
||||||
{
|
|
||||||
o.pack(v);
|
|
||||||
}
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline void pack_copy(packer<Stream>& o, T v)
|
|
||||||
{
|
|
||||||
pack(o, v);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
packer<Stream>& operator<< (packer<Stream>& o, const object& v)
|
|
||||||
{
|
|
||||||
switch(v.type) {
|
|
||||||
case type::NIL:
|
|
||||||
o.pack_nil();
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::BOOLEAN:
|
|
||||||
if(v.via.boolean) {
|
|
||||||
o.pack_true();
|
|
||||||
} else {
|
|
||||||
o.pack_false();
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::POSITIVE_INTEGER:
|
|
||||||
if(v.via.u64 <= (uint64_t)std::numeric_limits<uint16_t>::max()) {
|
|
||||||
if(v.via.u64 <= (uint16_t)std::numeric_limits<uint8_t>::max()) {
|
|
||||||
o.pack_uint8(v.via.u64);
|
|
||||||
} else {
|
|
||||||
o.pack_uint16(v.via.u64);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if(v.via.u64 <= (uint64_t)std::numeric_limits<uint32_t>::max()) {
|
|
||||||
o.pack_uint32(v.via.u64);
|
|
||||||
} else {
|
|
||||||
o.pack_uint64(v.via.u64);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::NEGATIVE_INTEGER:
|
|
||||||
if(v.via.i64 >= (int64_t)std::numeric_limits<int16_t>::min()) {
|
|
||||||
if(v.via.i64 >= (int64_t)std::numeric_limits<int8_t>::min()) {
|
|
||||||
o.pack_int8(v.via.i64);
|
|
||||||
} else {
|
|
||||||
o.pack_int16(v.via.i64);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if(v.via.i64 >= (int64_t)std::numeric_limits<int32_t>::min()) {
|
|
||||||
o.pack_int64(v.via.i64);
|
|
||||||
} else {
|
|
||||||
o.pack_int64(v.via.i64);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::RAW:
|
|
||||||
o.pack_raw(v.via.raw.size);
|
|
||||||
o.pack_raw_body(v.via.raw.ptr, v.via.raw.size);
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::ARRAY:
|
|
||||||
o.pack_array(v.via.array.size);
|
|
||||||
for(object* p(v.via.array.ptr),
|
|
||||||
* const pend(v.via.array.ptr + v.via.array.size);
|
|
||||||
p < pend; ++p) {
|
|
||||||
o << *p;
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
|
|
||||||
case type::MAP:
|
|
||||||
o.pack_map(v.via.map.size);
|
|
||||||
for(object_kv* p(v.via.map.ptr),
|
|
||||||
* const pend(v.via.map.ptr + v.via.map.size);
|
|
||||||
p < pend; ++p) {
|
|
||||||
o << p->key;
|
|
||||||
o << p->val;
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw type_error();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#include "msgpack/type.hpp"
|
|
||||||
|
|
||||||
#endif /* msgpack/object.hpp */
|
|
||||||
|
|
||||||
252
cpp/pack.hpp
252
cpp/pack.hpp
@@ -1,252 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ serializing routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_PACK_HPP__
|
|
||||||
#define MSGPACK_PACK_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/pack_define.h"
|
|
||||||
#include <stdexcept>
|
|
||||||
#include <limits.h>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
class packer {
|
|
||||||
public:
|
|
||||||
packer(Stream& s);
|
|
||||||
~packer();
|
|
||||||
|
|
||||||
public:
|
|
||||||
template <typename T>
|
|
||||||
packer<Stream>& pack(const T& v);
|
|
||||||
|
|
||||||
packer<Stream>& pack_uint8(uint8_t d);
|
|
||||||
packer<Stream>& pack_uint16(uint16_t d);
|
|
||||||
packer<Stream>& pack_uint32(uint32_t d);
|
|
||||||
packer<Stream>& pack_uint64(uint64_t d);
|
|
||||||
packer<Stream>& pack_int8(uint8_t d);
|
|
||||||
packer<Stream>& pack_int16(uint16_t d);
|
|
||||||
packer<Stream>& pack_int32(uint32_t d);
|
|
||||||
packer<Stream>& pack_int64(uint64_t d);
|
|
||||||
|
|
||||||
packer<Stream>& pack_short(int d);
|
|
||||||
packer<Stream>& pack_int(int d);
|
|
||||||
packer<Stream>& pack_long(long d);
|
|
||||||
packer<Stream>& pack_long_long(long long d);
|
|
||||||
packer<Stream>& pack_unsigned_short(unsigned short d);
|
|
||||||
packer<Stream>& pack_unsigned_int(unsigned int d);
|
|
||||||
packer<Stream>& pack_unsigned_long(unsigned long d);
|
|
||||||
packer<Stream>& pack_unsigned_long_long(unsigned long long d);
|
|
||||||
|
|
||||||
packer<Stream>& pack_float(float d);
|
|
||||||
packer<Stream>& pack_double(double d);
|
|
||||||
|
|
||||||
packer<Stream>& pack_nil();
|
|
||||||
packer<Stream>& pack_true();
|
|
||||||
packer<Stream>& pack_false();
|
|
||||||
|
|
||||||
packer<Stream>& pack_array(unsigned int n);
|
|
||||||
|
|
||||||
packer<Stream>& pack_map(unsigned int n);
|
|
||||||
|
|
||||||
packer<Stream>& pack_raw(size_t l);
|
|
||||||
packer<Stream>& pack_raw_body(const char* b, size_t l);
|
|
||||||
|
|
||||||
private:
|
|
||||||
static void _pack_uint8(Stream& x, uint8_t d);
|
|
||||||
static void _pack_uint16(Stream& x, uint16_t d);
|
|
||||||
static void _pack_uint32(Stream& x, uint32_t d);
|
|
||||||
static void _pack_uint64(Stream& x, uint64_t d);
|
|
||||||
static void _pack_int8(Stream& x, int8_t d);
|
|
||||||
static void _pack_int16(Stream& x, int16_t d);
|
|
||||||
static void _pack_int32(Stream& x, int32_t d);
|
|
||||||
static void _pack_int64(Stream& x, int64_t d);
|
|
||||||
|
|
||||||
static void _pack_short(Stream& x, short d);
|
|
||||||
static void _pack_int(Stream& x, int d);
|
|
||||||
static void _pack_long(Stream& x, long d);
|
|
||||||
static void _pack_long_long(Stream& x, long long d);
|
|
||||||
static void _pack_unsigned_short(Stream& x, unsigned short d);
|
|
||||||
static void _pack_unsigned_int(Stream& x, unsigned int d);
|
|
||||||
static void _pack_unsigned_long(Stream& x, unsigned long d);
|
|
||||||
static void _pack_unsigned_long_long(Stream& x, unsigned long long d);
|
|
||||||
|
|
||||||
static void _pack_float(Stream& x, float d);
|
|
||||||
static void _pack_double(Stream& x, double d);
|
|
||||||
|
|
||||||
static void _pack_nil(Stream& x);
|
|
||||||
static void _pack_true(Stream& x);
|
|
||||||
static void _pack_false(Stream& x);
|
|
||||||
|
|
||||||
static void _pack_array(Stream& x, unsigned int n);
|
|
||||||
|
|
||||||
static void _pack_map(Stream& x, unsigned int n);
|
|
||||||
|
|
||||||
static void _pack_raw(Stream& x, size_t l);
|
|
||||||
static void _pack_raw_body(Stream& x, const void* b, size_t l);
|
|
||||||
|
|
||||||
static void append_buffer(Stream& x, const unsigned char* buf, unsigned int len)
|
|
||||||
{ x.write((const char*)buf, len); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
Stream& m_stream;
|
|
||||||
|
|
||||||
private:
|
|
||||||
packer();
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline void pack(Stream& s, const T& v)
|
|
||||||
{
|
|
||||||
packer<Stream>(s).pack(v);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#define msgpack_pack_inline_func(name) \
|
|
||||||
template <typename Stream> \
|
|
||||||
inline void packer<Stream>::_pack ## name
|
|
||||||
|
|
||||||
#define msgpack_pack_inline_func_cint(name) \
|
|
||||||
template <typename Stream> \
|
|
||||||
inline void packer<Stream>::_pack ## name
|
|
||||||
|
|
||||||
#define msgpack_pack_user Stream&
|
|
||||||
|
|
||||||
#define msgpack_pack_append_buffer append_buffer
|
|
||||||
|
|
||||||
#include "msgpack/pack_template.h"
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
packer<Stream>::packer(Stream& s) : m_stream(s) { }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
packer<Stream>::~packer() { }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_uint8(uint8_t d)
|
|
||||||
{ _pack_uint8(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_uint16(uint16_t d)
|
|
||||||
{ _pack_uint16(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_uint32(uint32_t d)
|
|
||||||
{ _pack_uint32(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_uint64(uint64_t d)
|
|
||||||
{ _pack_uint64(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_int8(uint8_t d)
|
|
||||||
{ _pack_int8(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_int16(uint16_t d)
|
|
||||||
{ _pack_int16(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_int32(uint32_t d)
|
|
||||||
{ _pack_int32(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_int64(uint64_t d)
|
|
||||||
{ _pack_int64(m_stream, d); return *this;}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_short(int d)
|
|
||||||
{ _pack_short(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_int(int d)
|
|
||||||
{ _pack_int(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_long(long d)
|
|
||||||
{ _pack_long(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_long_long(long long d)
|
|
||||||
{ _pack_long_long(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_unsigned_short(unsigned short d)
|
|
||||||
{ _pack_unsigned_short(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_unsigned_int(unsigned int d)
|
|
||||||
{ _pack_unsigned_int(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_unsigned_long(unsigned long d)
|
|
||||||
{ _pack_unsigned_long(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_unsigned_long_long(unsigned long long d)
|
|
||||||
{ _pack_unsigned_long_long(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_float(float d)
|
|
||||||
{ _pack_float(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_double(double d)
|
|
||||||
{ _pack_double(m_stream, d); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_nil()
|
|
||||||
{ _pack_nil(m_stream); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_true()
|
|
||||||
{ _pack_true(m_stream); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_false()
|
|
||||||
{ _pack_false(m_stream); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_array(unsigned int n)
|
|
||||||
{ _pack_array(m_stream, n); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_map(unsigned int n)
|
|
||||||
{ _pack_map(m_stream, n); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_raw(size_t l)
|
|
||||||
{ _pack_raw(m_stream, l); return *this; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& packer<Stream>::pack_raw_body(const char* b, size_t l)
|
|
||||||
{ _pack_raw_body(m_stream, b, l); return *this; }
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/pack.hpp */
|
|
||||||
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
preprocess() {
|
|
||||||
ruby -r erb -e 'puts ERB.new(ARGF.read).result' $1.erb > $1.tmp
|
|
||||||
if [ "$?" != 0 ]; then
|
|
||||||
echo ""
|
|
||||||
echo "** preprocess failed **"
|
|
||||||
echo ""
|
|
||||||
else
|
|
||||||
mv $1.tmp $1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
preprocess msgpack/type/tuple.hpp
|
|
||||||
preprocess msgpack/type/define.hpp
|
|
||||||
preprocess msgpack/zone.hpp
|
|
||||||
|
|
||||||
103
cpp/sbuffer.hpp
103
cpp/sbuffer.hpp
@@ -1,103 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ simple buffer implementation
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_SBUFFER_HPP__
|
|
||||||
#define MSGPACK_SBUFFER_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/sbuffer.h"
|
|
||||||
#include <stdexcept>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
class sbuffer : public msgpack_sbuffer {
|
|
||||||
public:
|
|
||||||
sbuffer(size_t initsz = MSGPACK_SBUFFER_INIT_SIZE)
|
|
||||||
{
|
|
||||||
base::data = (char*)::malloc(initsz);
|
|
||||||
if(!base::data) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
|
|
||||||
base::size = 0;
|
|
||||||
base::alloc = initsz;
|
|
||||||
}
|
|
||||||
|
|
||||||
~sbuffer()
|
|
||||||
{
|
|
||||||
::free(base::data);
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
void write(const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
if(base::alloc - base::size < len) {
|
|
||||||
expand_buffer(len);
|
|
||||||
}
|
|
||||||
memcpy(base::data + base::size, buf, len);
|
|
||||||
base::size += len;
|
|
||||||
}
|
|
||||||
|
|
||||||
char* data()
|
|
||||||
{
|
|
||||||
return base::data;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* data() const
|
|
||||||
{
|
|
||||||
return base::data;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t size() const
|
|
||||||
{
|
|
||||||
return base::size;
|
|
||||||
}
|
|
||||||
|
|
||||||
char* release()
|
|
||||||
{
|
|
||||||
return msgpack_sbuffer_release(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
void expand_buffer(size_t len)
|
|
||||||
{
|
|
||||||
size_t nsize = (base::alloc) ?
|
|
||||||
base::alloc * 2 : MSGPACK_SBUFFER_INIT_SIZE;
|
|
||||||
|
|
||||||
while(nsize < base::size + len) { nsize *= 2; }
|
|
||||||
|
|
||||||
void* tmp = realloc(base::data, nsize);
|
|
||||||
if(!tmp) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
|
|
||||||
base::data = (char*)tmp;
|
|
||||||
base::alloc = nsize;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
typedef msgpack_sbuffer base;
|
|
||||||
|
|
||||||
private:
|
|
||||||
sbuffer(const sbuffer&);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/sbuffer.hpp */
|
|
||||||
|
|
||||||
792
cpp/test.cpp
792
cpp/test.cpp
@@ -1,792 +0,0 @@
|
|||||||
#include "msgpack.hpp"
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#include <map>
|
|
||||||
#include <deque>
|
|
||||||
#include <set>
|
|
||||||
#include <list>
|
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
const unsigned int kLoop = 10000;
|
|
||||||
const unsigned int kElements = 100;
|
|
||||||
const double kEPS = 1e-10;
|
|
||||||
|
|
||||||
#define GEN_TEST(test_type) \
|
|
||||||
do { \
|
|
||||||
vector<test_type> v; \
|
|
||||||
v.push_back(0); \
|
|
||||||
v.push_back(1); \
|
|
||||||
v.push_back(2); \
|
|
||||||
v.push_back(numeric_limits<test_type>::min()); \
|
|
||||||
v.push_back(numeric_limits<test_type>::max()); \
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) \
|
|
||||||
v.push_back(rand()); \
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) { \
|
|
||||||
msgpack::sbuffer sbuf; \
|
|
||||||
test_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); \
|
|
||||||
test_type val2; \
|
|
||||||
obj.convert(&val2); \
|
|
||||||
EXPECT_EQ(val1, val2); \
|
|
||||||
} \
|
|
||||||
} while(0)
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_short)
|
|
||||||
{
|
|
||||||
GEN_TEST(short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_int)
|
|
||||||
{
|
|
||||||
GEN_TEST(int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_long)
|
|
||||||
{
|
|
||||||
GEN_TEST(long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST(long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_unsigned_short)
|
|
||||||
{
|
|
||||||
GEN_TEST(unsigned short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_unsigned_int)
|
|
||||||
{
|
|
||||||
GEN_TEST(unsigned int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_unsigned_long)
|
|
||||||
{
|
|
||||||
GEN_TEST(unsigned long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_unsigned_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST(unsigned long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_uint8)
|
|
||||||
{
|
|
||||||
GEN_TEST(uint8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_uint16)
|
|
||||||
{
|
|
||||||
GEN_TEST(uint16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_uint32)
|
|
||||||
{
|
|
||||||
GEN_TEST(uint32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_uint64)
|
|
||||||
{
|
|
||||||
GEN_TEST(uint64_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_int8)
|
|
||||||
{
|
|
||||||
GEN_TEST(int8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_int16)
|
|
||||||
{
|
|
||||||
GEN_TEST(int16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_int32)
|
|
||||||
{
|
|
||||||
GEN_TEST(int32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_int64)
|
|
||||||
{
|
|
||||||
GEN_TEST(int64_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_float)
|
|
||||||
{
|
|
||||||
vector<float> v;
|
|
||||||
v.push_back(0.0);
|
|
||||||
v.push_back(-0.0);
|
|
||||||
v.push_back(1.0);
|
|
||||||
v.push_back(-1.0);
|
|
||||||
v.push_back(numeric_limits<float>::min());
|
|
||||||
v.push_back(numeric_limits<float>::max());
|
|
||||||
v.push_back(nanf("tag"));
|
|
||||||
v.push_back(1.0/0.0); // inf
|
|
||||||
v.push_back(-(1.0/0.0)); // -inf
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) {
|
|
||||||
v.push_back(drand48());
|
|
||||||
v.push_back(-drand48());
|
|
||||||
}
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) {
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
float 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 val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
|
|
||||||
if (isnan(val1))
|
|
||||||
EXPECT_TRUE(isnan(val2));
|
|
||||||
else if (isinf(val1))
|
|
||||||
EXPECT_TRUE(isinf(val2));
|
|
||||||
else
|
|
||||||
EXPECT_TRUE(fabs(val2 - val1) <= kEPS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_double)
|
|
||||||
{
|
|
||||||
vector<double> v;
|
|
||||||
v.push_back(0.0);
|
|
||||||
v.push_back(-0.0);
|
|
||||||
v.push_back(1.0);
|
|
||||||
v.push_back(-1.0);
|
|
||||||
v.push_back(numeric_limits<double>::min());
|
|
||||||
v.push_back(numeric_limits<double>::max());
|
|
||||||
v.push_back(nanf("tag"));
|
|
||||||
v.push_back(1.0/0.0); // inf
|
|
||||||
v.push_back(-(1.0/0.0)); // -inf
|
|
||||||
for (unsigned int i = 0; i < kLoop; i++) {
|
|
||||||
v.push_back(drand48());
|
|
||||||
v.push_back(-drand48());
|
|
||||||
}
|
|
||||||
for (unsigned int i = 0; i < v.size() ; i++) {
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
double 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);
|
|
||||||
double val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
|
|
||||||
if (isnan(val1))
|
|
||||||
EXPECT_TRUE(isnan(val2));
|
|
||||||
else if (isinf(val1))
|
|
||||||
EXPECT_TRUE(isinf(val2));
|
|
||||||
else
|
|
||||||
EXPECT_TRUE(fabs(val2 - val1) <= kEPS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_true)
|
|
||||||
{
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
bool val1 = true;
|
|
||||||
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);
|
|
||||||
bool val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1, val2);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, simple_buffer_false)
|
|
||||||
{
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
bool val1 = false;
|
|
||||||
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);
|
|
||||||
bool val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1, val2);
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_string)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
string val1;
|
|
||||||
for (unsigned int i = 0; i < kElements; i++)
|
|
||||||
val1 += 'a' + rand() % 26;
|
|
||||||
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);
|
|
||||||
string val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_EQ(val1, val2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_vector)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
vector<int> val1;
|
|
||||||
for (unsigned int i = 0; i < kElements; i++)
|
|
||||||
val1.push_back(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);
|
|
||||||
vector<int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_TRUE(equal(val1.begin(), val1.end(), val2.begin()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_map)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
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);
|
|
||||||
map<int, int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_TRUE(equal(val1.begin(), val1.end(), val2.begin()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_deque)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
deque<int> val1;
|
|
||||||
for (unsigned int i = 0; i < kElements; i++)
|
|
||||||
val1.push_back(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);
|
|
||||||
deque<int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_TRUE(equal(val1.begin(), val1.end(), val2.begin()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_list)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
list<int> val1;
|
|
||||||
for (unsigned int i = 0; i < kElements; i++)
|
|
||||||
val1.push_back(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);
|
|
||||||
list<int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_TRUE(equal(val1.begin(), val1.end(), val2.begin()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_set)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
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);
|
|
||||||
set<int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.size(), val2.size());
|
|
||||||
EXPECT_TRUE(equal(val1.begin(), val1.end(), val2.begin()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_STL, simple_buffer_pair)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
pair<int, int> val1 = make_pair(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);
|
|
||||||
pair<int, int> val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.first, val2.first);
|
|
||||||
EXPECT_EQ(val1.second, val2.second);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestClass
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
TestClass() : i(0), s("kzk") {}
|
|
||||||
int i;
|
|
||||||
string s;
|
|
||||||
MSGPACK_DEFINE(i, s);
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_class)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
TestClass val1;
|
|
||||||
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);
|
|
||||||
TestClass val2;
|
|
||||||
val2.i = -1;
|
|
||||||
val2.s = "";
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.i, val2.i);
|
|
||||||
EXPECT_EQ(val1.s, val2.s);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestClass2
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
TestClass2() : i(0), s("kzk") {
|
|
||||||
for (unsigned int i = 0; i < kElements; i++)
|
|
||||||
v.push_back(rand());
|
|
||||||
}
|
|
||||||
int i;
|
|
||||||
string s;
|
|
||||||
vector<int> v;
|
|
||||||
MSGPACK_DEFINE(i, s, v);
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_class_old_to_new)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
TestClass val1;
|
|
||||||
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);
|
|
||||||
TestClass2 val2;
|
|
||||||
val2.i = -1;
|
|
||||||
val2.s = "";
|
|
||||||
val2.v = vector<int>();
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.i, val2.i);
|
|
||||||
EXPECT_EQ(val1.s, val2.s);
|
|
||||||
EXPECT_FALSE(val2.s.empty());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_class_new_to_old)
|
|
||||||
{
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) {
|
|
||||||
TestClass2 val1;
|
|
||||||
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);
|
|
||||||
TestClass val2;
|
|
||||||
val2.i = -1;
|
|
||||||
val2.s = "";
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.i, val2.i);
|
|
||||||
EXPECT_EQ(val1.s, val2.s);
|
|
||||||
EXPECT_FALSE(val2.s.empty());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestEnumMemberClass
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
TestEnumMemberClass()
|
|
||||||
: t1(STATE_A), t2(STATE_B), t3(STATE_C) {}
|
|
||||||
|
|
||||||
enum TestEnumType {
|
|
||||||
STATE_INVALID = 0,
|
|
||||||
STATE_A = 1,
|
|
||||||
STATE_B = 2,
|
|
||||||
STATE_C = 3
|
|
||||||
};
|
|
||||||
TestEnumType t1;
|
|
||||||
TestEnumType t2;
|
|
||||||
TestEnumType t3;
|
|
||||||
|
|
||||||
MSGPACK_DEFINE((int&)t1, (int&)t2, (int&)t3);
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_enum_member)
|
|
||||||
{
|
|
||||||
TestEnumMemberClass val1;
|
|
||||||
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);
|
|
||||||
TestEnumMemberClass val2;
|
|
||||||
val2.t1 = TestEnumMemberClass::STATE_INVALID;
|
|
||||||
val2.t2 = TestEnumMemberClass::STATE_INVALID;
|
|
||||||
val2.t3 = TestEnumMemberClass::STATE_INVALID;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.t1, val2.t1);
|
|
||||||
EXPECT_EQ(val1.t2, val2.t2);
|
|
||||||
EXPECT_EQ(val1.t3, val2.t3);
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestUnionMemberClass
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
TestUnionMemberClass() {}
|
|
||||||
TestUnionMemberClass(double f) {
|
|
||||||
is_double = true;
|
|
||||||
value.f = f;
|
|
||||||
}
|
|
||||||
TestUnionMemberClass(int i) {
|
|
||||||
is_double = false;
|
|
||||||
value.i = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
union {
|
|
||||||
double f;
|
|
||||||
int i;
|
|
||||||
} value;
|
|
||||||
bool is_double;
|
|
||||||
|
|
||||||
template <typename Packer>
|
|
||||||
void msgpack_pack(Packer& pk) const
|
|
||||||
{
|
|
||||||
if (is_double)
|
|
||||||
pk.pack(msgpack::type::tuple<bool, double>(true, value.f));
|
|
||||||
else
|
|
||||||
pk.pack(msgpack::type::tuple<bool, int>(false, value.i));
|
|
||||||
}
|
|
||||||
|
|
||||||
void msgpack_unpack(msgpack::object o)
|
|
||||||
{
|
|
||||||
msgpack::type::tuple<bool, msgpack::object> tuple;
|
|
||||||
o.convert(&tuple);
|
|
||||||
|
|
||||||
is_double = tuple.get<0>();
|
|
||||||
if (is_double)
|
|
||||||
tuple.get<1>().convert(&value.f);
|
|
||||||
else
|
|
||||||
tuple.get<1>().convert(&value.i);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(MSGPACK_USER_DEFINED, simple_buffer_union_member)
|
|
||||||
{
|
|
||||||
{
|
|
||||||
// double
|
|
||||||
TestUnionMemberClass val1(1.0);
|
|
||||||
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);
|
|
||||||
TestUnionMemberClass val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.is_double, val2.is_double);
|
|
||||||
EXPECT_TRUE(fabs(val1.value.f - val2.value.f) < kEPS);
|
|
||||||
}
|
|
||||||
{
|
|
||||||
// int
|
|
||||||
TestUnionMemberClass val1(1);
|
|
||||||
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);
|
|
||||||
TestUnionMemberClass val2;
|
|
||||||
obj.convert(&val2);
|
|
||||||
EXPECT_EQ(val1.is_double, val2.is_double);
|
|
||||||
EXPECT_EQ(val1.value.i, 1);
|
|
||||||
EXPECT_EQ(val1.value.i, val2.value.i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#define GEN_TEST_VREF(test_type) \
|
|
||||||
do { \
|
|
||||||
vector<test_type> v; \
|
|
||||||
v.push_back(0); \
|
|
||||||
for (unsigned int i = 0; i < v.size(); i++) { \
|
|
||||||
test_type val1 = v[i]; \
|
|
||||||
msgpack::vrefbuffer vbuf; \
|
|
||||||
msgpack::pack(vbuf, val1); \
|
|
||||||
msgpack::sbuffer sbuf; \
|
|
||||||
const struct iovec* cur = vbuf.vector(); \
|
|
||||||
const struct iovec* end = cur + vbuf.vector_size(); \
|
|
||||||
for(; cur != end; ++cur) \
|
|
||||||
sbuf.write((const char*)cur->iov_base, cur->iov_len); \
|
|
||||||
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); \
|
|
||||||
test_type val2; \
|
|
||||||
obj.convert(&val2); \
|
|
||||||
EXPECT_EQ(val1, val2); \
|
|
||||||
} \
|
|
||||||
} while(0);
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_unsigned_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(unsigned short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_unsigned_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(unsigned int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_unsigned_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(unsigned long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_unsigned_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(unsigned long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_uint8)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(uint8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_uint16)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(uint16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_uint32)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(uint32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_uint64)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(uint64_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_int8)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(int8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_int16)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(int16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_int32)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(int32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, vrefbuffer_int64)
|
|
||||||
{
|
|
||||||
GEN_TEST_VREF(int64_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#define GEN_TEST_STREAM(test_type) \
|
|
||||||
for (unsigned int k = 0; k < kLoop; k++) { \
|
|
||||||
msgpack::sbuffer sbuf; \
|
|
||||||
msgpack::packer<msgpack::sbuffer> pk(sbuf); \
|
|
||||||
typedef std::vector<test_type> vec_type; \
|
|
||||||
vec_type vec; \
|
|
||||||
for(unsigned int i = 0; i < rand() % kLoop; ++i) { \
|
|
||||||
vec_type::value_type r = rand(); \
|
|
||||||
vec.push_back(r); \
|
|
||||||
pk.pack(r); \
|
|
||||||
} \
|
|
||||||
msgpack::unpacker pac; \
|
|
||||||
vec_type::const_iterator it = vec.begin(); \
|
|
||||||
const char *p = sbuf.data(); \
|
|
||||||
const char * const pend = p + sbuf.size(); \
|
|
||||||
while (p < pend) { \
|
|
||||||
const size_t sz = std::min<size_t>(pend - p, rand() % 128); \
|
|
||||||
pac.reserve_buffer(sz); \
|
|
||||||
memcpy(pac.buffer(), p, sz); \
|
|
||||||
pac.buffer_consumed(sz); \
|
|
||||||
while (pac.execute()) { \
|
|
||||||
if (it == vec.end()) goto out; \
|
|
||||||
msgpack::object obj = pac.data(); \
|
|
||||||
msgpack::zone *life = pac.release_zone(); \
|
|
||||||
EXPECT_TRUE(life != NULL); \
|
|
||||||
pac.reset(); \
|
|
||||||
vec_type::value_type val; \
|
|
||||||
obj.convert(&val); \
|
|
||||||
EXPECT_EQ(*it, val); \
|
|
||||||
++it; \
|
|
||||||
delete life; \
|
|
||||||
} \
|
|
||||||
p += sz; \
|
|
||||||
} \
|
|
||||||
out: \
|
|
||||||
; \
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_unsigned_short)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(unsigned short);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_unsigned_int)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(unsigned int);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_unsigned_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(unsigned long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_unsigned_long_long)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(unsigned long long);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_uint8)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(uint8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_uint16)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(uint16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_uint32)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(uint32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_uint64)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(uint64_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_int8)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(int8_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_int16)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(int16_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_int32)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(int32_t);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MSGPACK, stream_int64)
|
|
||||||
{
|
|
||||||
GEN_TEST_STREAM(int64_t);
|
|
||||||
}
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
|
|
||||||
CXXFLAGS += -Wall -g -I. -I.. -O4
|
|
||||||
LDFLAGS +=
|
|
||||||
|
|
||||||
all: test
|
|
||||||
|
|
||||||
test: test.o unpack.o zone.o object.o pack.hpp unpack.hpp zone.hpp object.hpp
|
|
||||||
$(CXX) test.o unpack.o zone.o object.o $(CXXFLAGS) $(LDFLAGS) -o $@
|
|
||||||
|
|
||||||
15
cpp/type.hpp
15
cpp/type.hpp
@@ -1,15 +0,0 @@
|
|||||||
#include "msgpack/type/bool.hpp"
|
|
||||||
#include "msgpack/type/float.hpp"
|
|
||||||
#include "msgpack/type/int.hpp"
|
|
||||||
#include "msgpack/type/list.hpp"
|
|
||||||
#include "msgpack/type/deque.hpp"
|
|
||||||
#include "msgpack/type/map.hpp"
|
|
||||||
#include "msgpack/type/nil.hpp"
|
|
||||||
#include "msgpack/type/pair.hpp"
|
|
||||||
#include "msgpack/type/raw.hpp"
|
|
||||||
#include "msgpack/type/set.hpp"
|
|
||||||
#include "msgpack/type/string.hpp"
|
|
||||||
#include "msgpack/type/vector.hpp"
|
|
||||||
#include "msgpack/type/tuple.hpp"
|
|
||||||
#include "msgpack/type/define.hpp"
|
|
||||||
|
|
||||||
@@ -1,98 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_DEFINE_HPP__
|
|
||||||
#define MSGPACK_TYPE_DEFINE_HPP__
|
|
||||||
|
|
||||||
#define MSGPACK_DEFINE(...) \
|
|
||||||
template <typename Packer> \
|
|
||||||
void msgpack_pack(Packer& pk) const \
|
|
||||||
{ \
|
|
||||||
msgpack::type::make_define(__VA_ARGS__).msgpack_pack(pk); \
|
|
||||||
} \
|
|
||||||
void msgpack_unpack(msgpack::object o) \
|
|
||||||
{ \
|
|
||||||
msgpack::type::make_define(__VA_ARGS__).msgpack_unpack(o); \
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
namespace type {
|
|
||||||
|
|
||||||
|
|
||||||
<% GENERATION_LIMIT = 31 %>
|
|
||||||
template <typename A0 = void<%1.upto(GENERATION_LIMIT+1) {|i|%>, typename A<%=i%> = void<%}%>>
|
|
||||||
struct define;
|
|
||||||
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct define<> {
|
|
||||||
typedef define<> value_type;
|
|
||||||
typedef tuple<> tuple_type;
|
|
||||||
template <typename Packer>
|
|
||||||
void msgpack_pack(Packer& pk) const
|
|
||||||
{
|
|
||||||
pk.pack_array(1);
|
|
||||||
}
|
|
||||||
void msgpack_unpack(msgpack::object o)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
}
|
|
||||||
};
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
struct define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> {
|
|
||||||
typedef define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> value_type;
|
|
||||||
typedef tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> tuple_type;
|
|
||||||
define(A0& _a0<%1.upto(i) {|j|%>, A<%=j%>& _a<%=j%><%}%>) :
|
|
||||||
a0(_a0)<%1.upto(i) {|j|%>, a<%=j%>(_a<%=j%>)<%}%> {}
|
|
||||||
template <typename Packer>
|
|
||||||
void msgpack_pack(Packer& pk) const
|
|
||||||
{
|
|
||||||
pk.pack_array(<%=i+1%>);
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
pk.pack(a<%=j%>);<%}%>
|
|
||||||
}
|
|
||||||
void msgpack_unpack(msgpack::object o)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
const size_t size = o.via.array.size;
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
if(size <= <%=j%>) { return; } o.via.array.ptr[<%=j%>].convert(&a<%=j%>);<%}%>
|
|
||||||
}
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
A<%=j%>& a<%=j%>;<%}%>
|
|
||||||
};
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
inline define<> make_define()
|
|
||||||
{
|
|
||||||
return define<>();
|
|
||||||
}
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> make_define(A0& a0<%1.upto(i) {|j|%>, A<%=j%>& a<%=j%><%}%>)
|
|
||||||
{
|
|
||||||
return define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>(a0<%1.upto(i) {|j|%>, a<%=j%><%}%>);
|
|
||||||
}
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
} // namespace type
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* msgpack/type/define.hpp */
|
|
||||||
|
|
||||||
147
cpp/type/int.hpp
147
cpp/type/int.hpp
@@ -1,147 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_INT_HPP__
|
|
||||||
#define MSGPACK_TYPE_INT_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <limits>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
namespace type {
|
|
||||||
namespace detail {
|
|
||||||
template <typename T, bool Signed>
|
|
||||||
struct convert_integer_sign;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct convert_integer_sign<T, true> {
|
|
||||||
static inline T convert(object o) {
|
|
||||||
if(o.type == type::POSITIVE_INTEGER) {
|
|
||||||
if(o.via.u64 > (uint64_t)std::numeric_limits<T>::max())
|
|
||||||
{ throw type_error(); }
|
|
||||||
return o.via.u64;
|
|
||||||
} else if(o.type == type::NEGATIVE_INTEGER) {
|
|
||||||
if(o.via.i64 < (int64_t)std::numeric_limits<T>::min())
|
|
||||||
{ throw type_error(); }
|
|
||||||
return o.via.i64;
|
|
||||||
}
|
|
||||||
throw type_error();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct convert_integer_sign<T, false> {
|
|
||||||
static inline T convert(object o) {
|
|
||||||
if(o.type == type::POSITIVE_INTEGER) {
|
|
||||||
if(o.via.u64 > (uint64_t)std::numeric_limits<T>::max())
|
|
||||||
{ throw type_error(); }
|
|
||||||
return o.via.u64;
|
|
||||||
}
|
|
||||||
throw type_error();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
static inline T convert_integer(object o)
|
|
||||||
{
|
|
||||||
return detail::convert_integer_sign<T, std::numeric_limits<T>::is_signed>::convert(o);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace detail
|
|
||||||
} // namespace type
|
|
||||||
|
|
||||||
|
|
||||||
inline signed char& operator>> (object o, signed char& v)
|
|
||||||
{ v = type::detail::convert_integer<signed char>(o); return v; }
|
|
||||||
|
|
||||||
inline signed short& operator>> (object o, signed short& v)
|
|
||||||
{ v = type::detail::convert_integer<signed short>(o); return v; }
|
|
||||||
|
|
||||||
inline signed int& operator>> (object o, signed int& v)
|
|
||||||
{ v = type::detail::convert_integer<signed int>(o); return v; }
|
|
||||||
|
|
||||||
inline signed long& operator>> (object o, signed long& v)
|
|
||||||
{ v = type::detail::convert_integer<signed long>(o); return v; }
|
|
||||||
|
|
||||||
inline signed long long& operator>> (object o, signed long long& v)
|
|
||||||
{ v = type::detail::convert_integer<signed long long>(o); return v; }
|
|
||||||
|
|
||||||
|
|
||||||
inline unsigned char& operator>> (object o, unsigned char& v)
|
|
||||||
{ v = type::detail::convert_integer<unsigned char>(o); return v; }
|
|
||||||
|
|
||||||
inline unsigned short& operator>> (object o, unsigned short& v)
|
|
||||||
{ v = type::detail::convert_integer<unsigned short>(o); return v; }
|
|
||||||
|
|
||||||
inline unsigned int& operator>> (object o, unsigned int& v)
|
|
||||||
{ v = type::detail::convert_integer<unsigned int>(o); return v; }
|
|
||||||
|
|
||||||
inline unsigned long& operator>> (object o, unsigned long& v)
|
|
||||||
{ v = type::detail::convert_integer<unsigned long>(o); return v; }
|
|
||||||
|
|
||||||
inline unsigned long long& operator>> (object o, unsigned long long& v)
|
|
||||||
{ v = type::detail::convert_integer<unsigned long long>(o); return v; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const signed char& v)
|
|
||||||
{ o.pack_int8(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const signed short& v)
|
|
||||||
{ o.pack_short(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const signed int& v)
|
|
||||||
{ o.pack_int(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const signed long& v)
|
|
||||||
{ o.pack_long(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const signed long long& v)
|
|
||||||
{ o.pack_long_long(v); return o; }
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const unsigned char& v)
|
|
||||||
{ o.pack_uint8(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const unsigned short& v)
|
|
||||||
{ o.pack_unsigned_short(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const unsigned int& v)
|
|
||||||
{ o.pack_unsigned_int(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const unsigned long& v)
|
|
||||||
{ o.pack_unsigned_long(v); return o; }
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const unsigned long long& v)
|
|
||||||
{ o.pack_unsigned_long_long(v); return o; }
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/int.hpp */
|
|
||||||
|
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_LIST_HPP__
|
|
||||||
#define MSGPACK_TYPE_LIST_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <list>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline std::list<T>& operator>> (object o, std::list<T>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
v.resize(o.via.array.size);
|
|
||||||
object* p = o.via.array.ptr;
|
|
||||||
object* const pend = o.via.array.ptr + o.via.array.size;
|
|
||||||
typename std::list<T>::iterator it = v.begin();
|
|
||||||
for(; p < pend; ++p, ++it) {
|
|
||||||
p->convert(&*it);
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::list<T>& v)
|
|
||||||
{
|
|
||||||
o.pack_array(v.size());
|
|
||||||
for(typename std::list<T>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(*it);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/list.hpp */
|
|
||||||
|
|
||||||
139
cpp/type/map.hpp
139
cpp/type/map.hpp
@@ -1,139 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_MAP_HPP__
|
|
||||||
#define MSGPACK_TYPE_MAP_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <map>
|
|
||||||
#include <vector>
|
|
||||||
#include <algorithm>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
namespace type {
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
class assoc_vector : public std::vector< std::pair<K, V> > {};
|
|
||||||
|
|
||||||
namespace detail {
|
|
||||||
template <typename K, typename V>
|
|
||||||
struct pair_first_less {
|
|
||||||
bool operator() (const std::pair<K, V>& x, const std::pair<K, V>& y) const
|
|
||||||
{ return x.first < y.first; }
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
} //namespace type
|
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
inline type::assoc_vector<K,V>& operator>> (object o, type::assoc_vector<K,V>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
|
||||||
v.resize(o.via.map.size);
|
|
||||||
object_kv* p = o.via.map.ptr;
|
|
||||||
object_kv* const pend = o.via.map.ptr + o.via.map.size;
|
|
||||||
std::pair<K, V>* it(&v.front());
|
|
||||||
for(; p < pend; ++p, ++it) {
|
|
||||||
p->key.convert(&it->first);
|
|
||||||
p->val.convert(&it->second);
|
|
||||||
}
|
|
||||||
std::sort(v.begin(), v.end(), type::detail::pair_first_less<K,V>());
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const type::assoc_vector<K,V>& v)
|
|
||||||
{
|
|
||||||
o.pack_map(v.size());
|
|
||||||
for(typename type::assoc_vector<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(it->first);
|
|
||||||
o.pack(it->second);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
inline std::map<K, V> operator>> (object o, std::map<K, V>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
|
||||||
object_kv* p(o.via.map.ptr);
|
|
||||||
object_kv* const pend(o.via.map.ptr + o.via.map.size);
|
|
||||||
for(; p != pend; ++p) {
|
|
||||||
K key;
|
|
||||||
p->key.convert(&key);
|
|
||||||
typename std::map<K,V>::iterator it(v.lower_bound(key));
|
|
||||||
if(it != v.end() && !(key < it->first)) {
|
|
||||||
p->val.convert(&it->second);
|
|
||||||
} else {
|
|
||||||
V val;
|
|
||||||
p->val.convert(&val);
|
|
||||||
v.insert(it, std::pair<K,V>(key, val));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::map<K,V>& v)
|
|
||||||
{
|
|
||||||
o.pack_map(v.size());
|
|
||||||
for(typename std::map<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(it->first);
|
|
||||||
o.pack(it->second);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
inline std::multimap<K, V> operator>> (object o, std::multimap<K, V>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
|
||||||
object_kv* p(o.via.map.ptr);
|
|
||||||
object_kv* const pend(o.via.map.ptr + o.via.map.size);
|
|
||||||
for(; p != pend; ++p) {
|
|
||||||
std::pair<K, V> value;
|
|
||||||
p->key.convert(&value.first);
|
|
||||||
p->val.convert(&value.second);
|
|
||||||
v.insert(value);
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::multimap<K,V>& v)
|
|
||||||
{
|
|
||||||
o.pack_map(v.size());
|
|
||||||
for(typename std::multimap<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(it->first);
|
|
||||||
o.pack(it->second);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/map.hpp */
|
|
||||||
|
|
||||||
@@ -1,84 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_RAW_HPP__
|
|
||||||
#define MSGPACK_TYPE_RAW_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <string.h>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
namespace type {
|
|
||||||
|
|
||||||
struct raw_ref {
|
|
||||||
raw_ref() : size(0), ptr(NULL) {}
|
|
||||||
raw_ref(const char* p, uint32_t s) : size(s), ptr(p) {}
|
|
||||||
|
|
||||||
uint32_t size;
|
|
||||||
const char* ptr;
|
|
||||||
|
|
||||||
std::string str() { return std::string(ptr, size); }
|
|
||||||
|
|
||||||
bool operator== (const raw_ref& x)
|
|
||||||
{
|
|
||||||
return size == x.size && memcmp(ptr, x.ptr, size) == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator!= (const raw_ref& x)
|
|
||||||
{
|
|
||||||
return !(*this != x);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator< (const raw_ref& x)
|
|
||||||
{
|
|
||||||
if(size == x.size) { return memcmp(ptr, x.ptr, size) < 0; }
|
|
||||||
else { return size < x.size; }
|
|
||||||
}
|
|
||||||
|
|
||||||
bool operator> (const raw_ref& x)
|
|
||||||
{
|
|
||||||
if(size == x.size) { return memcmp(ptr, x.ptr, size) > 0; }
|
|
||||||
else { return size > x.size; }
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace type
|
|
||||||
|
|
||||||
|
|
||||||
inline type::raw_ref& operator>> (object o, type::raw_ref& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::RAW) { throw type_error(); }
|
|
||||||
v.ptr = o.via.raw.ptr;
|
|
||||||
v.size = o.via.raw.size;
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const type::raw_ref& v)
|
|
||||||
{
|
|
||||||
o.pack_raw(v.size);
|
|
||||||
o.pack_raw_body(v.ptr, v.size);
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/raw.hpp */
|
|
||||||
|
|
||||||
@@ -1,80 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_SET_HPP__
|
|
||||||
#define MSGPACK_TYPE_SET_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <set>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline std::set<T>& operator>> (object o, std::set<T>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
|
||||||
object* const pbegin = o.via.array.ptr;
|
|
||||||
while(p > pbegin) {
|
|
||||||
--p;
|
|
||||||
v.insert(p->as<T>());
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::set<T>& v)
|
|
||||||
{
|
|
||||||
o.pack_array(v.size());
|
|
||||||
for(typename std::set<T>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(*it);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline std::multiset<T>& operator>> (object o, std::multiset<T>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
|
||||||
object* const pbegin = o.via.array.ptr;
|
|
||||||
while(p > pbegin) {
|
|
||||||
--p;
|
|
||||||
v.insert(p->as<T>());
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::multiset<T>& v)
|
|
||||||
{
|
|
||||||
o.pack_array(v.size());
|
|
||||||
for(typename std::multiset<T>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(*it);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/set.hpp */
|
|
||||||
|
|
||||||
@@ -1,85 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_TR1_UNORDERED_MAP_HPP__
|
|
||||||
#define MSGPACK_TYPE_TR1_UNORDERED_MAP_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <tr1/unordered_map>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
inline std::tr1::unordered_map<K, V> operator>> (object o, std::tr1::unordered_map<K, V>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
|
||||||
object_kv* p(o.via.map.ptr);
|
|
||||||
object_kv* const pend(o.via.map.ptr + o.via.map.size);
|
|
||||||
for(; p != pend; ++p) {
|
|
||||||
K key;
|
|
||||||
p->key.convert(&key);
|
|
||||||
p->val.convert(&v[key]);
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_map<K,V>& v)
|
|
||||||
{
|
|
||||||
o.pack_map(v.size());
|
|
||||||
for(typename std::tr1::unordered_map<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(it->first);
|
|
||||||
o.pack(it->second);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename K, typename V>
|
|
||||||
inline std::tr1::unordered_multimap<K, V> operator>> (object o, std::tr1::unordered_multimap<K, V>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::MAP) { throw type_error(); }
|
|
||||||
object_kv* p(o.via.map.ptr);
|
|
||||||
object_kv* const pend(o.via.map.ptr + o.via.map.size);
|
|
||||||
for(; p != pend; ++p) {
|
|
||||||
std::pair<K, V> value;
|
|
||||||
p->key.convert(&value.first);
|
|
||||||
p->val.convert(&value.second);
|
|
||||||
v.insert(value);
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename K, typename V>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_multimap<K,V>& v)
|
|
||||||
{
|
|
||||||
o.pack_map(v.size());
|
|
||||||
for(typename std::tr1::unordered_multimap<K,V>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(it->first);
|
|
||||||
o.pack(it->second);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/map.hpp */
|
|
||||||
|
|
||||||
@@ -1,80 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_TR1_UNORDERED_SET_HPP__
|
|
||||||
#define MSGPACK_TYPE_TR1_UNORDERED_SET_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include <tr1/unordered_set>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline std::tr1::unordered_set<T>& operator>> (object o, std::tr1::unordered_set<T>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
|
||||||
object* const pbegin = o.via.array.ptr;
|
|
||||||
while(p > pbegin) {
|
|
||||||
--p;
|
|
||||||
v.insert(p->as<T>());
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_set<T>& v)
|
|
||||||
{
|
|
||||||
o.pack_array(v.size());
|
|
||||||
for(typename std::tr1::unordered_set<T>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(*it);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline std::tr1::unordered_multiset<T>& operator>> (object o, std::tr1::unordered_multiset<T>& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
object* p = o.via.array.ptr + o.via.array.size;
|
|
||||||
object* const pbegin = o.via.array.ptr;
|
|
||||||
while(p > pbegin) {
|
|
||||||
--p;
|
|
||||||
v.insert(p->as<T>());
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Stream, typename T>
|
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const std::tr1::unordered_multiset<T>& v)
|
|
||||||
{
|
|
||||||
o.pack_array(v.size());
|
|
||||||
for(typename std::tr1::unordered_multiset<T>::const_iterator it(v.begin()), it_end(v.end());
|
|
||||||
it != it_end; ++it) {
|
|
||||||
o.pack(*it);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/set.hpp */
|
|
||||||
|
|
||||||
@@ -1,171 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ static resolution routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_TYPE_TUPLE_HPP__
|
|
||||||
#define MSGPACK_TYPE_TUPLE_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
namespace type {
|
|
||||||
|
|
||||||
// FIXME operator==
|
|
||||||
// FIXME operator!=
|
|
||||||
<% GENERATION_LIMIT = 31 %>
|
|
||||||
|
|
||||||
template <typename A0 = void<%1.upto(GENERATION_LIMIT+1) {|i|%>, typename A<%=i%> = void<%}%>>
|
|
||||||
struct tuple;
|
|
||||||
|
|
||||||
template <typename Tuple, int N>
|
|
||||||
struct tuple_element;
|
|
||||||
|
|
||||||
template <typename Tuple, int N>
|
|
||||||
struct const_tuple_element;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct tuple_type {
|
|
||||||
typedef T type;
|
|
||||||
typedef T value_type;
|
|
||||||
typedef T& reference;
|
|
||||||
typedef const T& const_reference;
|
|
||||||
typedef const T& transparent_reference;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct tuple_type<T&> {
|
|
||||||
typedef T type;
|
|
||||||
typedef T& value_type;
|
|
||||||
typedef T& reference;
|
|
||||||
typedef const T& const_reference;
|
|
||||||
typedef T& transparent_reference;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct tuple_type<const T&> {
|
|
||||||
typedef T type;
|
|
||||||
typedef T& value_type;
|
|
||||||
typedef T& reference;
|
|
||||||
typedef const T& const_reference;
|
|
||||||
typedef const T& transparent_reference;
|
|
||||||
};
|
|
||||||
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
|
||||||
struct tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>> : tuple_type<A<%=j%>> {
|
|
||||||
tuple_element(tuple<A0<%1.upto(i) {|k|%>, A<%=k%> <%}%>>& x) : _x(x.a<%=j%>) {}
|
|
||||||
typename tuple_type<A<%=j%>>::reference get() { return _x; }
|
|
||||||
typename tuple_type<A<%=j%>>::const_reference get() const { return _x; }
|
|
||||||
private:
|
|
||||||
typename tuple_type<A<%=j%>>::reference _x;
|
|
||||||
};
|
|
||||||
<%}%>
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
|
||||||
struct const_tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>> : tuple_type<A<%=j%>> {
|
|
||||||
const_tuple_element(const tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>& x) : _x(x.a<%=j%>) {}
|
|
||||||
typename tuple_type<A<%=j%>>::const_reference get() const { return _x; }
|
|
||||||
private:
|
|
||||||
typename tuple_type<A<%=j%>>::const_reference _x;
|
|
||||||
};
|
|
||||||
<%}%>
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct tuple<> {
|
|
||||||
tuple() {}
|
|
||||||
tuple(object o) { o.convert(this); }
|
|
||||||
typedef tuple<> value_type;
|
|
||||||
};
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
struct tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> {
|
|
||||||
typedef tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> value_type;
|
|
||||||
tuple() {}
|
|
||||||
tuple(typename tuple_type<A0>::transparent_reference _a0<%1.upto(i) {|j|%>, typename tuple_type<A<%=j%>>::transparent_reference _a<%=j%><%}%>) :
|
|
||||||
a0(_a0)<%1.upto(i) {|j|%>, a<%=j%>(_a<%=j%>)<%}%> {}
|
|
||||||
tuple(object o) { o.convert(this); }
|
|
||||||
template <int N> typename tuple_element<value_type, N>::reference get()
|
|
||||||
{ return tuple_element<value_type, N>(*this).get(); }
|
|
||||||
template <int N> typename const_tuple_element<value_type, N>::const_reference get() const
|
|
||||||
{ return const_tuple_element<value_type, N>(*this).get(); }
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
A<%=j%> a<%=j%>;<%}%>
|
|
||||||
};
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
inline tuple<> make_tuple()
|
|
||||||
{
|
|
||||||
return tuple<>();
|
|
||||||
}
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> make_tuple(typename tuple_type<A0>::transparent_reference a0<%1.upto(i) {|j|%>, typename tuple_type<A<%=j%>>::transparent_reference a<%=j%><%}%>)
|
|
||||||
{
|
|
||||||
return tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>(a0<%1.upto(i) {|j|%>, a<%=j%><%}%>);
|
|
||||||
}
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
} // namespace type
|
|
||||||
|
|
||||||
|
|
||||||
inline type::tuple<>& operator>> (
|
|
||||||
object o,
|
|
||||||
type::tuple<>& v) {
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& operator>> (
|
|
||||||
object o,
|
|
||||||
type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
|
||||||
if(o.type != type::ARRAY) { throw type_error(); }
|
|
||||||
if(o.via.array.size < <%=i+1%>) { throw type_error(); }
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
o.via.array.ptr[<%=j%>].convert<A<%=j%>>(&v.template get<<%=j%>>());<%}%>
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
template <typename Stream>
|
|
||||||
const packer<Stream>& operator<< (
|
|
||||||
packer<Stream>& o,
|
|
||||||
const type::tuple<>& v) {
|
|
||||||
o.pack_array(0);
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename Stream, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
const packer<Stream>& operator<< (
|
|
||||||
packer<Stream>& o,
|
|
||||||
const type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
|
||||||
o.pack_array(<%=i+1%>);
|
|
||||||
<%0.upto(i) {|j|%>
|
|
||||||
o.pack(v.template get<<%=j%>>());<%}%>
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/type/tuple.hpp */
|
|
||||||
|
|
||||||
301
cpp/unpack.hpp
301
cpp/unpack.hpp
@@ -1,301 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ deserializing routine
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_UNPACK_HPP__
|
|
||||||
#define MSGPACK_UNPACK_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/unpack.h"
|
|
||||||
#include "msgpack/object.hpp"
|
|
||||||
#include "msgpack/zone.hpp"
|
|
||||||
#include <memory>
|
|
||||||
#include <stdexcept>
|
|
||||||
|
|
||||||
#ifndef MSGPACK_UNPACKER_DEFAULT_INITIAL_BUFFER_SIZE
|
|
||||||
#define MSGPACK_UNPACKER_DEFAULT_INITIAL_BUFFER_SIZE (32*1024)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
struct unpack_error : public std::runtime_error {
|
|
||||||
unpack_error(const std::string& msg) :
|
|
||||||
std::runtime_error(msg) { }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class unpacker : public msgpack_unpacker {
|
|
||||||
public:
|
|
||||||
unpacker(size_t init_buffer_size = MSGPACK_UNPACKER_DEFAULT_INITIAL_BUFFER_SIZE);
|
|
||||||
~unpacker();
|
|
||||||
|
|
||||||
public:
|
|
||||||
/*! 1. reserve buffer. at least `size' bytes of capacity will be ready */
|
|
||||||
void reserve_buffer(size_t size);
|
|
||||||
|
|
||||||
/*! 2. read data to the buffer() up to buffer_capacity() bytes */
|
|
||||||
char* buffer();
|
|
||||||
size_t buffer_capacity() const;
|
|
||||||
|
|
||||||
/*! 3. specify the number of bytes actually copied */
|
|
||||||
void buffer_consumed(size_t size);
|
|
||||||
|
|
||||||
/*! 4. repeat execute() until it retunrs false */
|
|
||||||
bool execute();
|
|
||||||
|
|
||||||
/*! 5.1. if execute() returns true, take out the parsed object */
|
|
||||||
object data();
|
|
||||||
|
|
||||||
/*! 5.2. the object is valid until the zone is deleted */
|
|
||||||
// Note that once release_zone() from unpacker, you must delete it
|
|
||||||
// otherwise the memrory will leak.
|
|
||||||
zone* release_zone();
|
|
||||||
|
|
||||||
/*! 5.2. this method is equivalence to `delete release_zone()` */
|
|
||||||
void reset_zone();
|
|
||||||
|
|
||||||
/*! 5.3. after release_zone(), re-initialize unpacker */
|
|
||||||
void reset();
|
|
||||||
|
|
||||||
/*! 6. check if the size of message doesn't exceed assumption. */
|
|
||||||
size_t message_size() const;
|
|
||||||
|
|
||||||
|
|
||||||
// Basic usage of the unpacker is as following:
|
|
||||||
//
|
|
||||||
// msgpack::unpacker pac;
|
|
||||||
//
|
|
||||||
// while( /* readable */ ) {
|
|
||||||
//
|
|
||||||
// // 1.
|
|
||||||
// pac.reserve(1024);
|
|
||||||
//
|
|
||||||
// // 2.
|
|
||||||
// ssize_t bytes =
|
|
||||||
// read(the_source, pac.buffer(), pac.buffer_capacity());
|
|
||||||
//
|
|
||||||
// // error handling ...
|
|
||||||
//
|
|
||||||
// // 3.
|
|
||||||
// pac.buffer_consumed(bytes);
|
|
||||||
//
|
|
||||||
// // 4.
|
|
||||||
// while(pac.execute()) {
|
|
||||||
// // 5.1
|
|
||||||
// object o = pac.data();
|
|
||||||
//
|
|
||||||
// // 5.2
|
|
||||||
// std::auto_ptr<msgpack::zone> olife( pac.release_zone() );
|
|
||||||
//
|
|
||||||
// // boost::shared_ptr is also usable:
|
|
||||||
// // boost::shared_ptr<msgpack::zone> olife( pac.release_zone() );
|
|
||||||
//
|
|
||||||
// // 5.3
|
|
||||||
// pac.reset();
|
|
||||||
//
|
|
||||||
// // do some with the object with the old zone.
|
|
||||||
// do_something(o, olife);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
|
|
||||||
public:
|
|
||||||
// These functions are usable when non-MessagePack message follows after
|
|
||||||
// MessagePack message.
|
|
||||||
size_t parsed_size() const;
|
|
||||||
|
|
||||||
/*! get address of the buffer that is not parsed */
|
|
||||||
char* nonparsed_buffer();
|
|
||||||
size_t nonparsed_size() const;
|
|
||||||
|
|
||||||
/*! skip specified size of non-parsed buffer, leaving the buffer */
|
|
||||||
// Note that the `size' argument must be smaller than nonparsed_size()
|
|
||||||
void skip_nonparsed_buffer(size_t size);
|
|
||||||
|
|
||||||
/*! remove unparsed buffer from unpacker */
|
|
||||||
// Note that reset() leaves non-parsed buffer.
|
|
||||||
void remove_nonparsed_buffer();
|
|
||||||
|
|
||||||
private:
|
|
||||||
typedef msgpack_unpacker base;
|
|
||||||
|
|
||||||
private:
|
|
||||||
unpacker(const unpacker&);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
UNPACK_SUCCESS = 2,
|
|
||||||
UNPACK_EXTRA_BYTES = 1,
|
|
||||||
UNPACK_CONTINUE = 0,
|
|
||||||
UNPACK_PARSE_ERROR = -1,
|
|
||||||
} unpack_return;
|
|
||||||
|
|
||||||
static unpack_return unpack(const char* data, size_t len, size_t* off,
|
|
||||||
zone* z, object* result);
|
|
||||||
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
static object unpack(const char* data, size_t len, zone& z, size_t* off = NULL);
|
|
||||||
|
|
||||||
|
|
||||||
inline unpacker::unpacker(size_t initial_buffer_size)
|
|
||||||
{
|
|
||||||
if(!msgpack_unpacker_init(this, initial_buffer_size)) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unpacker::~unpacker()
|
|
||||||
{
|
|
||||||
msgpack_unpacker_destroy(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void unpacker::reserve_buffer(size_t size)
|
|
||||||
{
|
|
||||||
if(!msgpack_unpacker_reserve_buffer(this, size)) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline char* unpacker::buffer()
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_buffer(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t unpacker::buffer_capacity() const
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_buffer_capacity(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void unpacker::buffer_consumed(size_t size)
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_buffer_consumed(this, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline bool unpacker::execute()
|
|
||||||
{
|
|
||||||
int ret = msgpack_unpacker_execute(this);
|
|
||||||
if(ret < 0) {
|
|
||||||
throw unpack_error("parse error");
|
|
||||||
} else if(ret == 0) {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline object unpacker::data()
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_data(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline zone* unpacker::release_zone()
|
|
||||||
{
|
|
||||||
if(!msgpack_unpacker_flush_zone(this)) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
|
|
||||||
zone* r = new zone();
|
|
||||||
|
|
||||||
msgpack_zone old = *base::z;
|
|
||||||
*base::z = *r;
|
|
||||||
*static_cast<msgpack_zone*>(r) = old;
|
|
||||||
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void unpacker::reset_zone()
|
|
||||||
{
|
|
||||||
msgpack_unpacker_reset_zone(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void unpacker::reset()
|
|
||||||
{
|
|
||||||
msgpack_unpacker_reset(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t unpacker::message_size() const
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_message_size(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline size_t unpacker::parsed_size() const
|
|
||||||
{
|
|
||||||
return msgpack_unpacker_parsed_size(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline char* unpacker::nonparsed_buffer()
|
|
||||||
{
|
|
||||||
return base::buffer + base::off;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t unpacker::nonparsed_size() const
|
|
||||||
{
|
|
||||||
return base::used - base::off;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void unpacker::skip_nonparsed_buffer(size_t size)
|
|
||||||
{
|
|
||||||
base::off += size;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void unpacker::remove_nonparsed_buffer()
|
|
||||||
{
|
|
||||||
base::used = base::off;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline unpack_return unpack(const char* data, size_t len, size_t* off,
|
|
||||||
zone* z, object* result)
|
|
||||||
{
|
|
||||||
return (unpack_return)msgpack_unpack(data, len, off,
|
|
||||||
z, reinterpret_cast<msgpack_object*>(result));
|
|
||||||
}
|
|
||||||
|
|
||||||
// obsolete
|
|
||||||
inline object unpack(const char* data, size_t len, zone& z, size_t* off)
|
|
||||||
{
|
|
||||||
object result;
|
|
||||||
|
|
||||||
switch( msgpack::unpack(data, len, off, &z, &result) ) {
|
|
||||||
case UNPACK_SUCCESS:
|
|
||||||
return result;
|
|
||||||
|
|
||||||
case UNPACK_EXTRA_BYTES:
|
|
||||||
if(off) {
|
|
||||||
return result;
|
|
||||||
} else {
|
|
||||||
throw unpack_error("extra bytes");
|
|
||||||
}
|
|
||||||
|
|
||||||
case UNPACK_CONTINUE:
|
|
||||||
throw unpack_error("insufficient bytes");
|
|
||||||
|
|
||||||
case UNPACK_PARSE_ERROR:
|
|
||||||
default:
|
|
||||||
throw unpack_error("parse error");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/unpack.hpp */
|
|
||||||
|
|
||||||
@@ -1,92 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ zero-copy buffer implementation
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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_VREFBUFFER_HPP__
|
|
||||||
#define MSGPACK_VREFBUFFER_HPP__
|
|
||||||
|
|
||||||
#include "msgpack/vrefbuffer.h"
|
|
||||||
#include <stdexcept>
|
|
||||||
|
|
||||||
namespace msgpack {
|
|
||||||
|
|
||||||
|
|
||||||
class vrefbuffer : public msgpack_vrefbuffer {
|
|
||||||
public:
|
|
||||||
vrefbuffer(size_t ref_size = MSGPACK_VREFBUFFER_REF_SIZE,
|
|
||||||
size_t chunk_size = MSGPACK_VREFBUFFER_CHUNK_SIZE)
|
|
||||||
{
|
|
||||||
msgpack_vrefbuffer_init(this, ref_size, chunk_size);
|
|
||||||
}
|
|
||||||
|
|
||||||
~vrefbuffer()
|
|
||||||
{
|
|
||||||
msgpack_vrefbuffer_destroy(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
void write(const char* buf, unsigned int len)
|
|
||||||
{
|
|
||||||
if(len < base::ref_size) {
|
|
||||||
append_copy(buf, len);
|
|
||||||
} else {
|
|
||||||
append_ref(buf, len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void append_ref(const char* buf, size_t len)
|
|
||||||
{
|
|
||||||
if(msgpack_vrefbuffer_append_ref(this, buf, len) < 0) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void append_copy(const char* buf, size_t len)
|
|
||||||
{
|
|
||||||
if(msgpack_vrefbuffer_append_copy(this, buf, len) < 0) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const struct iovec* vector() const
|
|
||||||
{
|
|
||||||
return msgpack_vrefbuffer_vec(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t vector_size() const
|
|
||||||
{
|
|
||||||
return msgpack_vrefbuffer_veclen(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
void migrate(vrefbuffer* to)
|
|
||||||
{
|
|
||||||
if(msgpack_vrefbuffer_migrate(this, to) < 0) {
|
|
||||||
throw std::bad_alloc();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
typedef msgpack_vrefbuffer base;
|
|
||||||
|
|
||||||
private:
|
|
||||||
vrefbuffer(const vrefbuffer&);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/vrefbuffer.hpp */
|
|
||||||
|
|
||||||
149
cpp/zone.hpp.erb
149
cpp/zone.hpp.erb
@@ -1,149 +0,0 @@
|
|||||||
//
|
|
||||||
// MessagePack for C++ memory pool
|
|
||||||
//
|
|
||||||
// Copyright (C) 2008-2009 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 "msgpack/object.hpp"
|
|
||||||
#include "msgpack/zone.h"
|
|
||||||
#include <cstdlib>
|
|
||||||
#include <memory>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
<% GENERATION_LIMIT = 15 %>
|
|
||||||
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();
|
|
||||||
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
T* allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>);
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
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);
|
|
||||||
}
|
|
||||||
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
<%0.upto(GENERATION_LIMIT) {|i|%>
|
|
||||||
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
|
||||||
T* zone::allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>)
|
|
||||||
{
|
|
||||||
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(<%=(1..i).map{|j|"a#{j}"}.join(', ')%>);
|
|
||||||
} catch (...) {
|
|
||||||
--base::finalizer_array.tail;
|
|
||||||
undo_malloc(sizeof(T));
|
|
||||||
throw;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
<%}%>
|
|
||||||
|
|
||||||
} // namespace msgpack
|
|
||||||
|
|
||||||
#endif /* msgpack/zone.hpp */
|
|
||||||
|
|
||||||
133
crosslang.cc
Normal file
133
crosslang.cc
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
//
|
||||||
|
// MessagePack cross-language test tool
|
||||||
|
//
|
||||||
|
// $ cd ../cpp && ./configure && make && make install
|
||||||
|
// or
|
||||||
|
// $ port install msgpack # MacPorts
|
||||||
|
//
|
||||||
|
// $ g++ -Wall crosslang.cc -lmsgpack
|
||||||
|
//
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
static int run(int infd, int outfd)
|
||||||
|
try {
|
||||||
|
msgpack::unpacker pac;
|
||||||
|
|
||||||
|
while(true) {
|
||||||
|
pac.reserve_buffer(32*1024);
|
||||||
|
|
||||||
|
ssize_t count =
|
||||||
|
read(infd, pac.buffer(), pac.buffer_capacity());
|
||||||
|
|
||||||
|
if(count <= 0) {
|
||||||
|
if(count == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if(errno == EAGAIN || errno == EINTR) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
pac.buffer_consumed(count);
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
while(pac.next(&result)) {
|
||||||
|
msgpack::sbuffer sbuf;
|
||||||
|
msgpack::pack(sbuf, result.get());
|
||||||
|
|
||||||
|
const char* p = sbuf.data();
|
||||||
|
const char* const pend = p + sbuf.size();
|
||||||
|
while(p < pend) {
|
||||||
|
ssize_t bytes = write(outfd, p, pend-p);
|
||||||
|
|
||||||
|
if(bytes <= 0) {
|
||||||
|
if(count == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if(errno == EAGAIN || errno == EINTR) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p += bytes;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
} catch (std::exception& e) {
|
||||||
|
std::cerr << e.what() << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void usage(const char* prog)
|
||||||
|
{
|
||||||
|
printf(
|
||||||
|
"Usage: %s [in-file] [out-file]\n"
|
||||||
|
"\n"
|
||||||
|
"This tool is for testing of MessagePack implementation.\n"
|
||||||
|
"This does following behavior:\n"
|
||||||
|
"\n"
|
||||||
|
" 1. Reads objects serialized by MessagePack from <in-file> (default: stdin)\n"
|
||||||
|
" 2. Re-serializes the objects using C++ implementation of MessagePack (Note that C++ implementation is considered valid)\n"
|
||||||
|
" 3. Writes the re-serialized objects into <out-file> (default: stdout)\n"
|
||||||
|
"\n"
|
||||||
|
, prog);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
int infd = 0;
|
||||||
|
int outfd = 1;
|
||||||
|
|
||||||
|
if(argc < 1 || argc > 3) {
|
||||||
|
usage(argv[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int i=1; i < argc; ++i) {
|
||||||
|
if(strlen(argv[i]) > 1 && argv[i][0] == '-') {
|
||||||
|
usage(argv[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(argc >= 2) {
|
||||||
|
const char* fname = argv[1];
|
||||||
|
if(strcmp(fname, "-") != 0) {
|
||||||
|
infd = open(fname, O_RDONLY);
|
||||||
|
if(infd < 0) {
|
||||||
|
perror("can't open input file");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(argc >= 3) {
|
||||||
|
const char* fname = argv[2];
|
||||||
|
if(strcmp(fname, "-") != 0) {
|
||||||
|
outfd = open(fname, O_WRONLY | O_CREAT| O_TRUNC, 0666);
|
||||||
|
if(outfd < 0) {
|
||||||
|
perror("can't open output file");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int code = run(infd, outfd);
|
||||||
|
|
||||||
|
close(infd);
|
||||||
|
close(outfd);
|
||||||
|
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
|
||||||
88
crosslang.rb
Normal file
88
crosslang.rb
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
#
|
||||||
|
# MessagePack cross-language test tool
|
||||||
|
#
|
||||||
|
# $ gem install msgpack
|
||||||
|
# or
|
||||||
|
# $ port install rb_msgpack # MacPorts
|
||||||
|
#
|
||||||
|
begin
|
||||||
|
require 'rubygems'
|
||||||
|
rescue LoadError
|
||||||
|
end
|
||||||
|
require 'msgpack'
|
||||||
|
|
||||||
|
def run(inio, outio)
|
||||||
|
pac = MessagePack::Unpacker.new(inio)
|
||||||
|
|
||||||
|
begin
|
||||||
|
pac.each {|obj|
|
||||||
|
outio.write MessagePack.pack(obj)
|
||||||
|
outio.flush
|
||||||
|
}
|
||||||
|
rescue EOFError
|
||||||
|
return 0
|
||||||
|
rescue
|
||||||
|
$stderr.puts $!
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
|
||||||
|
return 0
|
||||||
|
end
|
||||||
|
|
||||||
|
def usage
|
||||||
|
puts <<EOF
|
||||||
|
Usage: #{$0} [in-file] [out-file]
|
||||||
|
|
||||||
|
This tool is for testing of MessagePack implementation.
|
||||||
|
This does following behavior:
|
||||||
|
|
||||||
|
1. Reads objects serialized by MessagePack from <in-file> (default: stdin)
|
||||||
|
2. Re-serializes the objects using Ruby implementation of MessagePack (Note that Ruby implementation is considered valid)
|
||||||
|
3. Writes the re-serialized objects into <out-file> (default: stdout)
|
||||||
|
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
|
||||||
|
inio = $stdin
|
||||||
|
outio = $stdout
|
||||||
|
|
||||||
|
if ARGV.length > 2
|
||||||
|
usage
|
||||||
|
end
|
||||||
|
|
||||||
|
ARGV.each {|str|
|
||||||
|
if str.size > 1 && str[0] == ?-
|
||||||
|
usage
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
|
if fname = ARGV[0]
|
||||||
|
unless fname == "-"
|
||||||
|
begin
|
||||||
|
inio = File.open(fname)
|
||||||
|
rescue
|
||||||
|
puts "can't open output file: #{$!}"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if fname = ARGV[1]
|
||||||
|
unless fname == "-"
|
||||||
|
begin
|
||||||
|
outio = File.open(fname, "w")
|
||||||
|
rescue
|
||||||
|
puts "can't open output file: #{$!}"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
code = run(inio, outio)
|
||||||
|
|
||||||
|
inio.close
|
||||||
|
outio.close
|
||||||
|
|
||||||
|
exit code
|
||||||
|
|
||||||
158
erb/cpp03_define.hpp.erb
Normal file
158
erb/cpp03_define.hpp.erb
Normal file
@@ -0,0 +1,158 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2009 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_CPP03_DEFINE_HPP
|
||||||
|
#define MSGPACK_CPP03_DEFINE_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/adaptor/msgpack_tuple_fwd.hpp"
|
||||||
|
#include "msgpack/adaptor/int_fwd.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
|
||||||
|
#define MSGPACK_DEFINE(...) \
|
||||||
|
template <typename Packer> \
|
||||||
|
void msgpack_pack(Packer& pk) const \
|
||||||
|
{ \
|
||||||
|
msgpack::type::make_define(__VA_ARGS__).msgpack_pack(pk); \
|
||||||
|
} \
|
||||||
|
void msgpack_unpack(msgpack::object const& o) \
|
||||||
|
{ \
|
||||||
|
msgpack::type::make_define(__VA_ARGS__).msgpack_unpack(o); \
|
||||||
|
}\
|
||||||
|
template <typename MSGPACK_OBJECT> \
|
||||||
|
void msgpack_object(MSGPACK_OBJECT* o, msgpack::zone& z) const \
|
||||||
|
{ \
|
||||||
|
msgpack::type::make_define(__VA_ARGS__).msgpack_object(o, z); \
|
||||||
|
}
|
||||||
|
|
||||||
|
// MSGPACK_ADD_ENUM must be used in the global namespace.
|
||||||
|
#define MSGPACK_ADD_ENUM(enum) \
|
||||||
|
namespace msgpack { \
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) { \
|
||||||
|
inline msgpack::object const& operator>> (msgpack::object const& o, enum& v) \
|
||||||
|
{ \
|
||||||
|
int tmp; \
|
||||||
|
o >> tmp; \
|
||||||
|
v = static_cast<enum>(tmp); \
|
||||||
|
return o; \
|
||||||
|
} \
|
||||||
|
inline void operator<< (msgpack::object& o, const enum& v) \
|
||||||
|
{ \
|
||||||
|
o << static_cast<int>(v); \
|
||||||
|
} \
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, const enum& v) \
|
||||||
|
{ \
|
||||||
|
o << static_cast<int>(v); \
|
||||||
|
} \
|
||||||
|
namespace detail { \
|
||||||
|
template <typename Stream> \
|
||||||
|
struct packer_serializer<Stream, enum> { \
|
||||||
|
static msgpack::packer<Stream>& pack(msgpack::packer<Stream>& o, const enum& v) { \
|
||||||
|
return o << static_cast<int>(v); \
|
||||||
|
} \
|
||||||
|
}; \
|
||||||
|
} \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
namespace type {
|
||||||
|
|
||||||
|
|
||||||
|
<% GENERATION_LIMIT = 31 %>
|
||||||
|
template <typename A0 = void<%1.upto(GENERATION_LIMIT+1) {|i|%>, typename A<%=i%> = void<%}%>>
|
||||||
|
struct define;
|
||||||
|
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct define<> {
|
||||||
|
typedef define<> value_type;
|
||||||
|
typedef tuple<> tuple_type;
|
||||||
|
template <typename Packer>
|
||||||
|
void msgpack_pack(Packer& pk) const
|
||||||
|
{
|
||||||
|
pk.pack_array(0);
|
||||||
|
}
|
||||||
|
void msgpack_unpack(msgpack::object const& o)
|
||||||
|
{
|
||||||
|
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
|
||||||
|
}
|
||||||
|
void msgpack_object(msgpack::object* o, msgpack::zone&) const
|
||||||
|
{
|
||||||
|
o->type = msgpack::type::ARRAY;
|
||||||
|
o->via.array.ptr = nullptr;
|
||||||
|
o->via.array.size = 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
struct define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> {
|
||||||
|
typedef define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> value_type;
|
||||||
|
typedef tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> tuple_type;
|
||||||
|
define(A0& _a0<%1.upto(i) {|j|%>, A<%=j%>& _a<%=j%><%}%>) :
|
||||||
|
a0(_a0)<%1.upto(i) {|j|%>, a<%=j%>(_a<%=j%>)<%}%> {}
|
||||||
|
template <typename Packer>
|
||||||
|
void msgpack_pack(Packer& pk) const
|
||||||
|
{
|
||||||
|
pk.pack_array(<%=i+1%>);
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
pk.pack(a<%=j%>);<%}%>
|
||||||
|
}
|
||||||
|
void msgpack_unpack(msgpack::object const& o)
|
||||||
|
{
|
||||||
|
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
|
||||||
|
const size_t size = o.via.array.size;
|
||||||
|
if(size > 0) {
|
||||||
|
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
|
||||||
|
{
|
||||||
|
o->type = msgpack::type::ARRAY;
|
||||||
|
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*<%=i+1%>));
|
||||||
|
o->via.array.size = <%=i+1%>;
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
o->via.array.ptr[<%=j%>] = msgpack::object(a<%=j%>, z);<%}%>
|
||||||
|
}
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
A<%=j%>& a<%=j%>;<%}%>
|
||||||
|
};
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
inline define<> make_define()
|
||||||
|
{
|
||||||
|
return define<>();
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> make_define(A0& a0<%1.upto(i) {|j|%>, A<%=j%>& a<%=j%><%}%>)
|
||||||
|
{
|
||||||
|
return define<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>(a0<%1.upto(i) {|j|%>, a<%=j%><%}%>);
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // namespace type
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP03_DEFINE_HPP
|
||||||
216
erb/cpp03_msgpack_tuple.hpp.erb
Normal file
216
erb/cpp03_msgpack_tuple.hpp.erb
Normal file
@@ -0,0 +1,216 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2013 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_CPP03_MSGPACK_TUPLE_HPP
|
||||||
|
#define MSGPACK_CPP03_MSGPACK_TUPLE_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object.hpp"
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
namespace type {
|
||||||
|
|
||||||
|
// FIXME operator==
|
||||||
|
// FIXME operator!=
|
||||||
|
<% GENERATION_LIMIT = 31 %>
|
||||||
|
|
||||||
|
template <typename A0<%1.upto(GENERATION_LIMIT+1) {|i|%>, typename A<%=i%><%}%>>
|
||||||
|
struct tuple;
|
||||||
|
|
||||||
|
template <typename Tuple, int N>
|
||||||
|
struct tuple_element;
|
||||||
|
|
||||||
|
template <typename Tuple, int N>
|
||||||
|
struct const_tuple_element;
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct tuple_type {
|
||||||
|
typedef T type;
|
||||||
|
typedef T value_type;
|
||||||
|
typedef T& reference;
|
||||||
|
typedef const T& const_reference;
|
||||||
|
typedef const T& transparent_reference;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct tuple_type<T&> {
|
||||||
|
typedef T type;
|
||||||
|
typedef T& value_type;
|
||||||
|
typedef T& reference;
|
||||||
|
typedef const T& const_reference;
|
||||||
|
typedef T& transparent_reference;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct tuple_type<const T&> {
|
||||||
|
typedef T type;
|
||||||
|
typedef T& value_type;
|
||||||
|
typedef T& reference;
|
||||||
|
typedef const T& const_reference;
|
||||||
|
typedef const T& transparent_reference;
|
||||||
|
};
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
||||||
|
struct tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>> : tuple_type<A<%=j%>> {
|
||||||
|
tuple_element(tuple<A0<%1.upto(i) {|k|%>, A<%=k%> <%}%>>& x) : m_x(x.a<%=j%>) {}
|
||||||
|
typename tuple_type<A<%=j%>>::reference get() { return m_x; }
|
||||||
|
typename tuple_type<A<%=j%>>::const_reference get() const { return m_x; }
|
||||||
|
private:
|
||||||
|
typename tuple_type<A<%=j%>>::reference m_x;
|
||||||
|
};
|
||||||
|
<%}%>
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
||||||
|
struct const_tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>> : tuple_type<A<%=j%>> {
|
||||||
|
const_tuple_element(const tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>& x) : m_x(x.a<%=j%>) {}
|
||||||
|
typename tuple_type<A<%=j%>>::const_reference get() const { return m_x; }
|
||||||
|
private:
|
||||||
|
typename tuple_type<A<%=j%>>::const_reference m_x;
|
||||||
|
};
|
||||||
|
<%}%>
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct tuple<> {
|
||||||
|
tuple() {}
|
||||||
|
tuple(msgpack::object const& o) { o.convert(*this); }
|
||||||
|
typedef tuple<> value_type;
|
||||||
|
};
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
struct tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> {
|
||||||
|
typedef tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> value_type;
|
||||||
|
tuple() {}
|
||||||
|
tuple(typename tuple_type<A0>::transparent_reference _a0<%1.upto(i) {|j|%>, typename tuple_type<A<%=j%>>::transparent_reference _a<%=j%><%}%>) :
|
||||||
|
a0(_a0)<%1.upto(i) {|j|%>, a<%=j%>(_a<%=j%>)<%}%> {}
|
||||||
|
tuple(msgpack::object const& o) { o.convert(*this); }
|
||||||
|
template <int N> typename tuple_element<value_type, N>::reference get()
|
||||||
|
{ return tuple_element<value_type, N>(*this).get(); }
|
||||||
|
template <int N> typename const_tuple_element<value_type, N>::const_reference get() const
|
||||||
|
{ return const_tuple_element<value_type, N>(*this).get(); }
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
A<%=j%> a<%=j%>;<%}%>
|
||||||
|
};
|
||||||
|
|
||||||
|
template <int N, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline typename type::tuple_element<type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>, N>::reference get(type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& t)
|
||||||
|
{ return t.template get<N>(); }
|
||||||
|
template <int N, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline typename type::const_tuple_element<type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>, N>::const_reference get(type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> const& t)
|
||||||
|
{ return t.template get<N>(); }
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
inline tuple<> make_tuple()
|
||||||
|
{
|
||||||
|
return tuple<>();
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> make_tuple(typename tuple_type<A0>::transparent_reference a0<%1.upto(i) {|j|%>, typename tuple_type<A<%=j%>>::transparent_reference a<%=j%><%}%>)
|
||||||
|
{
|
||||||
|
return tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>(a0<%1.upto(i) {|j|%>, a<%=j%><%}%>);
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // namespace type
|
||||||
|
|
||||||
|
inline msgpack::object const& operator>> (
|
||||||
|
msgpack::object const& o,
|
||||||
|
type::tuple<>&) {
|
||||||
|
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline msgpack::object const& operator>> (
|
||||||
|
msgpack::object const& o,
|
||||||
|
type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
||||||
|
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
|
||||||
|
if(o.via.array.size < <%=i+1%>) { throw msgpack::type_error(); }
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
o.via.array.ptr[<%=j%>].convert<typename type::tuple_type<A<%=j%>>::type>(v.template get<<%=j%>>());<%}%>
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
inline const msgpack::packer<Stream>& operator<< (
|
||||||
|
msgpack::packer<Stream>& o,
|
||||||
|
const type::tuple<>&) {
|
||||||
|
o.pack_array(0);
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename Stream, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline const msgpack::packer<Stream>& operator<< (
|
||||||
|
msgpack::packer<Stream>& o,
|
||||||
|
const type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
||||||
|
o.pack_array(<%=i+1%>);
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
o.pack(v.template get<<%=j%>>());<%}%>
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
inline void operator<< (
|
||||||
|
msgpack::object::with_zone& o,
|
||||||
|
const type::tuple<>&) {
|
||||||
|
o.type = msgpack::type::ARRAY;
|
||||||
|
o.via.array.ptr = nullptr;
|
||||||
|
o.via.array.size = 0;
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
inline void operator<< (
|
||||||
|
msgpack::object::with_zone& o,
|
||||||
|
const type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
||||||
|
o.type = msgpack::type::ARRAY;
|
||||||
|
o.via.array.ptr = static_cast<msgpack::object*>(o.zone.allocate_align(sizeof(msgpack::object)*<%=i+1%>));
|
||||||
|
o.via.array.size = <%=i+1%>;
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
o.via.array.ptr[<%=j%>] = msgpack::object(v.template get<<%=j%>>(), o.zone);<%}%>
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
|
||||||
|
//inline std::ostream& operator<< (std::ostream& o, const msgpack::type::tuple<>& v) {
|
||||||
|
// return o << "[]";
|
||||||
|
//}
|
||||||
|
//<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
//template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
//inline std::ostream& operator<< (std::ostream& o,
|
||||||
|
// const msgpack::type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v) {
|
||||||
|
// return o << "["
|
||||||
|
// <%0.upto(i) {|j|%>
|
||||||
|
// <<<%if j != 0 then%> ", " <<<%end%> v.template get<<%=j%>>()<%}%>
|
||||||
|
// << "]";
|
||||||
|
//}
|
||||||
|
//<%}%>
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP03_MSGPACK_TUPLE_HPP
|
||||||
125
erb/cpp03_msgpack_tuple_fwd.hpp.erb
Normal file
125
erb/cpp03_msgpack_tuple_fwd.hpp.erb
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2013 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_CPP03_MSGPACK_TUPLE_FWD_HPP
|
||||||
|
#define MSGPACK_CPP03_MSGPACK_TUPLE_FWD_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
namespace type {
|
||||||
|
|
||||||
|
// FIXME operator==
|
||||||
|
// FIXME operator!=
|
||||||
|
<% GENERATION_LIMIT = 31 %>
|
||||||
|
|
||||||
|
template <typename A0 = void<%1.upto(GENERATION_LIMIT+1) {|i|%>, typename A<%=i%> = void<%}%>>
|
||||||
|
struct tuple;
|
||||||
|
|
||||||
|
template <typename Tuple, int N>
|
||||||
|
struct tuple_element;
|
||||||
|
|
||||||
|
template <typename Tuple, int N>
|
||||||
|
struct const_tuple_element;
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct tuple_type;
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
||||||
|
struct tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>>;
|
||||||
|
<%}%>
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
<%0.upto(i) {|j|%>
|
||||||
|
template <typename A0<%1.upto(i) {|k|%>, typename A<%=k%><%}%>>
|
||||||
|
struct const_tuple_element<tuple<A0<%1.upto(i) {|k|%>, A<%=k%><%}%>>, <%=j%>>;
|
||||||
|
<%}%>
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct tuple<>;
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
struct tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>;
|
||||||
|
|
||||||
|
template <int N, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
typename type::tuple_element<type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>, N>::reference get(type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& t);
|
||||||
|
template <int N, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
typename type::const_tuple_element<type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>, N>::const_reference get(type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> const& t);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
tuple<> make_tuple();
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>> make_tuple(typename tuple_type<A0>::transparent_reference a0<%1.upto(i) {|j|%>, typename tuple_type<A<%=j%>>::transparent_reference a<%=j%><%}%>);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // namespace type
|
||||||
|
|
||||||
|
msgpack::object const& operator>> (
|
||||||
|
msgpack::object const& o,
|
||||||
|
type::tuple<>&);
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
msgpack::object const& operator>> (
|
||||||
|
msgpack::object const& o,
|
||||||
|
type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
const msgpack::packer<Stream>& operator<< (
|
||||||
|
msgpack::packer<Stream>& o,
|
||||||
|
const type::tuple<>&);
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename Stream, typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
const msgpack::packer<Stream>& operator<< (
|
||||||
|
msgpack::packer<Stream>& o,
|
||||||
|
const type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
void operator<< (
|
||||||
|
msgpack::object::with_zone& o,
|
||||||
|
const type::tuple<>&);
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
void operator<< (
|
||||||
|
msgpack::object::with_zone& o,
|
||||||
|
const type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
|
||||||
|
//std::ostream& operator<< (std::ostream& o, const msgpack::type::tuple<>& v);
|
||||||
|
//<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
//template <typename A0<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
//std::ostream& operator<< (std::ostream& o,
|
||||||
|
// const msgpack::type::tuple<A0<%1.upto(i) {|j|%>, A<%=j%><%}%>>& v);
|
||||||
|
//<%}%>
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP03_MSGPACK_TUPLE_FWD_HPP
|
||||||
332
erb/cpp03_zone.hpp.erb
Normal file
332
erb/cpp03_zone.hpp.erb
Normal file
@@ -0,0 +1,332 @@
|
|||||||
|
//
|
||||||
|
// 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_CPP03_ZONE_HPP
|
||||||
|
#define MSGPACK_CPP03_ZONE_HPP
|
||||||
|
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <memory>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
|
||||||
|
#ifndef MSGPACK_ZONE_CHUNK_SIZE
|
||||||
|
#define MSGPACK_ZONE_CHUNK_SIZE 8192
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MSGPACK_ZONE_ALIGN
|
||||||
|
#define MSGPACK_ZONE_ALIGN sizeof(void*)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
<% GENERATION_LIMIT = 15 %>
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
class zone {
|
||||||
|
struct finalizer {
|
||||||
|
finalizer(void (*func)(void*), void* data):m_func(func), m_data(data) {}
|
||||||
|
void operator()() { m_func(m_data); }
|
||||||
|
void (*m_func)(void*);
|
||||||
|
void* m_data;
|
||||||
|
};
|
||||||
|
struct finalizer_array {
|
||||||
|
finalizer_array():m_tail(nullptr), m_end(nullptr), m_array(nullptr) {}
|
||||||
|
void call() {
|
||||||
|
finalizer* fin = m_tail;
|
||||||
|
for(; fin != m_array; --fin) (*(fin-1))();
|
||||||
|
}
|
||||||
|
~finalizer_array() {
|
||||||
|
call();
|
||||||
|
::free(m_array);
|
||||||
|
}
|
||||||
|
void clear() {
|
||||||
|
call();
|
||||||
|
m_tail = m_array;
|
||||||
|
}
|
||||||
|
void push(void (*func)(void* data), void* data)
|
||||||
|
{
|
||||||
|
finalizer* fin = m_tail;
|
||||||
|
|
||||||
|
if(fin == m_end) {
|
||||||
|
push_expand(func, data);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
fin->m_func = func;
|
||||||
|
fin->m_data = data;
|
||||||
|
|
||||||
|
++m_tail;
|
||||||
|
}
|
||||||
|
void push_expand(void (*func)(void*), void* data) {
|
||||||
|
const size_t nused = m_end - m_array;
|
||||||
|
size_t nnext;
|
||||||
|
if(nused == 0) {
|
||||||
|
nnext = (sizeof(finalizer) < 72/2) ?
|
||||||
|
72 / sizeof(finalizer) : 8;
|
||||||
|
} else {
|
||||||
|
nnext = nused * 2;
|
||||||
|
}
|
||||||
|
finalizer* tmp =
|
||||||
|
static_cast<finalizer*>(::realloc(m_array, sizeof(finalizer) * nnext));
|
||||||
|
if(!tmp) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
m_array = tmp;
|
||||||
|
m_end = tmp + nnext;
|
||||||
|
m_tail = tmp + nused;
|
||||||
|
new (m_tail) finalizer(func, data);
|
||||||
|
|
||||||
|
++m_tail;
|
||||||
|
}
|
||||||
|
finalizer* m_tail;
|
||||||
|
finalizer* m_end;
|
||||||
|
finalizer* m_array;
|
||||||
|
};
|
||||||
|
struct chunk {
|
||||||
|
chunk* m_next;
|
||||||
|
};
|
||||||
|
struct chunk_list {
|
||||||
|
chunk_list(size_t chunk_size)
|
||||||
|
{
|
||||||
|
chunk* c = static_cast<chunk*>(::malloc(sizeof(chunk) + chunk_size));
|
||||||
|
if(!c) {
|
||||||
|
throw std::bad_alloc();
|
||||||
|
}
|
||||||
|
|
||||||
|
m_head = c;
|
||||||
|
m_free = chunk_size;
|
||||||
|
m_ptr = reinterpret_cast<char*>(c) + sizeof(chunk);
|
||||||
|
c->m_next = nullptr;
|
||||||
|
}
|
||||||
|
~chunk_list()
|
||||||
|
{
|
||||||
|
chunk* c = m_head;
|
||||||
|
while(c) {
|
||||||
|
chunk* n = c->m_next;
|
||||||
|
::free(c);
|
||||||
|
c = n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void clear(size_t chunk_size)
|
||||||
|
{
|
||||||
|
chunk* c = m_head;
|
||||||
|
while(true) {
|
||||||
|
chunk* n = c->m_next;
|
||||||
|
if(n) {
|
||||||
|
::free(c);
|
||||||
|
c = n;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m_head->m_next = nullptr;
|
||||||
|
m_free = chunk_size;
|
||||||
|
m_ptr = reinterpret_cast<char*>(m_head) + sizeof(chunk);
|
||||||
|
}
|
||||||
|
size_t m_free;
|
||||||
|
char* m_ptr;
|
||||||
|
chunk* m_head;
|
||||||
|
};
|
||||||
|
size_t m_chunk_size;
|
||||||
|
chunk_list m_chunk_list;
|
||||||
|
finalizer_array m_finalizer_array;
|
||||||
|
|
||||||
|
public:
|
||||||
|
zone(size_t chunk_size = MSGPACK_ZONE_CHUNK_SIZE) /* throw() */;
|
||||||
|
|
||||||
|
public:
|
||||||
|
void* allocate_align(size_t size, size_t align = MSGPACK_ZONE_ALIGN);
|
||||||
|
void* allocate_no_align(size_t size);
|
||||||
|
|
||||||
|
void push_finalizer(void (*func)(void*), void* data);
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void push_finalizer(msgpack::unique_ptr<T> obj);
|
||||||
|
|
||||||
|
void clear();
|
||||||
|
|
||||||
|
void swap(zone& o);
|
||||||
|
static void* operator new(std::size_t size)
|
||||||
|
{
|
||||||
|
void* p = ::malloc(size);
|
||||||
|
if (!p) throw std::bad_alloc();
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
static void operator delete(void *p) /* throw() */
|
||||||
|
{
|
||||||
|
::free(p);
|
||||||
|
}
|
||||||
|
static void* operator new(std::size_t size, void* place) /* throw() */
|
||||||
|
{
|
||||||
|
return ::operator new(size, place);
|
||||||
|
}
|
||||||
|
static void operator delete(void* p, void* place) /* throw() */
|
||||||
|
{
|
||||||
|
::operator delete(p, place);
|
||||||
|
}
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
T* allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>);
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
private:
|
||||||
|
void undo_allocate(size_t size);
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static void object_destruct(void* obj);
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static void object_delete(void* obj);
|
||||||
|
|
||||||
|
void* allocate_expand(size_t size);
|
||||||
|
private:
|
||||||
|
zone(const zone&);
|
||||||
|
zone& operator=(const zone&);
|
||||||
|
};
|
||||||
|
|
||||||
|
inline zone::zone(size_t chunk_size) /* throw() */ :m_chunk_size(chunk_size), m_chunk_list(m_chunk_size)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void* zone::allocate_align(size_t size, size_t align)
|
||||||
|
{
|
||||||
|
char* aligned =
|
||||||
|
reinterpret_cast<char*>(
|
||||||
|
reinterpret_cast<size_t>(
|
||||||
|
(m_chunk_list.m_ptr + (align - 1))) / align * align);
|
||||||
|
size_t adjusted_size = size + (aligned - m_chunk_list.m_ptr);
|
||||||
|
if(m_chunk_list.m_free >= adjusted_size) {
|
||||||
|
m_chunk_list.m_free -= adjusted_size;
|
||||||
|
m_chunk_list.m_ptr += adjusted_size;
|
||||||
|
return aligned;
|
||||||
|
}
|
||||||
|
return reinterpret_cast<char*>(
|
||||||
|
reinterpret_cast<size_t>(
|
||||||
|
allocate_expand(size + (align - 1))) / align * align);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void* zone::allocate_no_align(size_t size)
|
||||||
|
{
|
||||||
|
if(m_chunk_list.m_free < size) {
|
||||||
|
return allocate_expand(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
char* ptr = m_chunk_list.m_ptr;
|
||||||
|
m_chunk_list.m_free -= size;
|
||||||
|
m_chunk_list.m_ptr += size;
|
||||||
|
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void* zone::allocate_expand(size_t size)
|
||||||
|
{
|
||||||
|
chunk_list* const cl = &m_chunk_list;
|
||||||
|
|
||||||
|
size_t sz = m_chunk_size;
|
||||||
|
|
||||||
|
while(sz < size) {
|
||||||
|
size_t tmp_sz = sz * 2;
|
||||||
|
if (tmp_sz <= sz) {
|
||||||
|
sz = size;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
sz = tmp_sz;
|
||||||
|
}
|
||||||
|
|
||||||
|
chunk* c = static_cast<chunk*>(::malloc(sizeof(chunk) + sz));
|
||||||
|
if (!c) throw std::bad_alloc();
|
||||||
|
|
||||||
|
char* ptr = reinterpret_cast<char*>(c) + sizeof(chunk);
|
||||||
|
|
||||||
|
c->m_next = cl->m_head;
|
||||||
|
cl->m_head = c;
|
||||||
|
cl->m_free = sz - size;
|
||||||
|
cl->m_ptr = ptr + size;
|
||||||
|
|
||||||
|
return ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::push_finalizer(void (*func)(void*), void* data)
|
||||||
|
{
|
||||||
|
m_finalizer_array.push(func, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline void zone::push_finalizer(msgpack::unique_ptr<T> obj)
|
||||||
|
{
|
||||||
|
m_finalizer_array.push(&zone::object_delete<T>, obj.release());
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::clear()
|
||||||
|
{
|
||||||
|
m_finalizer_array.clear();
|
||||||
|
m_chunk_list.clear(m_chunk_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::swap(zone& o)
|
||||||
|
{
|
||||||
|
using std::swap;
|
||||||
|
swap(m_chunk_size, o.m_chunk_size);
|
||||||
|
swap(m_chunk_list, o.m_chunk_list);
|
||||||
|
swap(m_finalizer_array, o.m_finalizer_array);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void zone::object_destruct(void* obj)
|
||||||
|
{
|
||||||
|
static_cast<T*>(obj)->~T();
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void zone::object_delete(void* obj)
|
||||||
|
{
|
||||||
|
delete static_cast<T*>(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void zone::undo_allocate(size_t size)
|
||||||
|
{
|
||||||
|
m_chunk_list.m_ptr -= size;
|
||||||
|
m_chunk_list.m_free += size;
|
||||||
|
}
|
||||||
|
|
||||||
|
<%0.upto(GENERATION_LIMIT) {|i|%>
|
||||||
|
template <typename T<%1.upto(i) {|j|%>, typename A<%=j%><%}%>>
|
||||||
|
T* zone::allocate(<%=(1..i).map{|j|"A#{j} a#{j}"}.join(', ')%>)
|
||||||
|
{
|
||||||
|
void* x = allocate_align(sizeof(T));
|
||||||
|
try {
|
||||||
|
m_finalizer_array.push(&zone::object_destruct<T>, x);
|
||||||
|
} catch (...) {
|
||||||
|
undo_allocate(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return new (x) T(<%=(1..i).map{|j|"a#{j}"}.join(', ')%>);
|
||||||
|
} catch (...) {
|
||||||
|
--m_finalizer_array.m_tail;
|
||||||
|
undo_allocate(sizeof(T));
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
<%}%>
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP03_ZONE_HPP
|
||||||
119
example/c/lib_buffer_unpack.c
Normal file
119
example/c/lib_buffer_unpack.c
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct receiver {
|
||||||
|
msgpack_sbuffer sbuf;
|
||||||
|
size_t rest;
|
||||||
|
} receiver;
|
||||||
|
|
||||||
|
receiver r;
|
||||||
|
|
||||||
|
void receiver_init(receiver *r) {
|
||||||
|
msgpack_packer pk;
|
||||||
|
|
||||||
|
msgpack_sbuffer_init(&r->sbuf);
|
||||||
|
msgpack_packer_init(&pk, &r->sbuf, msgpack_sbuffer_write);
|
||||||
|
/* 1st object */
|
||||||
|
msgpack_pack_array(&pk, 3);
|
||||||
|
msgpack_pack_int(&pk, 1);
|
||||||
|
msgpack_pack_true(&pk);
|
||||||
|
msgpack_pack_str(&pk, 7);
|
||||||
|
msgpack_pack_str_body(&pk, "example", 7);
|
||||||
|
/* 2nd object */
|
||||||
|
msgpack_pack_str(&pk, 6);
|
||||||
|
msgpack_pack_str_body(&pk, "second", 6);
|
||||||
|
/* 3rd object */
|
||||||
|
msgpack_pack_array(&pk, 2);
|
||||||
|
msgpack_pack_int(&pk, 42);
|
||||||
|
msgpack_pack_false(&pk);
|
||||||
|
r->rest = r->sbuf.size;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t receiver_recv(receiver *r, char* buf, size_t try_size) {
|
||||||
|
size_t off = r->sbuf.size - r->rest;
|
||||||
|
|
||||||
|
size_t actual_size = try_size;
|
||||||
|
if (actual_size > r->rest) actual_size = r->rest;
|
||||||
|
|
||||||
|
memcpy(buf, r->sbuf.data + off, actual_size);
|
||||||
|
r->rest -= actual_size;
|
||||||
|
|
||||||
|
return actual_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define EACH_RECV_SIZE 4
|
||||||
|
|
||||||
|
void unpack(receiver* r) {
|
||||||
|
/* buf is allocated by unpacker. */
|
||||||
|
msgpack_unpacker* unp = msgpack_unpacker_new(100);
|
||||||
|
msgpack_unpacked result;
|
||||||
|
msgpack_unpack_return ret;
|
||||||
|
char* buf;
|
||||||
|
size_t recv_len;
|
||||||
|
int recv_count = 0;
|
||||||
|
|
||||||
|
msgpack_unpacked_init(&result);
|
||||||
|
if (msgpack_unpacker_buffer_capacity(unp) < EACH_RECV_SIZE) {
|
||||||
|
bool expanded = msgpack_unpacker_reserve_buffer(unp, 100);
|
||||||
|
assert(expanded);
|
||||||
|
}
|
||||||
|
buf = msgpack_unpacker_buffer(unp);
|
||||||
|
|
||||||
|
recv_len = receiver_recv(r, buf, EACH_RECV_SIZE);
|
||||||
|
msgpack_unpacker_buffer_consumed(unp, recv_len);
|
||||||
|
|
||||||
|
|
||||||
|
while (recv_len > 0) {
|
||||||
|
int i = 0;
|
||||||
|
printf("receive count: %d %zd bytes received.:\n", recv_count++, recv_len);
|
||||||
|
ret = msgpack_unpacker_next(unp, &result);
|
||||||
|
while (ret == MSGPACK_UNPACK_SUCCESS) {
|
||||||
|
msgpack_object obj = result.data;
|
||||||
|
|
||||||
|
/* Use obj. */
|
||||||
|
printf("Object no %d:\n", i++);
|
||||||
|
msgpack_object_print(stdout, obj);
|
||||||
|
printf("\n");
|
||||||
|
/* If you want to allocate something on the zone, you can use zone. */
|
||||||
|
/* msgpack_zone* zone = result.zone; */
|
||||||
|
/* The lifetime of the obj and the zone, */
|
||||||
|
|
||||||
|
ret = msgpack_unpacker_next(unp, &result);
|
||||||
|
}
|
||||||
|
if (ret == MSGPACK_UNPACK_PARSE_ERROR) {
|
||||||
|
printf("The data in the buf is invalid format.\n");
|
||||||
|
msgpack_unpacked_destroy(&result);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (msgpack_unpacker_buffer_capacity(unp) < EACH_RECV_SIZE) {
|
||||||
|
bool expanded = msgpack_unpacker_reserve_buffer(unp, 100);
|
||||||
|
assert(expanded);
|
||||||
|
}
|
||||||
|
buf = msgpack_unpacker_buffer(unp);
|
||||||
|
recv_len = receiver_recv(r, buf, 4);
|
||||||
|
msgpack_unpacker_buffer_consumed(unp, recv_len);
|
||||||
|
}
|
||||||
|
msgpack_unpacked_destroy(&result);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
receiver r;
|
||||||
|
receiver_init(&r);
|
||||||
|
|
||||||
|
unpack(&r);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Output */
|
||||||
|
|
||||||
|
/*
|
||||||
|
Object no 1:
|
||||||
|
[1, true, "example"]
|
||||||
|
Object no 2:
|
||||||
|
"second"
|
||||||
|
Object no 3:
|
||||||
|
[42, false]
|
||||||
|
*/
|
||||||
38
example/c/simple.c
Normal file
38
example/c/simple.c
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
msgpack_sbuffer sbuf;
|
||||||
|
msgpack_packer pk;
|
||||||
|
msgpack_zone mempool;
|
||||||
|
msgpack_object deserialized;
|
||||||
|
|
||||||
|
/* msgpack::sbuffer is a simple buffer implementation. */
|
||||||
|
msgpack_sbuffer_init(&sbuf);
|
||||||
|
|
||||||
|
/* serialize values into the buffer using msgpack_sbuffer_write callback function. */
|
||||||
|
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
msgpack_pack_array(&pk, 3);
|
||||||
|
msgpack_pack_int(&pk, 1);
|
||||||
|
msgpack_pack_true(&pk);
|
||||||
|
msgpack_pack_str(&pk, 7);
|
||||||
|
msgpack_pack_str_body(&pk, "example", 7);
|
||||||
|
|
||||||
|
/* deserialize the buffer into msgpack_object instance. */
|
||||||
|
/* deserialized object is valid during the msgpack_zone instance alive. */
|
||||||
|
msgpack_zone_init(&mempool, 2048);
|
||||||
|
|
||||||
|
msgpack_unpack(sbuf.data, sbuf.size, NULL, &mempool, &deserialized);
|
||||||
|
|
||||||
|
/* print the deserialized object. */
|
||||||
|
msgpack_object_print(stdout, deserialized);
|
||||||
|
puts("");
|
||||||
|
|
||||||
|
msgpack_zone_destroy(&mempool);
|
||||||
|
msgpack_sbuffer_destroy(&sbuf);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
36
example/c/speed_test_uint32_array.c
Normal file
36
example/c/speed_test_uint32_array.c
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
#include <msgpack.h>
|
||||||
|
|
||||||
|
void test()
|
||||||
|
{
|
||||||
|
size_t size = 10000000;
|
||||||
|
msgpack_sbuffer buf;
|
||||||
|
msgpack_packer * pk;
|
||||||
|
size_t upk_pos = 0;
|
||||||
|
msgpack_unpacked msg;
|
||||||
|
|
||||||
|
msgpack_sbuffer_init(&buf);
|
||||||
|
|
||||||
|
pk = msgpack_packer_new(&buf, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
msgpack_pack_array(pk, size);
|
||||||
|
{
|
||||||
|
int idx = 0;
|
||||||
|
for (; idx < size; ++idx)
|
||||||
|
msgpack_pack_uint32(pk, 1);
|
||||||
|
}
|
||||||
|
msgpack_packer_free(pk);
|
||||||
|
|
||||||
|
msgpack_unpacked_init(&msg);
|
||||||
|
|
||||||
|
while (msgpack_unpack_next(&msg, buf.data, buf.size, &upk_pos)) {
|
||||||
|
}
|
||||||
|
|
||||||
|
msgpack_sbuffer_destroy(&buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
for (; i < 10; ++i) test();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
37
example/c/speed_test_uint64_array.c
Normal file
37
example/c/speed_test_uint64_array.c
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
#include <msgpack.h>
|
||||||
|
|
||||||
|
void test()
|
||||||
|
{
|
||||||
|
uint64_t test_u64 = 0xFFF0000000000001LL;
|
||||||
|
size_t size = 10000000;
|
||||||
|
msgpack_sbuffer buf;
|
||||||
|
msgpack_packer * pk;
|
||||||
|
size_t upk_pos = 0;
|
||||||
|
msgpack_unpacked msg;
|
||||||
|
|
||||||
|
msgpack_sbuffer_init(&buf);
|
||||||
|
|
||||||
|
pk = msgpack_packer_new(&buf, msgpack_sbuffer_write);
|
||||||
|
|
||||||
|
msgpack_pack_array(pk, size);
|
||||||
|
{
|
||||||
|
int idx = 0;
|
||||||
|
for (; idx < size; ++idx)
|
||||||
|
msgpack_pack_uint64(pk, test_u64);
|
||||||
|
}
|
||||||
|
msgpack_packer_free(pk);
|
||||||
|
|
||||||
|
msgpack_unpacked_init(&msg);
|
||||||
|
|
||||||
|
while (msgpack_unpack_next(&msg, buf.data, buf.size, &upk_pos)) {
|
||||||
|
}
|
||||||
|
|
||||||
|
msgpack_sbuffer_destroy(&buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
for (; i < 10; ++i) test();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
75
example/c/user_buffer_unpack.c
Normal file
75
example/c/user_buffer_unpack.c
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
#include <msgpack.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
void prepare(msgpack_sbuffer* sbuf) {
|
||||||
|
msgpack_packer pk;
|
||||||
|
|
||||||
|
msgpack_packer_init(&pk, sbuf, msgpack_sbuffer_write);
|
||||||
|
/* 1st object */
|
||||||
|
msgpack_pack_array(&pk, 3);
|
||||||
|
msgpack_pack_int(&pk, 1);
|
||||||
|
msgpack_pack_true(&pk);
|
||||||
|
msgpack_pack_str(&pk, 7);
|
||||||
|
msgpack_pack_str_body(&pk, "example", 7);
|
||||||
|
/* 2nd object */
|
||||||
|
msgpack_pack_str(&pk, 6);
|
||||||
|
msgpack_pack_str_body(&pk, "second", 6);
|
||||||
|
/* 3rd object */
|
||||||
|
msgpack_pack_array(&pk, 2);
|
||||||
|
msgpack_pack_int(&pk, 42);
|
||||||
|
msgpack_pack_false(&pk);
|
||||||
|
}
|
||||||
|
|
||||||
|
void unpack(char const* buf, size_t len) {
|
||||||
|
/* buf is allocated by client. */
|
||||||
|
msgpack_unpacked result;
|
||||||
|
size_t off = 0;
|
||||||
|
msgpack_unpack_return ret;
|
||||||
|
int i = 0;
|
||||||
|
msgpack_unpacked_init(&result);
|
||||||
|
ret = msgpack_unpack_next(&result, buf, len, &off);
|
||||||
|
while (ret == MSGPACK_UNPACK_SUCCESS) {
|
||||||
|
msgpack_object obj = result.data;
|
||||||
|
|
||||||
|
/* Use obj. */
|
||||||
|
printf("Object no %d:\n", i++);
|
||||||
|
msgpack_object_print(stdout, obj);
|
||||||
|
printf("\n");
|
||||||
|
/* If you want to allocate something on the zone, you can use zone. */
|
||||||
|
/* msgpack_zone* zone = result.zone; */
|
||||||
|
/* The lifetime of the obj and the zone, */
|
||||||
|
|
||||||
|
ret = msgpack_unpack_next(&result, buf, len, &off);
|
||||||
|
}
|
||||||
|
msgpack_unpacked_destroy(&result);
|
||||||
|
|
||||||
|
if (ret == MSGPACK_UNPACK_CONTINUE) {
|
||||||
|
printf("All msgpack_object in the buffer is consumed.\n");
|
||||||
|
}
|
||||||
|
else if (ret == MSGPACK_UNPACK_PARSE_ERROR) {
|
||||||
|
printf("The data in the buf is invalid format.\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void) {
|
||||||
|
msgpack_sbuffer sbuf;
|
||||||
|
msgpack_sbuffer_init(&sbuf);
|
||||||
|
|
||||||
|
prepare(&sbuf);
|
||||||
|
unpack(sbuf.data, sbuf.size);
|
||||||
|
|
||||||
|
msgpack_sbuffer_destroy(&sbuf);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Output */
|
||||||
|
|
||||||
|
/*
|
||||||
|
Object no 1:
|
||||||
|
[1, true, "example"]
|
||||||
|
Object no 2:
|
||||||
|
"second"
|
||||||
|
Object no 3:
|
||||||
|
[42, false]
|
||||||
|
*/
|
||||||
83
example/cpp03/class_intrusive.cpp
Normal file
83
example/cpp03/class_intrusive.cpp
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <iomanip>
|
||||||
|
#include <sstream>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
// msgpack.hpp is also ok
|
||||||
|
#include <msgpack_fwd.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
class my_class {
|
||||||
|
public:
|
||||||
|
my_class() {} // When you want to convert from msgpack::object to my_class,
|
||||||
|
// my_class should be default constractible.
|
||||||
|
my_class(std::string const& name, int age):name_(name), age_(age) {}
|
||||||
|
|
||||||
|
friend bool operator==(my_class const& lhs, my_class const& rhs) {
|
||||||
|
return lhs.name_ == rhs.name_ && lhs.age_ == rhs.age_;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string name_;
|
||||||
|
int age_;
|
||||||
|
|
||||||
|
public:
|
||||||
|
MSGPACK_DEFINE(name_, age_);
|
||||||
|
};
|
||||||
|
|
||||||
|
void print(std::string const& buf) {
|
||||||
|
for (std::string::const_iterator it = buf.begin(), end = buf.end();
|
||||||
|
it != end;
|
||||||
|
++it) {
|
||||||
|
std::cout
|
||||||
|
<< std::setw(2)
|
||||||
|
<< std::hex
|
||||||
|
<< std::setfill('0')
|
||||||
|
<< (static_cast<int>(*it) & 0xff)
|
||||||
|
<< ' ';
|
||||||
|
}
|
||||||
|
std::cout << std::dec << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
{ // pack, unpack
|
||||||
|
my_class my("John Smith", 42);
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, my);
|
||||||
|
|
||||||
|
print(ss.str());
|
||||||
|
|
||||||
|
msgpack::unpacked unp;
|
||||||
|
msgpack::unpack(unp, ss.str().data(), ss.str().size());
|
||||||
|
msgpack::object obj = unp.get();
|
||||||
|
std::cout << obj << std::endl;
|
||||||
|
assert(obj.as<my_class>() == my);
|
||||||
|
}
|
||||||
|
{ // create object with zone
|
||||||
|
my_class my("John Smith", 42);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj(my, z);
|
||||||
|
std::cout << obj << std::endl;
|
||||||
|
assert(obj.as<my_class>() == my);
|
||||||
|
}
|
||||||
|
}
|
||||||
139
example/cpp03/class_non_intrusive.cpp
Normal file
139
example/cpp03/class_non_intrusive.cpp
Normal file
@@ -0,0 +1,139 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <iomanip>
|
||||||
|
#include <sstream>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
// msgpack.hpp should be included at after user declarations
|
||||||
|
#include <msgpack_fwd.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
// declarations
|
||||||
|
class my_class;
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS) {
|
||||||
|
|
||||||
|
object const& operator>> (msgpack::object const& o, my_class& v);
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
packer<Stream>& operator<< (msgpack::packer<Stream>& o, my_class const& v);
|
||||||
|
|
||||||
|
void operator<< (msgpack::object::with_zone& o, my_class const& v);
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS)
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
|
||||||
|
class my_class {
|
||||||
|
public:
|
||||||
|
my_class() {} // When you want to convert from msgpack::object to my_class,
|
||||||
|
// my_class should be default constractible.
|
||||||
|
my_class(std::string const& name, int age):name_(name), age_(age) {}
|
||||||
|
|
||||||
|
// my_class should provide getters for the data members you want to pack.
|
||||||
|
std::string const& get_name() const { return name_; }
|
||||||
|
int get_age() const { return age_; }
|
||||||
|
|
||||||
|
friend bool operator==(my_class const& lhs, my_class const& rhs) {
|
||||||
|
return lhs.name_ == rhs.name_ && lhs.age_ == rhs.age_;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string name_;
|
||||||
|
int age_;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// definitions
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS) {
|
||||||
|
|
||||||
|
inline object const& operator>> (msgpack::object const& o, my_class& v) {
|
||||||
|
if (o.type != msgpack::type::ARRAY) throw msgpack::type_error();
|
||||||
|
if (o.via.array.size != 2) throw msgpack::type_error();
|
||||||
|
v = my_class(
|
||||||
|
o.via.array.ptr[0].as<std::string>(),
|
||||||
|
o.via.array.ptr[1].as<int>());
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
inline packer<Stream>& operator<< (msgpack::packer<Stream>& o, my_class const& v) {
|
||||||
|
// packing member variables as an array.
|
||||||
|
o.pack_array(2);
|
||||||
|
o.pack(v.get_name());
|
||||||
|
o.pack(v.get_age());
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, my_class const& v) {
|
||||||
|
o.type = type::ARRAY;
|
||||||
|
o.via.array.size = 2;
|
||||||
|
o.via.array.ptr = static_cast<object*>(o.zone.allocate_align(sizeof(object) * o.via.array.size));
|
||||||
|
o.via.array.ptr[0] = msgpack::object(v.get_name(), o.zone);
|
||||||
|
o.via.array.ptr[1] = msgpack::object(v.get_age(), o.zone);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS)
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
|
||||||
|
void print(std::string const& buf) {
|
||||||
|
for (std::string::const_iterator it = buf.begin(), end = buf.end();
|
||||||
|
it != end;
|
||||||
|
++it) {
|
||||||
|
std::cout
|
||||||
|
<< std::setw(2)
|
||||||
|
<< std::hex
|
||||||
|
<< std::setfill('0')
|
||||||
|
<< (static_cast<int>(*it) & 0xff)
|
||||||
|
<< ' ';
|
||||||
|
}
|
||||||
|
std::cout << std::dec << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
{ // pack, unpack
|
||||||
|
my_class my("John Smith", 42);
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, my);
|
||||||
|
|
||||||
|
print(ss.str());
|
||||||
|
|
||||||
|
msgpack::unpacked unp;
|
||||||
|
msgpack::unpack(unp, ss.str().data(), ss.str().size());
|
||||||
|
msgpack::object obj = unp.get();
|
||||||
|
std::cout << obj << std::endl;
|
||||||
|
assert(obj.as<my_class>() == my);
|
||||||
|
}
|
||||||
|
{ // create object with zone
|
||||||
|
my_class my("John Smith", 42);
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object obj(my, z);
|
||||||
|
std::cout << obj << std::endl;
|
||||||
|
assert(obj.as<my_class>() == my);
|
||||||
|
}
|
||||||
|
}
|
||||||
75
example/cpp03/custom.cpp
Normal file
75
example/cpp03/custom.cpp
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <sstream>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
class old_class {
|
||||||
|
public:
|
||||||
|
old_class() : value("default") { }
|
||||||
|
|
||||||
|
std::string value;
|
||||||
|
|
||||||
|
MSGPACK_DEFINE(value);
|
||||||
|
};
|
||||||
|
|
||||||
|
class new_class {
|
||||||
|
public:
|
||||||
|
new_class() : value("default"), flag(-1) { }
|
||||||
|
|
||||||
|
std::string value;
|
||||||
|
int flag;
|
||||||
|
|
||||||
|
MSGPACK_DEFINE(value, flag);
|
||||||
|
};
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
{
|
||||||
|
old_class oc;
|
||||||
|
new_class nc;
|
||||||
|
|
||||||
|
std::stringstream sbuf;
|
||||||
|
msgpack::pack(sbuf, oc);
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
msgpack::unpack(result, sbuf.str().data(), sbuf.str().size());
|
||||||
|
msgpack::object obj = result.get();
|
||||||
|
|
||||||
|
obj.convert(&nc);
|
||||||
|
|
||||||
|
std::cout << obj << " value=" << nc.value << " flag=" << nc.flag << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
new_class nc;
|
||||||
|
old_class oc;
|
||||||
|
|
||||||
|
std::stringstream sbuf;
|
||||||
|
msgpack::pack(sbuf, nc);
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
msgpack::unpack(result, sbuf.str().data(), sbuf.str().size());
|
||||||
|
msgpack::object obj = result.get();
|
||||||
|
|
||||||
|
obj.convert(&oc);
|
||||||
|
|
||||||
|
std::cout << obj << " value=" << oc.value << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
68
example/cpp03/enum.cpp
Normal file
68
example/cpp03/enum.cpp
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <msgpack_fwd.hpp>
|
||||||
|
#include <sstream>
|
||||||
|
#include <iostream>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
enum my_enum {
|
||||||
|
elem1,
|
||||||
|
elem2,
|
||||||
|
elem3
|
||||||
|
};
|
||||||
|
|
||||||
|
MSGPACK_ADD_ENUM(my_enum);
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
{ // pack, unpack
|
||||||
|
std::stringstream sbuf;
|
||||||
|
msgpack::pack(sbuf, elem1);
|
||||||
|
msgpack::pack(sbuf, elem2);
|
||||||
|
my_enum e3 = elem3;
|
||||||
|
msgpack::pack(sbuf, e3);
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
std::size_t off = 0;
|
||||||
|
|
||||||
|
msgpack::unpack(result, sbuf.str().data(), sbuf.str().size(), off);
|
||||||
|
std::cout << result.get().as<my_enum>() << std::endl;
|
||||||
|
assert(result.get().as<my_enum>() == elem1);
|
||||||
|
|
||||||
|
msgpack::unpack(result, sbuf.str().data(), sbuf.str().size(), off);
|
||||||
|
std::cout << result.get().as<my_enum>() << std::endl;
|
||||||
|
assert(result.get().as<my_enum>() == elem2);
|
||||||
|
|
||||||
|
msgpack::unpack(result, sbuf.str().data(), sbuf.str().size(), off);
|
||||||
|
std::cout << result.get().as<my_enum>() << std::endl;
|
||||||
|
assert(result.get().as<my_enum>() == elem3);
|
||||||
|
}
|
||||||
|
{ // create object without zone
|
||||||
|
msgpack::object obj(elem2);
|
||||||
|
std::cout << obj.as<my_enum>() << std::endl;
|
||||||
|
assert(obj.as<my_enum>() == elem2);
|
||||||
|
}
|
||||||
|
{ // create object with zone
|
||||||
|
msgpack::zone z;
|
||||||
|
msgpack::object objz(elem3, z);
|
||||||
|
std::cout << objz.as<my_enum>() << std::endl;
|
||||||
|
assert(objz.as<my_enum>() == elem3);
|
||||||
|
}
|
||||||
|
}
|
||||||
103
example/cpp03/protocol.cpp
Normal file
103
example/cpp03/protocol.cpp
Normal file
@@ -0,0 +1,103 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
namespace myprotocol {
|
||||||
|
using namespace msgpack::type;
|
||||||
|
using msgpack::define;
|
||||||
|
|
||||||
|
struct Get : define< tuple<uint32_t, std::string> > {
|
||||||
|
Get() { }
|
||||||
|
Get(uint32_t f, const std::string& k) :
|
||||||
|
define_type(msgpack_type(f, k)) { }
|
||||||
|
uint32_t& flags() { return msgpack::type::get<0>(*this); }
|
||||||
|
std::string& key() { return msgpack::type::get<1>(*this); }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct Put : define< tuple<uint32_t, std::string, raw_ref> > {
|
||||||
|
Put() { }
|
||||||
|
Put(uint32_t f, const std::string& k, const char* valref, uint32_t vallen) :
|
||||||
|
define_type(msgpack_type( f, k, raw_ref(valref,vallen) )) { }
|
||||||
|
uint32_t& flags() { return msgpack::type::get<0>(*this); }
|
||||||
|
std::string& key() { return msgpack::type::get<1>(*this); }
|
||||||
|
raw_ref& value() { return msgpack::type::get<2>(*this); }
|
||||||
|
};
|
||||||
|
|
||||||
|
struct MultiGet : define< std::vector<Get> > {
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
// send Get request
|
||||||
|
std::stringstream stream;
|
||||||
|
{
|
||||||
|
myprotocol::Get req;
|
||||||
|
req.flags() = 0;
|
||||||
|
req.key() = "key0";
|
||||||
|
msgpack::pack(stream, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
stream.seekg(0);
|
||||||
|
|
||||||
|
// receive Get request
|
||||||
|
{
|
||||||
|
std::string buffer(stream.str());
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
msgpack::unpack(result, buffer.data(), buffer.size());
|
||||||
|
msgpack::object o = result.get();
|
||||||
|
|
||||||
|
myprotocol::Get req;
|
||||||
|
o.convert(req);
|
||||||
|
std::cout << "received: " << o << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
stream.str("");
|
||||||
|
|
||||||
|
|
||||||
|
// send MultiGet request
|
||||||
|
{
|
||||||
|
myprotocol::MultiGet req;
|
||||||
|
req.push_back( myprotocol::Get(1, "key1") );
|
||||||
|
req.push_back( myprotocol::Get(2, "key2") );
|
||||||
|
req.push_back( myprotocol::Get(3, "key3") );
|
||||||
|
msgpack::pack(stream, req);
|
||||||
|
}
|
||||||
|
|
||||||
|
stream.seekg(0);
|
||||||
|
|
||||||
|
// receive MultiGet request
|
||||||
|
{
|
||||||
|
std::string buffer(stream.str());
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
msgpack::unpack(result, buffer.data(), buffer.size());
|
||||||
|
msgpack::object o = result.get();
|
||||||
|
|
||||||
|
|
||||||
|
myprotocol::MultiGet req;
|
||||||
|
o.convert(req);
|
||||||
|
std::cout << "received: " << o << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
47
example/cpp03/reuse_zone.cpp
Normal file
47
example/cpp03/reuse_zone.cpp
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
std::vector<int> v;
|
||||||
|
v.push_back(1);
|
||||||
|
v.push_back(42);
|
||||||
|
std::string s("ABC");
|
||||||
|
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, v);
|
||||||
|
msgpack::pack(ss, s);
|
||||||
|
|
||||||
|
msgpack::zone z;
|
||||||
|
std::size_t offset = 0;
|
||||||
|
|
||||||
|
// msgpack array is constructed on z.
|
||||||
|
msgpack::object obj = msgpack::unpack(z, ss.str().data(), ss.str().size(), offset);
|
||||||
|
assert(obj.as<std::vector<int> >() == v);
|
||||||
|
|
||||||
|
// msgpack str is constructed on z.
|
||||||
|
assert(msgpack::unpack(z, ss.str().data(), ss.str().size(), offset).as<std::string>() == s);
|
||||||
|
}
|
||||||
54
example/cpp03/simple.cpp
Normal file
54
example/cpp03/simple.cpp
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
msgpack::type::tuple<int, bool, std::string> src(1, true, "example");
|
||||||
|
|
||||||
|
// serialize the object into the buffer.
|
||||||
|
// any classes that implements write(const char*,size_t) can be a buffer.
|
||||||
|
std::stringstream buffer;
|
||||||
|
msgpack::pack(buffer, src);
|
||||||
|
|
||||||
|
// send the buffer ...
|
||||||
|
buffer.seekg(0);
|
||||||
|
|
||||||
|
// deserialize the buffer into msgpack::object instance.
|
||||||
|
std::string str(buffer.str());
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
|
||||||
|
msgpack::unpack(result, str.data(), str.size());
|
||||||
|
|
||||||
|
// deserialized object is valid during the msgpack::unpacked instance alive.
|
||||||
|
msgpack::object deserialized = result.get();
|
||||||
|
|
||||||
|
// msgpack::object supports ostream.
|
||||||
|
std::cout << deserialized << std::endl;
|
||||||
|
|
||||||
|
// convert msgpack::object instance into the original type.
|
||||||
|
// if the type is mismatched, it throws msgpack::type_error exception.
|
||||||
|
msgpack::type::tuple<int, bool, std::string> dst;
|
||||||
|
deserialized.convert(&dst);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
71
example/cpp03/speed_test.cpp
Normal file
71
example/cpp03/speed_test.cpp
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2013-2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
// g++ -std=c++11 -O3 -g -Ipath_to_msgpack_src -Ipath_to_boost speed_test.cc -Lpath_to_boost_lib -lboost_timer -lboost_system
|
||||||
|
// export LD_LIBRARY_PATH=path_to_boost_lib
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
#include <map>
|
||||||
|
#include <boost/timer/timer.hpp>
|
||||||
|
|
||||||
|
void test_map_pack_unpack() {
|
||||||
|
std::cout << "[TEST][map_pack_unpack]" << std::endl;
|
||||||
|
// setup
|
||||||
|
std::cout << "Setting up map data..." << std::endl;
|
||||||
|
std::map<int, int> m1;
|
||||||
|
int const num = 30000000L;
|
||||||
|
for (int i = 0; i < num; ++i) m1[i] = i;
|
||||||
|
std::cout << "Start packing..." << std::endl;
|
||||||
|
std::stringstream buffer;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
msgpack::pack(buffer, m1);
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Pack finished..." << std::endl;
|
||||||
|
|
||||||
|
buffer.seekg(0);
|
||||||
|
std::string str(buffer.str());
|
||||||
|
|
||||||
|
msgpack::unpacked unpacked;
|
||||||
|
std::cout << "Start unpacking...by void unpack(unpacked& result, const char* data, size_t len)" << std::endl;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
msgpack::unpack(unpacked, str.data(), str.size());
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Unpack finished..." << std::endl;
|
||||||
|
std::map<int, int> m2;
|
||||||
|
std::cout << "Start converting..." << std::endl;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
unpacked.get().convert(&m2);
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Convert finished..." << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
test_map_pack_unpack();
|
||||||
|
}
|
||||||
94
example/cpp03/speed_test_nested_array.cpp
Normal file
94
example/cpp03/speed_test_nested_array.cpp
Normal file
@@ -0,0 +1,94 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2013-2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
// g++ -std=c++11 -O3 -g -Ipath_to_msgpack_src -Ipath_to_boost speed_test.cc -Lpath_to_boost_lib -lboost_timer -lboost_system
|
||||||
|
// export LD_LIBRARY_PATH=path_to_boost_lib
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
#include <vector>
|
||||||
|
#include <boost/timer/timer.hpp>
|
||||||
|
|
||||||
|
template <typename T, std::size_t level>
|
||||||
|
struct vecvec {
|
||||||
|
typedef std::vector<typename vecvec<T, level - 1>::type> type;
|
||||||
|
static void fill(type& v, std::size_t num_of_elems, T const& val) {
|
||||||
|
for (int elem = 0; elem < num_of_elems; ++elem) {
|
||||||
|
typename vecvec<T, level - 1>::type child;
|
||||||
|
vecvec<T, level - 1>::fill(child, num_of_elems, val);
|
||||||
|
v.push_back(child);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct vecvec<T, 0> {
|
||||||
|
typedef std::vector<T> type;
|
||||||
|
static void fill(type& v, std::size_t num_of_elems, T const& val) {
|
||||||
|
for (int elem = 0; elem < num_of_elems; ++elem) {
|
||||||
|
v.push_back(val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void test_array_of_array() {
|
||||||
|
std::cout << "[TEST][array_of_array]" << std::endl;
|
||||||
|
// setup
|
||||||
|
int const depth = 16;
|
||||||
|
std::cout << "Setting up array data..." << std::endl;
|
||||||
|
typename vecvec<int, depth>::type v1;
|
||||||
|
vecvec<int, depth>::fill(v1, 3, 42);
|
||||||
|
|
||||||
|
std::cout << "Start packing..." << std::endl;
|
||||||
|
std::stringstream buffer;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
msgpack::pack(buffer, v1);
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Pack finished..." << std::endl;
|
||||||
|
|
||||||
|
buffer.seekg(0);
|
||||||
|
std::string str(buffer.str());
|
||||||
|
|
||||||
|
msgpack::unpacked unpacked;
|
||||||
|
std::cout << "Start unpacking...by void unpack(unpacked& result, const char* data, size_t len)" << std::endl;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
msgpack::unpack(unpacked, str.data(), str.size());
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Unpack finished..." << std::endl;
|
||||||
|
typename vecvec<int, depth>::type v2;
|
||||||
|
std::cout << "Start converting..." << std::endl;
|
||||||
|
{
|
||||||
|
boost::timer::cpu_timer timer;
|
||||||
|
unpacked.get().convert(&v2);
|
||||||
|
std::string result = timer.format();
|
||||||
|
std::cout << result << std::endl;
|
||||||
|
}
|
||||||
|
std::cout << "Convert finished..." << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
test_array_of_array();
|
||||||
|
}
|
||||||
150
example/cpp03/stream.cpp
Normal file
150
example/cpp03/stream.cpp
Normal file
@@ -0,0 +1,150 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2015 FURUHASHI Sadayuki and KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include <stdexcept>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
|
class Server {
|
||||||
|
public:
|
||||||
|
Server(int sock) : m_sock(sock) { }
|
||||||
|
|
||||||
|
~Server() { }
|
||||||
|
|
||||||
|
typedef msgpack::unique_ptr<msgpack::zone> unique_zone;
|
||||||
|
|
||||||
|
void socket_readable()
|
||||||
|
{
|
||||||
|
m_pac.reserve_buffer(1024);
|
||||||
|
|
||||||
|
ssize_t count =
|
||||||
|
read(m_sock, m_pac.buffer(), m_pac.buffer_capacity());
|
||||||
|
|
||||||
|
if(count <= 0) {
|
||||||
|
if(count == 0) {
|
||||||
|
throw std::runtime_error("connection closed");
|
||||||
|
}
|
||||||
|
if(errno == EAGAIN || errno == EINTR) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
throw std::runtime_error(strerror(errno));
|
||||||
|
}
|
||||||
|
|
||||||
|
m_pac.buffer_consumed(count);
|
||||||
|
|
||||||
|
msgpack::unpacked result;
|
||||||
|
while (m_pac.next(&result)) {
|
||||||
|
msgpack::object msg = result.get();
|
||||||
|
unique_zone& life = result.zone();
|
||||||
|
process_message(msg, life);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(m_pac.message_size() > 10*1024*1024) {
|
||||||
|
throw std::runtime_error("message is too large");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
void process_message(msgpack::object msg, unique_zone&)
|
||||||
|
{
|
||||||
|
std::cout << "message reached: " << msg << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
int m_sock;
|
||||||
|
msgpack::unpacker m_pac;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
static void* run_server(void* arg)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
Server* srv = reinterpret_cast<Server*>(arg);
|
||||||
|
|
||||||
|
while(true) {
|
||||||
|
srv->socket_readable();
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
} catch (std::exception& e) {
|
||||||
|
std::cerr << "error while processing client packet: "
|
||||||
|
<< e.what() << std::endl;
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
} catch (...) {
|
||||||
|
std::cerr << "error while processing client packet: "
|
||||||
|
<< "unknown error" << std::endl;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct fwriter {
|
||||||
|
fwriter(int fd) : m_fp( fdopen(fd, "w") ) { }
|
||||||
|
|
||||||
|
void write(const char* buf, size_t buflen)
|
||||||
|
{
|
||||||
|
size_t count = fwrite(buf, buflen, 1, m_fp);
|
||||||
|
if(count < 1) {
|
||||||
|
std::cout << buflen << std::endl;
|
||||||
|
std::cout << count << std::endl;
|
||||||
|
throw std::runtime_error(strerror(errno));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void flush() { fflush(m_fp); }
|
||||||
|
|
||||||
|
void close() { fclose(m_fp); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
FILE* m_fp;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
int pair[2];
|
||||||
|
pipe(pair);
|
||||||
|
|
||||||
|
// run server thread
|
||||||
|
Server srv(pair[0]);
|
||||||
|
pthread_t thread;
|
||||||
|
pthread_create(&thread, NULL,
|
||||||
|
run_server, reinterpret_cast<void*>(&srv));
|
||||||
|
|
||||||
|
// client thread:
|
||||||
|
fwriter writer(pair[1]);
|
||||||
|
msgpack::packer<fwriter> pk(writer);
|
||||||
|
|
||||||
|
typedef msgpack::type::tuple<std::string, std::string, std::string> put_t;
|
||||||
|
typedef msgpack::type::tuple<std::string, std::string> get_t;
|
||||||
|
|
||||||
|
put_t req1("put", "apple", "red");
|
||||||
|
put_t req2("put", "lemon", "yellow");
|
||||||
|
get_t req3("get", "apple");
|
||||||
|
pk.pack(req1);
|
||||||
|
pk.pack(req2);
|
||||||
|
pk.pack(req3);
|
||||||
|
writer.flush();
|
||||||
|
writer.close();
|
||||||
|
|
||||||
|
pthread_join(thread, NULL);
|
||||||
|
}
|
||||||
108
example/cpp11/container.cpp
Normal file
108
example/cpp11/container.cpp
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
// MessagePack for C++ example
|
||||||
|
//
|
||||||
|
// Copyright (C) 2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
#include <tuple>
|
||||||
|
#include <unordered_map>
|
||||||
|
#include <unordered_set>
|
||||||
|
#include <forward_list>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include <msgpack.hpp>
|
||||||
|
|
||||||
|
void array() {
|
||||||
|
std::array<int, 5> a { 1, 2, 3, 4, 5 };
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, a);
|
||||||
|
|
||||||
|
msgpack::unpacked und = msgpack::unpack(ss.str().data(), ss.str().size());
|
||||||
|
msgpack::object obj = und.get();
|
||||||
|
std::array<int, 5> const& new_a = obj.as<std::array<int, 5>>();
|
||||||
|
|
||||||
|
assert(new_a == a);
|
||||||
|
}
|
||||||
|
|
||||||
|
void tuple() {
|
||||||
|
std::tuple<bool, std::string, int> t(true, "ABC", 42);
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, t);
|
||||||
|
|
||||||
|
auto und = msgpack::unpack(ss.str().data(), ss.str().size());
|
||||||
|
auto obj = und.get();
|
||||||
|
assert(obj.as<decltype(t)>() == t);
|
||||||
|
}
|
||||||
|
|
||||||
|
void unordered_map() {
|
||||||
|
std::unordered_map<std::string, int> m { {"ABC", 1}, {"DEF", 3} };
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, m);
|
||||||
|
|
||||||
|
auto und = msgpack::unpack(ss.str().data(), ss.str().size());
|
||||||
|
assert(und.get().as<decltype(m)>() == m);
|
||||||
|
}
|
||||||
|
|
||||||
|
void unordered_set() {
|
||||||
|
std::unordered_set<std::string> s { "ABC", "DEF" };
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, s);
|
||||||
|
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size()).get().as<decltype(s)>() == s);
|
||||||
|
}
|
||||||
|
|
||||||
|
void forward_list() {
|
||||||
|
using type = std::forward_list<std::string>;
|
||||||
|
type f { "ABC", "DEF" };
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, f);
|
||||||
|
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size()).get().as<type>() == f);
|
||||||
|
}
|
||||||
|
|
||||||
|
void combi() {
|
||||||
|
std::array<int, 5> a { 1, 2, 3, 4, 5 };
|
||||||
|
std::tuple<bool, std::string, int> t {true, "ABC", 42};
|
||||||
|
std::unordered_map<std::string, int> m { {"ABC", 1}, {"DEF", 3} };
|
||||||
|
std::unordered_set<std::string> s { "ABC", "DEF" };
|
||||||
|
std::forward_list<std::string> f { "ABC", "DEF" };
|
||||||
|
|
||||||
|
std::stringstream ss;
|
||||||
|
msgpack::pack(ss, a);
|
||||||
|
msgpack::pack(ss, t);
|
||||||
|
msgpack::pack(ss, m);
|
||||||
|
msgpack::pack(ss, s);
|
||||||
|
msgpack::pack(ss, f);
|
||||||
|
|
||||||
|
std::size_t offset = 0;
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size(), offset).get().as<decltype(a)>() == a);
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size(), offset).get().as<decltype(t)>() == t);
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size(), offset).get().as<decltype(m)>() == m);
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size(), offset).get().as<decltype(s)>() == s);
|
||||||
|
assert(msgpack::unpack(ss.str().data(), ss.str().size(), offset).get().as<decltype(f)>() == f);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
array();
|
||||||
|
tuple();
|
||||||
|
unordered_map();
|
||||||
|
unordered_set();
|
||||||
|
forward_list();
|
||||||
|
combi();
|
||||||
|
}
|
||||||
@@ -1,58 +0,0 @@
|
|||||||
#include <msgpack.hpp>
|
|
||||||
#include <string>
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
class old_class {
|
|
||||||
public:
|
|
||||||
old_class() : value("default") { }
|
|
||||||
|
|
||||||
std::string value;
|
|
||||||
|
|
||||||
MSGPACK_DEFINE(value);
|
|
||||||
};
|
|
||||||
|
|
||||||
class new_class {
|
|
||||||
public:
|
|
||||||
new_class() : value("default"), flag(-1) { }
|
|
||||||
|
|
||||||
std::string value;
|
|
||||||
int flag;
|
|
||||||
|
|
||||||
MSGPACK_DEFINE(value, flag);
|
|
||||||
};
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
{
|
|
||||||
old_class oc;
|
|
||||||
new_class nc;
|
|
||||||
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
msgpack::pack(sbuf, oc);
|
|
||||||
|
|
||||||
msgpack::zone zone;
|
|
||||||
msgpack::object obj;
|
|
||||||
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &zone, &obj);
|
|
||||||
|
|
||||||
obj.convert(&nc);
|
|
||||||
|
|
||||||
std::cout << obj << " value=" << nc.value << " flag=" << nc.flag << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
new_class nc;
|
|
||||||
old_class oc;
|
|
||||||
|
|
||||||
msgpack::sbuffer sbuf;
|
|
||||||
msgpack::pack(sbuf, nc);
|
|
||||||
|
|
||||||
msgpack::zone zone;
|
|
||||||
msgpack::object obj;
|
|
||||||
msgpack::unpack(sbuf.data(), sbuf.size(), NULL, &zone, &obj);
|
|
||||||
|
|
||||||
obj.convert(&oc);
|
|
||||||
|
|
||||||
std::cout << obj << " value=" << oc.value << std::endl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,86 +0,0 @@
|
|||||||
#include <msgpack.hpp>
|
|
||||||
#include <string>
|
|
||||||
#include <iostream>
|
|
||||||
#include <sstream>
|
|
||||||
|
|
||||||
namespace myprotocol {
|
|
||||||
using namespace msgpack::type;
|
|
||||||
using msgpack::define;
|
|
||||||
|
|
||||||
struct Get : define< tuple<uint32_t, std::string> > {
|
|
||||||
Get() { }
|
|
||||||
Get(uint32_t f, const std::string& k) :
|
|
||||||
define_type(msgpack_type(f, k)) { }
|
|
||||||
uint32_t& flags() { return get<0>(); }
|
|
||||||
std::string& key() { return get<1>(); }
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Put : define< tuple<uint32_t, std::string, raw_ref> > {
|
|
||||||
Put() { }
|
|
||||||
Put(uint32_t f, const std::string& k, const char* valref, size_t vallen) :
|
|
||||||
define_type(msgpack_type( f, k, raw_ref(valref,vallen) )) { }
|
|
||||||
uint32_t& flags() { return get<0>(); }
|
|
||||||
std::string& key() { return get<1>(); }
|
|
||||||
raw_ref& value() { return get<2>(); }
|
|
||||||
};
|
|
||||||
|
|
||||||
struct MultiGet : define< std::vector<Get> > {
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
// send Get request
|
|
||||||
std::stringstream stream;
|
|
||||||
{
|
|
||||||
myprotocol::Get req;
|
|
||||||
req.flags() = 0;
|
|
||||||
req.key() = "key0";
|
|
||||||
msgpack::pack(stream, req);
|
|
||||||
}
|
|
||||||
|
|
||||||
stream.seekg(0);
|
|
||||||
|
|
||||||
// receive Get request
|
|
||||||
{
|
|
||||||
std::string buffer(stream.str());
|
|
||||||
|
|
||||||
msgpack::zone mempool;
|
|
||||||
msgpack::object o =
|
|
||||||
msgpack::unpack(buffer.data(), buffer.size(), mempool);
|
|
||||||
|
|
||||||
myprotocol::Get req;
|
|
||||||
msgpack::convert(req, o);
|
|
||||||
std::cout << "received: " << o << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
stream.str("");
|
|
||||||
|
|
||||||
|
|
||||||
// send MultiGet request
|
|
||||||
{
|
|
||||||
myprotocol::MultiGet req;
|
|
||||||
req.push_back( myprotocol::Get(1, "key1") );
|
|
||||||
req.push_back( myprotocol::Get(2, "key2") );
|
|
||||||
req.push_back( myprotocol::Get(3, "key3") );
|
|
||||||
msgpack::pack(stream, req);
|
|
||||||
}
|
|
||||||
|
|
||||||
stream.seekg(0);
|
|
||||||
|
|
||||||
// receive MultiGet request
|
|
||||||
{
|
|
||||||
std::string buffer(stream.str());
|
|
||||||
|
|
||||||
msgpack::zone mempool;
|
|
||||||
msgpack::object o =
|
|
||||||
msgpack::unpack(buffer.data(), buffer.size(), mempool);
|
|
||||||
|
|
||||||
myprotocol::MultiGet req;
|
|
||||||
msgpack::convert(req, o);
|
|
||||||
std::cout << "received: " << o << std::endl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
#include <msgpack.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
/* msgpack::sbuffer is a simple buffer implementation. */
|
|
||||||
msgpack_sbuffer sbuf;
|
|
||||||
msgpack_sbuffer_init(&sbuf);
|
|
||||||
|
|
||||||
/* serialize values into the buffer using msgpack_sbuffer_write callback function. */
|
|
||||||
msgpack_packer pk;
|
|
||||||
msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
|
|
||||||
|
|
||||||
msgpack_pack_array(&pk, 3);
|
|
||||||
msgpack_pack_int(&pk, 1);
|
|
||||||
msgpack_pack_true(&pk);
|
|
||||||
msgpack_pack_raw(&pk, 7);
|
|
||||||
msgpack_pack_raw_body(&pk, "example", 7);
|
|
||||||
|
|
||||||
/* deserialize the buffer into msgpack_object instance. */
|
|
||||||
/* deserialized object is valid during the msgpack_zone instance alive. */
|
|
||||||
msgpack_zone mempool;
|
|
||||||
msgpack_zone_init(&mempool, 2048);
|
|
||||||
|
|
||||||
msgpack_object deserialized;
|
|
||||||
msgpack_unpack(sbuf.data, sbuf.size, NULL, &mempool, &deserialized);
|
|
||||||
|
|
||||||
/* print the deserialized object. */
|
|
||||||
msgpack_object_print(stdout, deserialized);
|
|
||||||
puts("");
|
|
||||||
|
|
||||||
msgpack_zone_destroy(&mempool);
|
|
||||||
msgpack_sbuffer_destroy(&sbuf);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
#include <msgpack.hpp>
|
|
||||||
#include <string>
|
|
||||||
#include <iostream>
|
|
||||||
#include <sstream>
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
msgpack::type::tuple<int, bool, std::string> src(1, true, "example");
|
|
||||||
|
|
||||||
// serialize the object into the buffer.
|
|
||||||
// any classes that implements write(const char*,size_t) can be a buffer.
|
|
||||||
std::stringstream buffer;
|
|
||||||
msgpack::pack(buffer, src);
|
|
||||||
|
|
||||||
// send the buffer ...
|
|
||||||
buffer.seekg(0);
|
|
||||||
|
|
||||||
// deserialize the buffer into msgpack::object instance.
|
|
||||||
std::string str(buffer.str());
|
|
||||||
|
|
||||||
// deserialized object is valid during the msgpack::zone instance alive.
|
|
||||||
msgpack::zone mempool;
|
|
||||||
|
|
||||||
msgpack::object deserialized;
|
|
||||||
msgpack::unpack(str.data(), str.size(), NULL, &mempool, &deserialized);
|
|
||||||
|
|
||||||
// msgpack::object supports ostream.
|
|
||||||
std::cout << deserialized << std::endl;
|
|
||||||
|
|
||||||
// convert msgpack::object instance into the original type.
|
|
||||||
// if the type is mismatched, it throws msgpack::type_error exception.
|
|
||||||
msgpack::type::tuple<int, bool, std::string> dst;
|
|
||||||
deserialized.convert(&dst);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
require 'msgpack'
|
|
||||||
|
|
||||||
serialized = [1, -1, true, false, nil, {"key" => "value"}].to_msgpack
|
|
||||||
p MessagePack.unpack(serialized)
|
|
||||||
|
|
||||||
@@ -1,136 +0,0 @@
|
|||||||
#include <msgpack.hpp>
|
|
||||||
#include <iostream>
|
|
||||||
#include <stdexcept>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <pthread.h>
|
|
||||||
|
|
||||||
class Server {
|
|
||||||
public:
|
|
||||||
Server(int sock) : m_sock(sock) { }
|
|
||||||
|
|
||||||
~Server() { }
|
|
||||||
|
|
||||||
typedef std::auto_ptr<msgpack::zone> auto_zone;
|
|
||||||
|
|
||||||
void socket_readable()
|
|
||||||
{
|
|
||||||
m_pac.reserve_buffer(1024);
|
|
||||||
|
|
||||||
ssize_t count =
|
|
||||||
read(m_sock, m_pac.buffer(), m_pac.buffer_capacity());
|
|
||||||
|
|
||||||
if(count <= 0) {
|
|
||||||
if(count == 0) {
|
|
||||||
throw std::runtime_error("connection closed");
|
|
||||||
}
|
|
||||||
if(errno == EAGAIN || errno == EINTR) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
throw std::runtime_error(strerror(errno));
|
|
||||||
}
|
|
||||||
|
|
||||||
m_pac.buffer_consumed(count);
|
|
||||||
|
|
||||||
while(m_pac.execute()) {
|
|
||||||
msgpack::object msg = m_pac.data();
|
|
||||||
|
|
||||||
auto_zone life( m_pac.release_zone() );
|
|
||||||
|
|
||||||
m_pac.reset();
|
|
||||||
|
|
||||||
process_message(msg, life);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(m_pac.message_size() > 10*1024*1024) {
|
|
||||||
throw std::runtime_error("message is too large");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
void process_message(msgpack::object msg, auto_zone& life)
|
|
||||||
{
|
|
||||||
std::cout << "message reached: " << msg << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
int m_sock;
|
|
||||||
msgpack::unpacker m_pac;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
static void* run_server(void* arg)
|
|
||||||
try {
|
|
||||||
Server* srv = reinterpret_cast<Server*>(arg);
|
|
||||||
|
|
||||||
while(true) {
|
|
||||||
srv->socket_readable();
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
} catch (std::exception& e) {
|
|
||||||
std::cerr << "error while processing client packet: "
|
|
||||||
<< e.what() << std::endl;
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
} catch (...) {
|
|
||||||
std::cerr << "error while processing client packet: "
|
|
||||||
<< "unknown error" << std::endl;
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
struct fwriter {
|
|
||||||
fwriter(int fd) : m_fp( fdopen(fd, "w") ) { }
|
|
||||||
|
|
||||||
void write(const char* buf, size_t buflen)
|
|
||||||
{
|
|
||||||
size_t count = fwrite(buf, buflen, 1, m_fp);
|
|
||||||
if(count < 1) {
|
|
||||||
std::cout << buflen << std::endl;
|
|
||||||
std::cout << count << std::endl;
|
|
||||||
throw std::runtime_error(strerror(errno));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void flush() { fflush(m_fp); }
|
|
||||||
|
|
||||||
void close() { fclose(m_fp); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
FILE* m_fp;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
int pair[2];
|
|
||||||
pipe(pair);
|
|
||||||
|
|
||||||
// run server thread
|
|
||||||
Server srv(pair[0]);
|
|
||||||
pthread_t thread;
|
|
||||||
pthread_create(&thread, NULL,
|
|
||||||
run_server, reinterpret_cast<void*>(&srv));
|
|
||||||
|
|
||||||
// client thread:
|
|
||||||
fwriter writer(pair[1]);
|
|
||||||
msgpack::packer<fwriter> pk(writer);
|
|
||||||
|
|
||||||
typedef msgpack::type::tuple<std::string, std::string, std::string> put_t;
|
|
||||||
typedef msgpack::type::tuple<std::string, std::string> get_t;
|
|
||||||
|
|
||||||
put_t req1("put", "apple", "red");
|
|
||||||
put_t req2("put", "lemon", "yellow");
|
|
||||||
get_t req3("get", "apple");
|
|
||||||
pk.pack(req1);
|
|
||||||
pk.pack(req2);
|
|
||||||
pk.pack(req3);
|
|
||||||
writer.flush();
|
|
||||||
writer.close();
|
|
||||||
|
|
||||||
pthread_join(thread, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,72 +0,0 @@
|
|||||||
require 'msgpack'
|
|
||||||
|
|
||||||
class Server
|
|
||||||
def initialize(sock)
|
|
||||||
@sock = sock
|
|
||||||
@pk = MessagePack::Unpacker.new
|
|
||||||
@buffer = ''
|
|
||||||
@nread = 0
|
|
||||||
end
|
|
||||||
|
|
||||||
def run
|
|
||||||
while true
|
|
||||||
begin
|
|
||||||
data = @sock.sysread(1024)
|
|
||||||
rescue
|
|
||||||
puts "connection closed (#{$!})"
|
|
||||||
return
|
|
||||||
end
|
|
||||||
receive_data(data)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
def receive_data(data)
|
|
||||||
@buffer << data
|
|
||||||
|
|
||||||
while true
|
|
||||||
@nread = @pk.execute(@buffer, @nread)
|
|
||||||
|
|
||||||
if @pk.finished?
|
|
||||||
msg = @pk.data
|
|
||||||
process_message(msg)
|
|
||||||
|
|
||||||
@pk.reset
|
|
||||||
@buffer.slice!(0, @nread)
|
|
||||||
@nread = 0
|
|
||||||
|
|
||||||
next unless @buffer.empty?
|
|
||||||
end
|
|
||||||
|
|
||||||
break
|
|
||||||
end
|
|
||||||
|
|
||||||
if @buffer.length > 10*1024*1024
|
|
||||||
raise "message is too large"
|
|
||||||
end
|
|
||||||
|
|
||||||
rescue
|
|
||||||
puts "error while processing client packet: #{$!}"
|
|
||||||
end
|
|
||||||
|
|
||||||
def process_message(msg)
|
|
||||||
puts "message reached: #{msg.inspect}"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
rpipe, wpipe = IO.pipe
|
|
||||||
|
|
||||||
# run server thread
|
|
||||||
thread = Thread.new(Server.new(rpipe)) {|srv|
|
|
||||||
srv.run
|
|
||||||
}
|
|
||||||
|
|
||||||
# client thread:
|
|
||||||
wpipe.write ["put", "apple", "red"].to_msgpack
|
|
||||||
wpipe.write ["put", "lemon", "yellow"].to_msgpack
|
|
||||||
wpipe.write ["get", "apple"].to_msgpack
|
|
||||||
wpipe.close
|
|
||||||
|
|
||||||
thread.join
|
|
||||||
|
|
||||||
@@ -15,9 +15,18 @@
|
|||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
/**
|
||||||
|
* @defgroup msgpack MessagePack C
|
||||||
|
* @{
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "msgpack/util.h"
|
||||||
#include "msgpack/object.h"
|
#include "msgpack/object.h"
|
||||||
#include "msgpack/zone.h"
|
#include "msgpack/zone.h"
|
||||||
#include "msgpack/pack.h"
|
#include "msgpack/pack.h"
|
||||||
#include "msgpack/unpack.h"
|
#include "msgpack/unpack.h"
|
||||||
#include "msgpack/sbuffer.h"
|
#include "msgpack/sbuffer.h"
|
||||||
#include "msgpack/vrefbuffer.h"
|
#include "msgpack/vrefbuffer.h"
|
||||||
|
#include "msgpack/version.h"
|
||||||
|
|
||||||
@@ -16,9 +16,10 @@
|
|||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
//
|
//
|
||||||
#include "msgpack/object.hpp"
|
#include "msgpack/object.hpp"
|
||||||
|
#include "msgpack/iterator.hpp"
|
||||||
#include "msgpack/zone.hpp"
|
#include "msgpack/zone.hpp"
|
||||||
#include "msgpack/pack.hpp"
|
#include "msgpack/pack.hpp"
|
||||||
#include "msgpack/unpack.hpp"
|
#include "msgpack/unpack.hpp"
|
||||||
#include "msgpack/sbuffer.hpp"
|
#include "msgpack/sbuffer.hpp"
|
||||||
#include "msgpack/vrefbuffer.hpp"
|
#include "msgpack/vrefbuffer.hpp"
|
||||||
#include "msgpack.h"
|
#include "msgpack/version.hpp"
|
||||||
58
include/msgpack/adaptor/bool.hpp
Normal file
58
include/msgpack/adaptor/bool.hpp
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2008-2009 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_TYPE_BOOL_HPP
|
||||||
|
#define MSGPACK_TYPE_BOOL_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
inline msgpack::object const& operator>> (msgpack::object const& o, bool& v)
|
||||||
|
{
|
||||||
|
if(o.type != msgpack::type::BOOLEAN) { throw msgpack::type_error(); }
|
||||||
|
v = o.via.boolean;
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
inline msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const bool& v)
|
||||||
|
{
|
||||||
|
if(v) { o.pack_true(); }
|
||||||
|
else { o.pack_false(); }
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (msgpack::object& o, bool v)
|
||||||
|
{
|
||||||
|
o.type = msgpack::type::BOOLEAN;
|
||||||
|
o.via.boolean = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, bool v)
|
||||||
|
{ static_cast<msgpack::object&>(o) << v; }
|
||||||
|
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_TYPE_BOOL_HPP
|
||||||
@@ -15,35 +15,25 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
//
|
//
|
||||||
#ifndef MSGPACK_TYPE_NIL_HPP__
|
#ifndef MSGPACK_TYPE_BOOL_FWD_HPP
|
||||||
#define MSGPACK_TYPE_NIL_HPP__
|
#define MSGPACK_TYPE_BOOL_FWD_HPP
|
||||||
|
|
||||||
#include "msgpack/object.hpp"
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
|
||||||
namespace msgpack {
|
namespace msgpack {
|
||||||
|
|
||||||
namespace type {
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
struct nil { };
|
|
||||||
|
|
||||||
} // namespace type
|
|
||||||
|
|
||||||
|
|
||||||
inline type::nil& operator>> (object o, type::nil& v)
|
|
||||||
{
|
|
||||||
if(o.type != type::NIL) { throw type_error(); }
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
msgpack::object const& operator>> (msgpack::object const& o, bool& v);
|
||||||
template <typename Stream>
|
template <typename Stream>
|
||||||
inline packer<Stream>& operator<< (packer<Stream>& o, const type::nil& v)
|
msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const bool& v);
|
||||||
{
|
void operator<< (msgpack::object& o, bool v);
|
||||||
o.pack_nil();
|
void operator<< (msgpack::object::with_zone& o, bool v);
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
} // namespace msgpack
|
} // namespace msgpack
|
||||||
|
|
||||||
#endif /* msgpack/type/nil.hpp */
|
#endif // MSGPACK_TYPE_BOOL_FWD_HPP
|
||||||
|
|
||||||
78
include/msgpack/adaptor/char_ptr.hpp
Normal file
78
include/msgpack/adaptor/char_ptr.hpp
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014-2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_TYPE_CHAR_PTR_HPP
|
||||||
|
#define MSGPACK_TYPE_CHAR_PTR_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
#include "msgpack/adaptor/check_container_size.hpp"
|
||||||
|
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
inline msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const char* v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(std::strlen(v));
|
||||||
|
o.pack_str(size);
|
||||||
|
o.pack_str_body(v, size);
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, const char* v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(std::strlen(v));
|
||||||
|
o.type = msgpack::type::STR;
|
||||||
|
char* ptr = static_cast<char*>(o.zone.allocate_align(size));
|
||||||
|
o.via.str.ptr = ptr;
|
||||||
|
o.via.str.size = size;
|
||||||
|
std::memcpy(ptr, v, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (msgpack::object& o, const char* v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(std::strlen(v));
|
||||||
|
o.type = msgpack::type::STR;
|
||||||
|
o.via.str.ptr = v;
|
||||||
|
o.via.str.size = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
inline packer<Stream>& operator<< (packer<Stream>& o, char* v)
|
||||||
|
{
|
||||||
|
return msgpack::operator<<(o, static_cast<const char*>(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (object::with_zone& o, char* v)
|
||||||
|
{
|
||||||
|
msgpack::operator<<(o, static_cast<const char*>(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void operator<< (object& o, char* v)
|
||||||
|
{
|
||||||
|
msgpack::operator<<(o, static_cast<const char*>(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_TYPE_CHAR_PTR_HPP
|
||||||
43
include/msgpack/adaptor/char_ptr_fwd.hpp
Normal file
43
include/msgpack/adaptor/char_ptr_fwd.hpp
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_TYPE_CHAR_PTR_FWD_HPP
|
||||||
|
#define MSGPACK_TYPE_CHAR_PTR_FWD_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const char* v);
|
||||||
|
void operator<< (msgpack::object::with_zone& o, const char* v);
|
||||||
|
void operator<< (msgpack::object& o, const char* v);
|
||||||
|
|
||||||
|
template <typename Stream>
|
||||||
|
packer<Stream>& operator<< (packer<Stream>& o, char* v);
|
||||||
|
void operator<< (object::with_zone& o, char* v);
|
||||||
|
void operator<< (object& o, char* v);
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_TYPE_CHAR_PTR_FWD_HPP
|
||||||
61
include/msgpack/adaptor/check_container_size.hpp
Normal file
61
include/msgpack/adaptor/check_container_size.hpp
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_CHECK_CONTAINER_SIZE_HPP
|
||||||
|
#define MSGPACK_CHECK_CONTAINER_SIZE_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
struct container_size_overflow : public std::runtime_error {
|
||||||
|
explicit container_size_overflow(const std::string& msg)
|
||||||
|
:std::runtime_error(msg) {}
|
||||||
|
#if !defined(MSGPACK_USE_CPP03)
|
||||||
|
explicit container_size_overflow(const char* msg):
|
||||||
|
std::runtime_error(msg) {}
|
||||||
|
#endif // !defined(MSGPACK_USE_CPP03)
|
||||||
|
};
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
inline void check_container_size(std::size_t size) {
|
||||||
|
if (size > 0xffffffff) throw container_size_overflow("container size overflow");
|
||||||
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline void check_container_size<4>(std::size_t size) {
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline uint32_t checked_get_container_size(T size) {
|
||||||
|
detail::check_container_size<sizeof(T)>(size);
|
||||||
|
return static_cast<uint32_t>(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_CHECK_CONTAINER_SIZE_HPP
|
||||||
76
include/msgpack/adaptor/cpp11/array.hpp
Normal file
76
include/msgpack/adaptor/cpp11/array.hpp
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014-2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef MSGPACK_CPP11_ARRAY_HPP
|
||||||
|
#define MSGPACK_CPP11_ARRAY_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
#include "msgpack/adaptor/check_container_size.hpp"
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <typename T, std::size_t N>
|
||||||
|
inline msgpack::object const& operator>> (msgpack::object const& o, std::array<T, N>& v) {
|
||||||
|
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
|
||||||
|
if(o.via.array.size != N) { throw msgpack::type_error(); }
|
||||||
|
if(o.via.array.size > 0) {
|
||||||
|
msgpack::object* p = o.via.array.ptr;
|
||||||
|
msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
|
||||||
|
T* it = &v[0];
|
||||||
|
do {
|
||||||
|
p->convert(*it);
|
||||||
|
++p;
|
||||||
|
++it;
|
||||||
|
} while(p < pend);
|
||||||
|
}
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Stream, typename T, std::size_t N>
|
||||||
|
inline msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const std::array<T, N>& v) {
|
||||||
|
uint32_t size = checked_get_container_size(v.size());
|
||||||
|
o.pack_array(size);
|
||||||
|
for(auto const& e : v) o.pack(e);
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, std::size_t N>
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, const std::array<T, N>& v) {
|
||||||
|
o.type = msgpack::type::ARRAY;
|
||||||
|
if(v.empty()) {
|
||||||
|
o.via.array.ptr = nullptr;
|
||||||
|
o.via.array.size = 0;
|
||||||
|
} else {
|
||||||
|
uint32_t size = checked_get_container_size(v.size());
|
||||||
|
msgpack::object* p = static_cast<msgpack::object*>(o.zone.allocate_align(sizeof(msgpack::object)*size));
|
||||||
|
o.via.array.size = size;
|
||||||
|
o.via.array.ptr = p;
|
||||||
|
for (auto const& e : v) *p++ = msgpack::object(e, o.zone);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP11_ARRAY_HPP
|
||||||
84
include/msgpack/adaptor/cpp11/array_char.hpp
Normal file
84
include/msgpack/adaptor/cpp11/array_char.hpp
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014-2015 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_TYPE_ARRAY_CHAR_HPP
|
||||||
|
#define MSGPACK_TYPE_ARRAY_CHAR_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack_fwd.hpp"
|
||||||
|
#include "msgpack/adaptor/check_container_size.hpp"
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
inline msgpack::object const& operator>> (msgpack::object const& o, std::array<char, N>& v)
|
||||||
|
{
|
||||||
|
switch (o.type) {
|
||||||
|
case msgpack::type::BIN:
|
||||||
|
if(o.via.bin.size != N) { throw msgpack::type_error(); }
|
||||||
|
std::memcpy(v.data(), o.via.bin.ptr, o.via.bin.size);
|
||||||
|
break;
|
||||||
|
case msgpack::type::STR:
|
||||||
|
if(o.via.str.size != N) { throw msgpack::type_error(); }
|
||||||
|
std::memcpy(v.data(), o.via.str.ptr, N);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw msgpack::type_error();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Stream, std::size_t N>
|
||||||
|
inline msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const std::array<char, N>& v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(v.size());
|
||||||
|
o.pack_bin(size);
|
||||||
|
o.pack_bin_body(v.data(), size);
|
||||||
|
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
inline void operator<< (msgpack::object& o, const std::array<char, N>& v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(v.size());
|
||||||
|
o.type = msgpack::type::BIN;
|
||||||
|
o.via.bin.ptr = v.data();
|
||||||
|
o.via.bin.size = size;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
inline void operator<< (msgpack::object::with_zone& o, const std::array<char, N>& v)
|
||||||
|
{
|
||||||
|
uint32_t size = checked_get_container_size(v.size());
|
||||||
|
o.type = msgpack::type::BIN;
|
||||||
|
char* ptr = static_cast<char*>(o.zone.allocate_align(size));
|
||||||
|
o.via.bin.ptr = ptr;
|
||||||
|
o.via.bin.size = size;
|
||||||
|
std::memcpy(ptr, v.data(), size);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_TYPE_ARRAY_CHAR_HPP
|
||||||
45
include/msgpack/adaptor/cpp11/array_char_fwd.hpp
Normal file
45
include/msgpack/adaptor/cpp11/array_char_fwd.hpp
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
#ifndef MSGPACK_TYPE_ARRAY_CHAR_FWD_HPP
|
||||||
|
#define MSGPACK_TYPE_ARRAY_CHAR_FWD_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
msgpack::object const& operator>> (msgpack::object const& o, std::array<char, N>& v);
|
||||||
|
|
||||||
|
template <typename Stream, std::size_t N>
|
||||||
|
msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const std::array<char, N>& v);
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
void operator<< (msgpack::object& o, const std::array<char, N>& v);
|
||||||
|
|
||||||
|
template <std::size_t N>
|
||||||
|
void operator<< (msgpack::object::with_zone& o, const std::array<char, N>& v);
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_TYPE_ARRAY_CHAR_FWD_HPP
|
||||||
44
include/msgpack/adaptor/cpp11/array_fwd.hpp
Normal file
44
include/msgpack/adaptor/cpp11/array_fwd.hpp
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
//
|
||||||
|
// MessagePack for C++ static resolution routine
|
||||||
|
//
|
||||||
|
// Copyright (C) 2014 KONDO Takatoshi
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef MSGPACK_CPP11_ARRAY_FWD_HPP
|
||||||
|
#define MSGPACK_CPP11_ARRAY_FWD_HPP
|
||||||
|
|
||||||
|
#include "msgpack/versioning.hpp"
|
||||||
|
#include "msgpack/object_fwd.hpp"
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
namespace msgpack {
|
||||||
|
|
||||||
|
MSGPACK_API_VERSION_NAMESPACE(v1) {
|
||||||
|
|
||||||
|
template <typename T, std::size_t N>
|
||||||
|
msgpack::object const& operator>> (msgpack::object const& o, std::array<T, N>& v);
|
||||||
|
|
||||||
|
template <typename Stream, typename T, std::size_t N>
|
||||||
|
msgpack::packer<Stream>& operator<< (msgpack::packer<Stream>& o, const std::array<T, N>& v);
|
||||||
|
|
||||||
|
template <typename T, std::size_t N>
|
||||||
|
void operator<< (msgpack::object::with_zone& o, const std::array<T, N>& v);
|
||||||
|
|
||||||
|
} // MSGPACK_API_VERSION_NAMESPACE(v1)
|
||||||
|
|
||||||
|
} // namespace msgpack
|
||||||
|
|
||||||
|
#endif // MSGPACK_CPP11_ARRAY_FWD_HPP
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user