mirror of
https://github.com/python/cpython.git
synced 2024-11-25 19:03:49 +08:00
a977329b6f
(branch-creation time) up to 43067. 43068 and 43069 contain a little swapping action between re.py and sre.py, and this mightily confuses svn merge, so later changes are going in separately. This merge should break no additional tests. The last-merged revision is going in a 'last_merge' property on '.' (the branch directory.) Arbitrarily chosen, really; if there's a BCP for this, I couldn't find it, but we can easily change it afterwards ;)
39 lines
953 B
Python
39 lines
953 B
Python
# -*- coding: iso-8859-1 -*-
|
|
""" Python 'escape' Codec
|
|
|
|
|
|
Written by Martin v. Löwis (martin@v.loewis.de).
|
|
|
|
"""
|
|
import codecs
|
|
|
|
class Codec(codecs.Codec):
|
|
|
|
encode = codecs.escape_encode
|
|
decode = codecs.escape_decode
|
|
|
|
class IncrementalEncoder(codecs.IncrementalEncoder):
|
|
def encode(self, input, final=False):
|
|
return codecs.escape_encode(input, self.errors)[0]
|
|
|
|
class IncrementalDecoder(codecs.IncrementalDecoder):
|
|
def decode(self, input, final=False):
|
|
return codecs.escape_decode(input, self.errors)[0]
|
|
|
|
class StreamWriter(Codec,codecs.StreamWriter):
|
|
pass
|
|
|
|
class StreamReader(Codec,codecs.StreamReader):
|
|
pass
|
|
|
|
def getregentry():
|
|
return codecs.CodecInfo(
|
|
name='string-escape',
|
|
encode=Codec.encode,
|
|
decode=Codec.decode,
|
|
incrementalencoder=IncrementalEncoder,
|
|
incrementaldecoder=IncrementalDecoder,
|
|
streamwriter=StreamWriter,
|
|
streamreader=StreamReader,
|
|
)
|