• Thomas Wouters's avatar
    Merge part of the trunk changes into the p3yk branch. This merges from 43030 · a977329b
    Thomas Wouters yazdı
    (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 ;)
    a977329b
ascii.py 1.22 KB
""" Python 'ascii' 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.ascii_encode
    decode = codecs.ascii_decode

class IncrementalEncoder(codecs.IncrementalEncoder):
    def encode(self, input, final=False):
        return codecs.ascii_encode(input, self.errors)[0]

class IncrementalDecoder(codecs.IncrementalDecoder):
    def decode(self, input, final=False):
        return codecs.ascii_decode(input, self.errors)[0]

class StreamWriter(Codec,codecs.StreamWriter):
    pass

class StreamReader(Codec,codecs.StreamReader):
    pass

class StreamConverter(StreamWriter,StreamReader):

    encode = codecs.ascii_decode
    decode = codecs.ascii_encode

### encodings module API

def getregentry():
    return codecs.CodecInfo(
        name='ascii',
        encode=Codec.encode,
        decode=Codec.decode,
        incrementalencoder=IncrementalEncoder,
        incrementaldecoder=IncrementalDecoder,
        streamwriter=StreamWriter,
        streamreader=StreamReader,
    )