a
    ³yjc  ã                   @   s*   d dl mZ ddd„Zeeffdd„ZdS )é    )ÚfilterfalseNc                 c   sb   t ƒ }|j}|du r6t|j| ƒD ]}||ƒ |V  q n(| D ]"}||ƒ}||vr:||ƒ |V  q:dS )zHList unique elements, preserving order. Remember all elements ever seen.N)ÚsetÚaddr   Ú__contains__)ÚiterableÚkeyÚseenZseen_addÚelementÚk© r   úY/var/www/html/django/DPS/env/lib/python3.9/site-packages/importlib_metadata/_itertools.pyÚunique_everseen   s    
r   c                 C   sX   | du rt dƒS |dur,t| |ƒr,t | fƒS z
t | ƒW S  tyR   t | fƒ Y S 0 dS )ax  If *obj* is iterable, return an iterator over its items::

        >>> obj = (1, 2, 3)
        >>> list(always_iterable(obj))
        [1, 2, 3]

    If *obj* is not iterable, return a one-item iterable containing *obj*::

        >>> obj = 1
        >>> list(always_iterable(obj))
        [1]

    If *obj* is ``None``, return an empty iterable:

        >>> obj = None
        >>> list(always_iterable(None))
        []

    By default, binary and text strings are not considered iterable::

        >>> obj = 'foo'
        >>> list(always_iterable(obj))
        ['foo']

    If *base_type* is set, objects for which ``isinstance(obj, base_type)``
    returns ``True`` won't be considered iterable.

        >>> obj = {'a': 1}
        >>> list(always_iterable(obj))  # Iterate over the dict's keys
        ['a']
        >>> list(always_iterable(obj, base_type=dict))  # Treat dicts as a unit
        [{'a': 1}]

    Set *base_type* to ``None`` to avoid any special handling and treat objects
    Python considers iterable as iterable:

        >>> obj = 'foo'
        >>> list(always_iterable(obj, base_type=None))
        ['f', 'o', 'o']
    Nr   )ÚiterÚ
isinstanceÚ	TypeError)ÚobjZ	base_typer   r   r   Úalways_iterable   s    )

r   )N)Ú	itertoolsr   r   ÚstrÚbytesr   r   r   r   r   Ú<module>   s   
