PEP 574: update (#883)

* PEP 574: add bit of trivia about the undocumented "inst_persistent_id" hook

Communicated by Martin Gfeller.

* PEP 574: make it a requirement that buffers are contiguous
This commit is contained in:
Antoine Pitrou 2019-01-27 12:48:33 +01:00 committed by Nick Coghlan
parent 33459e7b49
commit 5bf886ecbb
1 changed files with 18 additions and 3 deletions

View File

@ -212,10 +212,20 @@ PickleBuffer objects:
Release the ``PickleBuffer`` instance's underlying buffer. Release the ``PickleBuffer`` instance's underlying buffer.
Buffer requirements
-------------------
``PickleBuffer`` can wrap any kind of buffer, including non-contiguous ``PickleBuffer`` can wrap any kind of buffer, including non-contiguous
buffers. It's up to consumers to decide how best to handle different kinds buffers. However, it is required that ``__reduce__`` only returns a
of buffers (for example, some consumers may find it acceptable to make a contiguous ``PickleBuffer`` (*contiguity* here is meant in the PEP 3118
contiguous copy of non-contiguous buffers). sense: either C-ordered or Fortran-ordered). Non-contiguous buffers
will raise an error when pickled.
This restriction is primarily an ease-of-implementation issue for the
``pickle`` module but also other consumers of out-of-band buffers.
The simplest solution on the provider side is to return a contiguous
copy of a non-contiguous buffer; a sophisticated provider, though, may
decide instead to return a sequence of contiguous sub-buffers.
Consumer API Consumer API
@ -420,6 +430,11 @@ This mechanism has two drawbacks:
such as ints and strings) triggers a call to the user's ``persistent_id()`` such as ints and strings) triggers a call to the user's ``persistent_id()``
method, leading to a possible performance drop compared to nominal. method, leading to a possible performance drop compared to nominal.
(the Python 2 ``cPickle`` module supported an undocumented
``inst_persistent_id()`` hook that was only called on non-built-in types;
it was added in 1997 in order to alleviate the performance issue of
calling ``persistent_id``, presumably at ZODB's request)
Passing a sequence of buffers in ``buffer_callback`` Passing a sequence of buffers in ``buffer_callback``
---------------------------------------------------- ----------------------------------------------------