zmc
2023-08-08 e792e9a60d958b93aef96050644f369feb25d61b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
U
ß=®dã@s*ddlmZddd„Zeeffdd„ZdS)é)Ú filterfalseNccsbtƒ}|j}|dkr6t|j|ƒD]}||ƒ|Vq n(|D]"}||ƒ}||kr:||ƒ|Vq:dS)zHList unique elements, preserving order. Remember all elements ever seen.N)ÚsetÚaddrÚ __contains__)ÚiterableÚkeyÚseenZseen_addÚelementÚk©r úTd:\z\workplace\vscode\pyvenv\venv\Lib\site-packages\importlib_metadata/_itertools.pyÚunique_everseens
r cCsZ|dkrtdƒS|dk    r,t||ƒr,t|fƒSz
t|ƒWStk
rTt|fƒYSXdS)axIf *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_iterables)
 
r)N)Ú    itertoolsrr ÚstrÚbytesrr r r r Ú<module>s