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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
U
G=®d;ã@s|dZddlZddlmZzddlmZmZWn$ek
rPddlmZmZYnXe    dƒZ
dZ dd„Z Gdd    „d    eeƒZ dS)
An OrderedSet is a custom MutableSet that remembers its order, so that every
entry has an index that can be looked up.
 
Based on a recipe originally posted to ActiveState Recipes by Raymond Hettiger,
and released under the MIT license.
éN)Údeque)Ú
MutableSetÚSequencez3.1cCs"t|dƒo t|tƒ o t|tƒ S)a
 
    Are we being asked to look up a list of things, instead of a single thing?
    We check for the `__iter__` attribute so that this can cover types that
    don't have to be known by this module, such as NumPy arrays.
 
    Strings, however, should be considered as atomic values to look up, not
    iterables. The same goes for tuples, since they are immutable and therefore
    valid entries.
 
    We don't need to check for the Python 2 `unicode` type, because it doesn't
    have an `__iter__` attribute anyway.
    Ú__iter__)ÚhasattrÚ
isinstanceÚstrÚtuple)Úobj©r úUD:\z\workplace\VsCode\pyvenv\venv\Lib\site-packages\setuptools/_vendor/ordered_set.pyÚ is_iterables
 
 
ÿ
ýr c@sþeZdZdZd;dd„Zdd„Zdd„Zd    d
„Zd d „Zd d„Z    dd„Z
dd„Z e Z dd„Z dd„ZeZeZdd„Zdd„Zdd„Zdd„Zdd „Zd!d"„Zd#d$„Zd%d&„Zd'd(„Zd)d*„Zd+d,„Zd-d.„Zd/d0„Zd1d2„Zd3d4„Zd5d6„Z d7d8„Z!d9d:„Z"dS)<Ú
OrderedSetzØ
    An OrderedSet is a custom MutableSet that remembers its order, so that
    every entry has an index that can be looked up.
 
    Example:
        >>> OrderedSet([1, 1, 2, 3, 2])
        OrderedSet([1, 2, 3])
    NcCs g|_i|_|dk    r||O}dS©N)ÚitemsÚmap)ÚselfÚiterabler r r Ú__init__4szOrderedSet.__init__cCs
t|jƒS)zÄ
        Returns the number of unique elements in the ordered set
 
        Example:
            >>> len(OrderedSet([]))
            0
            >>> len(OrderedSet([1, 2]))
            2
        )Úlenr©rr r r Ú__len__:s
zOrderedSet.__len__cs|t|tƒr|tkrˆ ¡St|ƒr4‡fdd„|DƒSt|dƒsHt|tƒrlˆj|}t|tƒrfˆ |¡S|Sn t    d|ƒ‚dS)aQ
        Get the item at a given index.
 
        If `index` is a slice, you will get back that slice of items, as a
        new OrderedSet.
 
        If `index` is a list or a similar iterable, you'll get a list of
        items corresponding to those indices. This is similar to NumPy's
        "fancy indexing". The result is not an OrderedSet because you may ask
        for duplicate indices, and the number of elements returned should be
        the number of elements asked for.
 
        Example:
            >>> oset = OrderedSet([1, 2, 3])
            >>> oset[1]
            2
        csg|]}ˆj|‘qSr )r)Ú.0Úirr r Ú
<listcomp>[sz*OrderedSet.__getitem__.<locals>.<listcomp>Ú    __index__z+Don't know how to index an OrderedSet by %rN)
rÚsliceÚ    SLICE_ALLÚcopyr rrÚlistÚ    __class__Ú    TypeError)rÚindexÚresultr rr Ú __getitem__Fs
 
 
zOrderedSet.__getitem__cCs
| |¡S)zù
        Return a shallow copy of this object.
 
        Example:
            >>> this = OrderedSet([1, 2, 3])
            >>> other = this.copy()
            >>> this == other
            True
            >>> this is other
            False
        )r rr r r res zOrderedSet.copycCst|ƒdkrdSt|ƒSdS)Nrr)rrrr r r Ú __getstate__ss zOrderedSet.__getstate__cCs"|dkr| g¡n
