[Python-Dev] Accepting PEP 3154 for 3.4?
Tim Peters
tim.peters at gmail.com
Thu Nov 21 02:23:18 CET 2013
[Alexandre Vassalotti]
> Looking at the different options available to us:
>
> 1A. Mandatory framing
> (+) Allows the internal buffering layer of the Unpickler to rely
> on the presence of framing to simplify its implementation.
> (-) Forces all implementations of pickle to include support for
> framing if they want to use the new protocol.
> (-) Cannot be removed from future versions of the Unpickler
> without breaking protocols which mandates framing.
> 1B. Optional framing
> (+) Could allow optimizations to disable framing if beneficial
> (e.g., when pickling to and unpickling from a string).
Or to slash the size of small pickles (an 8-byte size field can be
more than half the total pickle size).
> 2A. With explicit FRAME opcode
> (+) Makes optional framing simpler to implement.
> (+) Makes variable-length encoding of the frame size simpler
> to implement.
> (+) Makes framing visible to pickletools.
(+) Adds (a little) redundancy for sanity checking.
> (-) Adds an extra byte of overhead to each frames.
> 2B. No opcode
>
> 3A. With fixed 8-bytes headers
> (+) Is simple to implement
> (-) Adds overhead to small pickles.
> 3B. With variable-length headers
> (-) Requires Pickler implemention to do extra data copies when
> pickling to strings.
>
> 4A. Framing baked-in the pickle protocol
> (+) Enables faster implementations
> 4B. Framing through a specialized I/O buffering layer
> (+) Could be reused by other modules
>
> I may change my mind as I work on the implementation, but at least for now,
> I think the combination of 1B, 2A, 3A, 4A will be a reasonable compromise
> here.
At this time I'd make the same choices, so don't expect an argument
from me ;-) Thank you!
More information about the Python-Dev
mailing list