|
@@ -28,6 +28,7 @@ _ITEM_HASH = 0x02
|
|
|
_ITEM_LIST = 0x03
|
|
|
_ITEM_NULL = 0x04
|
|
|
_ITEM_BOOL = 0x05
|
|
|
+_ITEM_INT = 0x06
|
|
|
_ITEM_UTF8 = 0x08
|
|
|
_ITEM_MASK = 0x0f
|
|
|
|
|
@@ -73,6 +74,10 @@ def _pack_bool(item):
|
|
|
"""Pack a bool and its type/length prefix."""
|
|
|
return (_encode_length_and_type(_encode_bool(item), _ITEM_BOOL))
|
|
|
|
|
|
+def _pack_int(item):
|
|
|
+ """Pack an integer and its type/length prefix."""
|
|
|
+ return (_encode_length_and_type(bytes(str(item), 'utf-8'), _ITEM_INT))
|
|
|
+
|
|
|
def _pack_array(item):
|
|
|
"""Pack a list (array) and its type/length prefix."""
|
|
|
return (_encode_length_and_type(_encode_array(item), _ITEM_LIST))
|
|
@@ -100,6 +105,8 @@ def _encode_item(item):
|
|
|
return (_pack_nil())
|
|
|
elif type(item) == bool:
|
|
|
return (_pack_bool(item))
|
|
|
+ elif type(item) == int:
|
|
|
+ return (_pack_int(item))
|
|
|
elif type(item) == dict:
|
|
|
return (_pack_hash(item))
|
|
|
elif type(item) == list:
|
|
@@ -186,6 +193,8 @@ def _decode_item(data):
|
|
|
value = item
|
|
|
elif item_type == _ITEM_BOOL:
|
|
|
value = _decode_bool(item)
|
|
|
+ elif item_type == _ITEM_INT:
|
|
|
+ value = _decode_int(item)
|
|
|
elif item_type == _ITEM_UTF8:
|
|
|
value = str(item, 'utf-8')
|
|
|
elif item_type == _ITEM_HASH:
|
|
@@ -202,6 +211,9 @@ def _decode_item(data):
|
|
|
def _decode_bool(data):
|
|
|
return data == b'0x01'
|
|
|
|
|
|
+def _decode_int(data):
|
|
|
+ return int(str(data, 'utf-8'))
|
|
|
+
|
|
|
def _decode_hash(data):
|
|
|
ret = {}
|
|
|
while len(data) > 0:
|