| |¡dS)Nr)r)rÚstater r r Ú __setstate__s zOrderedSet.__setstate__cCs
||jkS)zÄ
        Test if the item is in this ordered set
 
        Example:
            >>> 1 in OrderedSet([1, 3, 2])
            True
            >>> 5 in OrderedSet([1, 3, 2])
            False
        )r©rÚkeyr r r Ú __contains__…s
zOrderedSet.__contains__cCs0||jkr&t|jƒ|j|<|j |¡|j|S)aE
        Add `key` as an item to this OrderedSet, then return its index.
 
        If `key` is already in the OrderedSet, return the index it already
        had.
 
        Example:
            >>> oset = OrderedSet()
            >>> oset.append(3)
            0
            >>> print(oset)
            OrderedSet([3])
        )rrrÚappendr(r r r Úadd‘s
 zOrderedSet.addcCsFd}z|D]}| |¡}q
Wn$tk
r@tdt|ƒƒ‚YnX|S)a<
        Update the set with the given iterable sequence, then return the index
        of the last element inserted.
 
        Example:
            >>> oset = OrderedSet([1, 2, 3])
            >>> oset.update([3, 1, 5, 1, 4])
            4
            >>> print(oset)
            OrderedSet([1, 2, 3, 5, 4])
        Nz(Argument needs to be an iterable, got %s)r,r!Ú
ValueErrorÚtype)rÚsequenceZ
item_indexÚitemr r r Úupdate¦s 
ÿ
zOrderedSet.updatecs$t|ƒr‡fdd„|DƒSˆj|S)aH
        Get the index of a given entry, raising an IndexError if it's not
        present.
 
        `key` can be an iterable of entries that is not a string, in which case
        this returns a list of indices.
 
        Example:
            >>> oset = OrderedSet([1, 2, 3])
            >>> oset.index(2)
            1
        csg|]}ˆ |¡‘qSr )r")rÚsubkeyrr r rÊsz$OrderedSet.index.<locals>.<listcomp>)r rr(r rr r"¼s zOrderedSet.indexcCs,|jstdƒ‚|jd}|jd=|j|=|S)zØ
        Remove and return the last element from the set.
 
        Raises KeyError if the set is empty.
 
        Example:
            >>> oset = OrderedSet([1, 2, 3])
            >>> oset.pop()
            3
        z Set is emptyéÿÿÿÿ)rÚKeyErrorr)rÚelemr r r ÚpopÑs 
zOrderedSet.popcCsP||krL|j|}|j|=|j|=|j ¡D]\}}||kr,|d|j|<q,dS)aØ
        Remove an element.  Do not raise an exception if absent.
 
        The MutableSet mixin uses this to implement the .remove() method, which
        *does* raise an error when asked to remove a non-existent item.
 
        Example:
            >>> oset = OrderedSet([1, 2, 3])
            >>> oset.discard(2)
            >>> print(oset)
            OrderedSet([1, 3])
            >>> oset.discard(2)
            >>> print(oset)
            OrderedSet([1, 3])
        éN)rr)rr)rÚkÚvr r r Údiscardäs
zOrderedSet.discardcCs|jdd…=|j ¡dS)z8
        Remove all items from this OrderedSet.
        N)rrÚclearrr r r r;üs zOrderedSet.clearcCs
t|jƒS)zb
        Example:
            >>> list(iter(OrderedSet([1, 2, 3])))
            [1, 2, 3]
        )Úiterrrr r r rszOrderedSet.__iter__cCs
t|jƒS)zf
        Example:
            >>> list(reversed(OrderedSet([1, 2, 3])))
            [3, 2, 1]
        )Úreversedrrr r r Ú __reversed__ szOrderedSet.__reversed__cCs&|sd|jjfSd|jjt|ƒfS)Nz%s()z%s(%r))r Ú__name__rrr r r Ú__repr__szOrderedSet.__repr__cCsRt|ttfƒrt|ƒt|ƒkSz t|ƒ}Wntk
