File: //usr/lib/python3.5/encodings/__pycache__/__init__.cpython-35.pyc
FüƒaË ã @ s‚ d Z d d l Z d d l m Z i Z d Z d g Z e j Z Gd d „ d e e ƒ Z
d d
„ Z d d „ Z e j
e ƒ d S)
a3 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 return 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.
é Né )Úaliasesz--unknown--Ú*c @ s e Z d Z d S)ÚCodecRegistryErrorN)Ú__name__Ú
__module__Ú__qualname__© r r ú(/usr/lib/python3.5/encodings/__init__.pyr ' s r c C s• t | t ƒ r t | d ƒ } g } d } x[ | D]S } | j ƒ sO | d k r~ | rh | rh | j d ƒ | j | ƒ d } q1 d } q1 Wd j | ƒ S)a´ 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.
ÚasciiFÚ.Ú_TÚ )Ú
isinstanceÚbytesÚstrÚisalnumÚappendÚjoin)ÚencodingÚcharsÚpunctÚcr r r
Únormalize_encoding* s
r c
C s t j | t ƒ } | t k r"