³ò JÖ±Gc@sŽdZddkZddkZddklZhZdZdgZdZeiZ de e fd„ƒYZ d „Z d „ZeieƒdS( s, Standard "encodings" Package Standard Python encoding modules are stored in this package directory. Codec modules must have names corresponding to normalized encoding names as defined in the normalize_encoding() function below, e.g. 'utf-8' must be implemented by the module 'utf_8.py'. Each codec module must export the following interface: * getregentry() -> codecs.CodecInfo object The getregentry() API must a CodecInfo object with encoder, decoder, incrementalencoder, incrementaldecoder, streamwriter and streamreader atttributes which adhere to the Python Codec Interface Standard. In addition, a module may optionally also define the following APIs which are then used by the package's codec search function: * getaliases() -> sequence of encoding name strings to use as aliases Alias names returned by getaliases() must be normalized encoding names as defined by normalize_encoding(). Written by Marc-Andre Lemburg (mal@lemburg.com). (c) Copyright CNRI, All Rights Reserved. NO WARRANTY. iÿÿÿÿN(taliasess --unknown--t*s . 0123456789 ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz tCodecRegistryErrorcBseZRS((t__name__t __module__(((sencodings\__init__.pycR-scCsUttdƒo)t|ƒtijo|idƒ}ndi|itƒiƒƒS(s´ Normalize an encoding name. Normalization works as follows: all non-alphanumeric characters except the dot used for Python package names are collapsed and replaced with a single underscore, e.g. ' -;#' becomes '_'. Leading and trailing underscores are removed. Note that encoding names should be ASCII only; if they do use non-ASCII characters, these must be Latin-1 compatible. t UnicodeTypeslatin-1t_( thasattrttypesttypeRtencodetjoint translatet_norm_encoding_maptsplit(tencoding((sencodings\__init__.pyctnormalize_encoding0s&c CsYti|tƒ}|tj o|Snt|ƒ}ti|ƒpti|iddƒƒ}|dj o||g}n |g}xj|D]\}| p d|joq‹ny#td|tƒt ƒt ƒ}Wnt j oq‹XPq‹Wd}y |i }Wnt j o d}nX|djodt|s    T