mirror of
https://github.com/python/cpython.git
synced 2024-12-14 20:34:12 +08:00
39aa98346d
They support now splitting escape sequences between input chunks. Add the third parameter "final" in codecs.raw_unicode_escape_decode(). It is True by default to match the former behavior.
47 lines
1.3 KiB
Python
47 lines
1.3 KiB
Python
""" Python 'raw-unicode-escape' Codec
|
|
|
|
|
|
Written by Marc-Andre Lemburg (mal@lemburg.com).
|
|
|
|
(c) Copyright CNRI, All Rights Reserved. NO WARRANTY.
|
|
|
|
"""
|
|
import codecs
|
|
|
|
### Codec APIs
|
|
|
|
class Codec(codecs.Codec):
|
|
|
|
# Note: Binding these as C functions will result in the class not
|
|
# converting them to methods. This is intended.
|
|
encode = codecs.raw_unicode_escape_encode
|
|
decode = codecs.raw_unicode_escape_decode
|
|
|
|
class IncrementalEncoder(codecs.IncrementalEncoder):
|
|
def encode(self, input, final=False):
|
|
return codecs.raw_unicode_escape_encode(input, self.errors)[0]
|
|
|
|
class IncrementalDecoder(codecs.BufferedIncrementalDecoder):
|
|
def _buffer_decode(self, input, errors, final):
|
|
return codecs.raw_unicode_escape_decode(input, errors, final)
|
|
|
|
class StreamWriter(Codec,codecs.StreamWriter):
|
|
pass
|
|
|
|
class StreamReader(Codec,codecs.StreamReader):
|
|
def decode(self, input, errors='strict'):
|
|
return codecs.raw_unicode_escape_decode(input, errors, False)
|
|
|
|
### encodings module API
|
|
|
|
def getregentry():
|
|
return codecs.CodecInfo(
|
|
name='raw-unicode-escape',
|
|
encode=Codec.encode,
|
|
decode=Codec.decode,
|
|
incrementalencoder=IncrementalEncoder,
|
|
incrementaldecoder=IncrementalDecoder,
|
|
streamwriter=StreamWriter,
|
|
streamreader=StreamReader,
|
|
)
|