10000 [WIP] Newspec stage 2. by methane · Pull Request #79 · msgpack/msgpack-python · GitHub
[go: up one dir, main page]

Skip to content

[WIP] Newspec stage 2. #79

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 22 commits into from
Oct 20, 2013
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
d610975
add support for extended types: you can now pack/unpack custom python…
antocuni Oct 15, 2013
5529dfe
kill some duplicate code from unpack/unpackb and move the logic to Un…
antocuni Oct 18, 2013
522c4bf
slightly change to API
antocuni Oct 18, 2013
c727440
automatically find the best format to encode extended types
antocuni Oct 18, 2013
afa28fb
add support to unpack all ext formats
antocuni Oct 18, 2013
5467515
implement Packer.pack_extended_type also in the cython version of the…
antocuni Oct 18, 2013
a7485ec
add the hook for unknown types also to the cython Packer
antocuni Oct 18, 2013
ff85838
implement unpack_one also for the cython version, and add a test for it
antocuni Oct 18, 2013
985d4c1
add a test for unpacking extended types
antocuni Oct 19, 2013
56dd165
implement unpacking for all the fixtext formats
antocuni Oct 19, 2013
c9b97f0
implement unpacking of ext 8,16,32
antocuni Oct 19, 2013
6386481
add a note in the README
antocuni Oct 19, 2013
27f0cba
Merge branch 'master' of https://github.com/antocuni/msgpack-python i…
methane Oct 20, 2013
aa68c9b
fallback: Support pack_ext_type.
methane Oct 20, 2013
96bcd76
Packing ExtType and some cleanup
methane Oct 20, 2013
822cce8
Support unpacking new types.
methane Oct 20, 2013
0d5c58b
cleanup
methane Oct 20, 2013
84dc99c
Add ext_type example to README.
methane Oct 20, 2013
cb78959
Update README.
methane Oct 20, 2013
37c2ad6
Add tests and bugfix.
methane Oct 20, 2013
e3fee4d
fallback: support packing ExtType
methane Oct 20, 2013
d84a403
fix bugs.
methane Oct 20, 2013
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
automatically find the best format to encode extended types
  • Loading branch information
antocuni committed Oct 18, 2013
commit c727440ba5fe2f77d6cc03171ad7c193a3f481ee
28 changes: 22 additions & 6 deletions msgpack/fallback.py
Original file line number Diff line number Diff line change
Expand Up @@ -545,13 +545,29 @@ def handle_unknown_type(self, obj):
# overridden by subclasses
return None

def pack_extended_type(self, fmt, typecode, data):
# for now we support only this. We should add support for the other
# fixext/ext formats
assert fmt == "ext 32"
def pack_extended_type(self, typecode, data):
assert 0 <= typecode <= 127
N = len(data)
self._buffer.write(struct.pack('>BIB', 0xc9, N, typecode))
n = len(data)
if n == 1:
header = struct.pack(">BB", 0xd4, typecode) # fixext 1
elif n == 2:
header = struct.pack(">BB", 0xd5, typecode) # fixext 2
elif n == 4:
header = struct.pack(">BB", 0xd6, typecode) # fixext 4
elif n == 8:
header = struct.pack(">BB", 0xd7, typecode) # fixext 8
elif n == 16:
header = struct.pack(">BB", 0xd8, typecode) # fixext 16
elif n <= 2**8-1:
header = struct.pack(">BBB", 0xc7, n, typecode) # ext 8
elif n <= 2**16-1:
header = struct.pack(">BHB", 0xc8, n, typecode) # ext 16
elif n <= 2**32-1:
header = struct.pack(">BIB", 0xc9, n, typecode) # ext 32
else:
raise PackValueError("ext data too large")
#
self._buffer.write(header)
self._buffer.write(data)

def pack(self, obj):
Expand Down
18 changes: 16 additions & 2 deletions test/test_extension.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,28 @@
import array
import struct
import msgpack

def test_pack_extended_type():
def p(s):
packer = msgpack.Packer()
packer.pack_extended_type(0x42, s)
return packer._buffer.getvalue()
assert p('A') == '\xd4\x42A' # fixext 1
assert p('AB') == '\xd5\x42AB' # fixext 2
assert p('ABCD') == '\xd6\x42ABCD' # fixext 4
assert p('ABCDEFGH') == '\xd7\x42ABCDEFGH' # fixext 8
assert p('A'*16) == '\xd8\x42' + 'A'*16 # fixext 16
assert p('ABC') == '\xc7\x03\x42ABC' # ext 8
assert p('A'*0x0123) == '\xc8\x01\x23\x42' + 'A'*0x0123 # ext 16
assert p('A'*0x00012345) == '\xc9\x00\x01\x23\x45\x42' + 'A'*0x00012345 # ext 32

def test_extension_type():
class MyPacker(msgpack.Packer):
def handle_unknown_type(self, obj):
if isinstance(obj, array.array):
fmt = "ext 32"
typecode = 123 # application specific typecode
data = obj.tostring()
self.pack_extended_type(fmt, typecode, data)
self.pack_extended_type(typecode, data)
return True

class MyUnpacker(msgpack.Unpacker):
Expand Down
0