r@YdSXt|ƒ|kSdS)a®
        Returns true if the containers have the same items. If `other` is a
        Sequence, then order is checked, otherwise it is ignored.
 
        Example:
            >>> oset = OrderedSet([1, 3, 2])
            >>> oset == [1, 3, 2]
            True
            >>> oset == [1, 2, 3]
            False
            >>> oset == [2, 3]
            False
            >>> oset == OrderedSet([3, 2, 1])
            False
        FN)rrrrÚsetr!)rÚotherZ other_as_setr r r Ú__eq__s zOrderedSet.__eq__cGs<t|tƒr|jnt}ttt |g|¡ƒ}tj |¡}||ƒS)a¶
        Combines all unique items.
        Each items order is defined by its first appearance.
 
        Example:
            >>> oset = OrderedSet.union(OrderedSet([3, 1, 4, 1, 5]), [1, 3], [2, 0])
            >>> print(oset)
            OrderedSet([3, 1, 4, 5, 2, 0])
            >>> oset.union([8, 9])
            OrderedSet([3, 1, 4, 5, 2, 0, 8, 9])
            >>> oset | {10}
            OrderedSet([3, 1, 4, 5, 2, 0, 10])
        )rrr rrÚitÚchainÚ from_iterable)rÚsetsÚclsZ
containersrr r r Úunion6s zOrderedSet.unioncCs
| |¡Sr)Ú intersection©rrBr r r Ú__and__IszOrderedSet.__and__csHt|tƒr|jnt}|r<tjtt|ƒމ‡fdd„|Dƒ}n|}||ƒS)a¯
        Returns elements in common between all sets. Order is defined only
        by the first set.
 
        Example:
            >>> oset = OrderedSet.intersection(OrderedSet([0, 1, 2, 3]), [1, 2, 3])
            >>> print(oset)
            OrderedSet([1, 2, 3])
            >>> oset.intersection([2, 4, 5], [1, 2, 3, 4])
            OrderedSet([2])
            >>> oset.intersection()
            OrderedSet([1, 2, 3])
        c3s|]}|ˆkr|VqdSrr ©rr0©Úcommonr r Ú    <genexpr>^sz*OrderedSet.intersection.<locals>.<genexpr>)rrr rArJr©rrGrHrr rNr rJMs zOrderedSet.intersectioncs:|j}|r.tjtt|ƒމ‡fdd„|Dƒ}n|}||ƒS)aÝ
        Returns all elements that are in this set but not the others.
 
        Example:
            >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2]))
            OrderedSet([1, 3])
            >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2]), OrderedSet([3]))
            OrderedSet([1])
            >>> OrderedSet([1, 2, 3]) - OrderedSet([2])
            OrderedSet([1, 3])
            >>> OrderedSet([1, 2, 3]).difference()
            OrderedSet([1, 2, 3])
        c3s|]}|ˆkr|VqdSrr rM©rBr r rPtsz(OrderedSet.difference.<locals>.<genexpr>)r rArIrrQr rRr Ú
differencecs zOrderedSet.differencecs*t|ƒtˆƒkrdSt‡fdd„|DƒƒS)a7
        Report whether another set contains this set.
 
        Example:
            >>> OrderedSet([1, 2, 3]).issubset({1, 2})
            False
            >>> OrderedSet([1, 2, 3]).issubset({1, 2, 3, 4})
            True
            >>> OrderedSet([1, 2, 3]).issubset({1, 4, 3, 5})
            False
        Fc3s|]}|ˆkVqdSrr rMrRr r rP‡sz&OrderedSet.issubset.<locals>.<genexpr>©rÚallrKr rRr Úissubsetys zOrderedSet.issubsetcs*tˆƒt|ƒkrdSt‡fdd„|DƒƒS)a=
        Report whether this set contains another set.
 
        Example:
            >>> OrderedSet([1, 2]).issuperset([1, 2, 3])
            False
            >>> OrderedSet([1, 2, 3, 4]).issuperset({1, 2, 3})
            True
            >>> OrderedSet([1, 4, 3, 5]).issuperset({1, 2, 3})
            False
        Fc3s|]}|ˆkVqdSrr rMrr r rP—sz(OrderedSet.issuperset.<locals>.<genexpr>rTrKr rr Ú
issuperset‰s zOrderedSet.issupersetcCs:t|tƒr|jnt}||ƒ |¡}||ƒ |¡}| |¡S)að
        Return the symmetric difference of two OrderedSets as a new set.
        That is, the new set will contain all elements that are in exactly
        one of the sets.
 
        Their order will be preserved, with elements from `self` preceding
        elements from `other`.
 
        Example:
            >>> this = OrderedSet([1, 4, 3, 5, 7])
            >>> other = OrderedSet([9, 7, 1, 3, 2])
            >>> this.symmetric_difference(other)
            OrderedSet([4, 5, 9, 2])
        )rrr rSrI)rrBrHZdiff1Zdiff2r r r Úsymmetric_difference™szOrderedSet.symmetric_differencecCs||_dd„t|ƒDƒ|_dS)zt
        Replace the 'items' list of this OrderedSet with a new one, updating
        self.map accordingly.
        cSsi|]\}}||“qSr r )rÚidxr0r r r Ú
