Message106641
STINNER Victor wrote:
>
> New submission from STINNER Victor <victor.stinner@haypocalc.com>:
>
> "t#" format was introduced by r11803 (11 years ago): "Implement new format character 't#'. This is like s#, accepting an object that implements the buffer interface, but requires a buffer that contains 8-bit character data."
>
> Python3 now has a strict separation between byte string (bytes and bytearray types) and unicode string (str), and has PyBuffer and PyCapsule APIs. "t#" format can be replaced by "y#" or "y*".
>
> Extract of getarg.c:
>
> /*TEO: This can be eliminated --- here only for backward
> compatibility */
> case 't': { /* 8-bit character buffer, read-only access */
>
> In Python, the last function using "t#" is _codecs.charbuffer_encode() and I proposed to remove this function in #8838. We can also patch this function.
>
> I don't know if third party modules use this format or not. I don't know if it can be just removed or if it should raise a deprecation warning (but who will notice such warning since there are disabled by default?).
Since Python3 completely removed the getcharbuffer interface
to which the "t#" interfaces in Python2, "t#" does indeed no
longer serve any special purpose.
It's probably wise to just map "t#" to "y#" in order to ease
porting extensions from 2.x to 3.x. |
|
Date |
User |
Action |
Args |
2010-05-28 08:14:57 | lemburg | set | recipients:
+ lemburg, vstinner |
2010-05-28 08:14:41 | lemburg | link | issue8839 messages |
2010-05-28 08:14:40 | lemburg | create | |
|