fix(serializer): Add support for bytearray
and memoryview
types
#1833
+33
−4
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Both
bytearray
andmemoryview
built-in types weren't explicitly mentioned in the serializer logic, and as they are subtyping Sequence, this led their instances to be enumerated upon, and to be output as a list of bytes, byte per byte.In the case of
memoryview
, this could also lead to a segmentation fault if the memory referenced was already freed and unavailable to the process by then.By explicitly adding them as seralizable types, bytearray will be decoded as a string just like bytes, and memoryview will use its repr method instead.
Close GH-1829
I noticed Python 2.7 was still supported, so I also attempted to add the fix for this version.
However
bytearray
andmemoryview
were introduced by Python 2.7, so this PR introduces code that is not supported by Python 2.6 (which reached its end of life in 2013).I don't know if this is a concern or not?