2015-05-04 09:35:40 -04:00
|
|
|
try:
|
|
|
|
import ustruct as struct
|
|
|
|
except:
|
|
|
|
import struct
|
2014-04-09 20:45:38 -04:00
|
|
|
print(struct.calcsize("<bI"))
|
|
|
|
print(struct.unpack("<bI", b"\x80\0\0\x01\0"))
|
2014-04-10 15:19:32 -04:00
|
|
|
print(struct.calcsize(">bI"))
|
|
|
|
print(struct.unpack(">bI", b"\x80\0\0\x01\0"))
|
2014-04-10 20:47:21 -04:00
|
|
|
|
|
|
|
# 32-bit little-endian specific
|
|
|
|
#print(struct.unpack("bI", b"\x80\xaa\x55\xaa\0\0\x01\0"))
|
2014-04-18 20:13:15 -04:00
|
|
|
|
|
|
|
print(struct.pack("<i", 1))
|
|
|
|
print(struct.pack(">i", 1))
|
|
|
|
print(struct.pack("<h", 1))
|
|
|
|
print(struct.pack(">h", 1))
|
|
|
|
print(struct.pack("<b", 1))
|
|
|
|
print(struct.pack(">b", 1))
|
|
|
|
|
|
|
|
print(struct.pack("<bI", -128, 256))
|
|
|
|
print(struct.pack(">bI", -128, 256))
|
2014-05-12 16:45:50 -04:00
|
|
|
|
|
|
|
print(struct.calcsize("100sI"))
|
|
|
|
print(struct.calcsize("97sI"))
|
|
|
|
print(struct.unpack("<6sH", b"foo\0\0\0\x12\x34"))
|
|
|
|
print(struct.pack("<6sH", b"foo", 10000))
|
2014-06-25 15:25:53 -04:00
|
|
|
|
|
|
|
s = struct.pack("BHBI", 10, 100, 200, 300)
|
|
|
|
v = struct.unpack("BHBI", s)
|
|
|
|
print(v == (10, 100, 200, 300))
|
2014-12-05 18:13:52 -05:00
|
|
|
|
|
|
|
# check maximum pack on 32-bit machine
|
|
|
|
print(struct.pack("<I", 2**32 - 1))
|
|
|
|
print(struct.pack("<I", 0xffffffff))
|
|
|
|
|
2015-04-25 18:16:39 -04:00
|
|
|
# long long ints
|
|
|
|
print(struct.pack("<Q", 2**64 - 1))
|
2015-10-01 13:49:37 -04:00
|
|
|
print(struct.pack(">Q", 2**64 - 1))
|
2015-04-25 18:16:39 -04:00
|
|
|
print(struct.pack("<Q", 0xffffffffffffffff))
|
2015-10-01 13:49:37 -04:00
|
|
|
print(struct.pack(">Q", 0xffffffffffffffff))
|
2015-04-25 18:16:39 -04:00
|
|
|
print(struct.pack("<q", -1))
|
2015-10-01 13:49:37 -04:00
|
|
|
print(struct.pack(">q", -1))
|
2015-04-25 18:16:39 -04:00
|
|
|
print(struct.pack("<Q", 1234567890123456789))
|
|
|
|
print(struct.pack("<q", -1234567890123456789))
|
|
|
|
print(struct.pack(">Q", 1234567890123456789))
|
|
|
|
print(struct.pack(">q", -1234567890123456789))
|
|
|
|
print(struct.unpack("<Q", b"\x12\x34\x56\x78\x90\x12\x34\x56"))
|
|
|
|
print(struct.unpack(">Q", b"\x12\x34\x56\x78\x90\x12\x34\x56"))
|
|
|
|
print(struct.unpack("<q", b"\x12\x34\x56\x78\x90\x12\x34\xf6"))
|
|
|
|
print(struct.unpack(">q", b"\xf2\x34\x56\x78\x90\x12\x34\x56"))
|
2014-12-05 18:13:52 -05:00
|
|
|
|
|
|
|
# check maximum unpack
|
|
|
|
print(struct.unpack("<I", b"\xff\xff\xff\xff"))
|
|
|
|
print(struct.unpack("<Q", b"\xff\xff\xff\xff\xff\xff\xff\xff"))
|
2015-04-04 19:03:43 -04:00
|
|
|
|
|
|
|
# network byte order
|
|
|
|
print(struct.pack('!i', 123))
|
2015-09-03 18:06:18 -04:00
|
|
|
|
|
|
|
# first arg must be a string
|
|
|
|
try:
|
|
|
|
struct.pack(1, 2)
|
|
|
|
except TypeError:
|
|
|
|
print('TypeError')
|
2015-10-31 11:43:55 -04:00
|
|
|
|
|
|
|
# Initially repitition counters were supported only for strings,
|
|
|
|
# but later were implemented for all.
|
|
|
|
print(struct.unpack("<3B2h", b"foo\x12\x34\xff\xff"))
|
|
|
|
print(struct.pack("<3B", 1, 2, 3))
|