<dictcomp>³sz,OrderedSet._update_items.<locals>.<dictcomp>N)rÚ    enumerater)rrr r r Ú _update_items­szOrderedSet._update_itemscs:tƒ‰|D]}ˆt|ƒO‰q
| ‡fdd„|jDƒ¡dS)aË
        Update this OrderedSet to remove items from one or more other sets.
 
        Example:
            >>> this = OrderedSet([1, 2, 3])
            >>> this.difference_update(OrderedSet([2, 4]))
            >>> print(this)
            OrderedSet([1, 3])
 
            >>> this = OrderedSet([1, 2, 3, 4, 5])
            >>> this.difference_update(OrderedSet([2, 4]), OrderedSet([1, 4, 6]))
            >>> print(this)
            OrderedSet([3, 5])
        csg|]}|ˆkr|‘qSr r rM©Úitems_to_remover r rÇsz0OrderedSet.difference_update.<locals>.<listcomp>N©rAr\r)rrGrBr r]r Údifference_updateµszOrderedSet.difference_updatecs&tˆƒ‰| ‡fdd„|jDƒ¡dS)a^
        Update this OrderedSet to keep only items in another set, preserving
        their order in this set.
 
        Example:
            >>> this = OrderedSet([1, 4, 3, 5, 7])
            >>> other = OrderedSet([9, 7, 1, 3, 2])
            >>> this.intersection_update(other)
            >>> print(this)
            OrderedSet([1, 3, 7])
        csg|]}|ˆkr|‘qSr r rMrRr r rÖsz2OrderedSet.intersection_update.<locals>.<listcomp>Nr_rKr rRr Úintersection_updateÉs zOrderedSet.intersection_updatecs<‡fdd„|Dƒ}t|ƒ‰ˆ ‡fdd„ˆjDƒ|¡dS)a‰
        Update this OrderedSet to remove items from another set, then
        add items from the other set that were not present in this set.
 
        Example:
            >>> this = OrderedSet([1, 4, 3, 5, 7])
            >>> other = OrderedSet([9, 7, 1, 3, 2])
            >>> this.symmetric_difference_update(other)
            >>> print(this)
            OrderedSet([4, 5, 9, 2])
        csg|]}|ˆkr|‘qSr r rMrr r räsz:OrderedSet.symmetric_difference_update.<locals>.<listcomp>csg|]}|ˆkr|‘qSr r rMr]r r rçsNr_)rrBZ items_to_addr )r^rr Úsymmetric_difference_updateØs
ÿz&OrderedSet.symmetric_difference_update)N)#r?Ú
__module__Ú __qualname__Ú__doc__rrr$rr%r'r*r,r+r1r"Zget_locZ get_indexerr6r:r;rr>r@rCrIrLrJrSrVrWrXr\r`rarbr r r r r*s@    
   r)reÚ    itertoolsrDÚ collectionsrÚcollections.abcrrÚ ImportErrorrrÚ __version__r rr r r r Ú<module>s