Rev | Line | |
---|
[1169] | 1 | from typing import TypeVar, Generic, List
|
---|
[694] | 2 |
|
---|
| 3 | E = TypeVar('E')
|
---|
| 4 |
|
---|
| 5 | class ArrayListSet(Generic[E],List[E]):
|
---|
| 6 |
|
---|
| 7 | def __hash__(self):
|
---|
| 8 | hashCode = 1
|
---|
| 9 | for e in self:
|
---|
| 10 | hashCode += 0 if e == None else hash(e)
|
---|
| 11 | return hashCode
|
---|
| 12 |
|
---|
| 13 | def __eq__(self, o) -> bool:
|
---|
| 14 | if not isinstance(o, ArrayListSet):
|
---|
| 15 | return False
|
---|
| 16 |
|
---|
| 17 | list2:ArrayListSet = o
|
---|
| 18 | if len(self) != len(list2):
|
---|
| 19 | return False
|
---|
| 20 |
|
---|
| 21 | for e1 in self:
|
---|
| 22 | if not e1 in list2:
|
---|
| 23 | return False
|
---|
| 24 |
|
---|
| 25 | return True
|
---|
| 26 |
|
---|
| 27 | # we can't declare index:int , python says mismatch with superclass!
|
---|
| 28 | def __setitem__(self, index, element):
|
---|
| 29 | if element in self:
|
---|
| 30 | self.remove(element)
|
---|
| 31 | return super().__setitem__(index, element)
|
---|
| 32 |
|
---|
| 33 | def append(self, e) :
|
---|
| 34 | if e in self:
|
---|
| 35 | return False
|
---|
| 36 | return super().append(e)
|
---|
| 37 |
|
---|
| 38 | def insert(self, index, element):
|
---|
| 39 | if element in self:
|
---|
| 40 | return;
|
---|
| 41 | super().insert(index, element)
|
---|
| 42 |
|
---|
[752] | 43 | def extend(self, c) : # superclass does not do typing, we can't either...
|
---|
[694] | 44 | for e in c:
|
---|
[752] | 45 | self.append(e)
|
---|
[694] | 46 |
|
---|
Note:
See
TracBrowser
for help on using the repository browser.