Current Path: > > opt > alt > python35 > lib64 > python3.5 >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
asyncio | Directory | - | - | |
collections | Directory | - | - | |
concurrent | Directory | - | - | |
config-3.5m | Directory | - | - | |
ctypes | Directory | - | - | |
curses | Directory | - | - | |
dbm | Directory | - | - | |
distutils | Directory | - | - | |
Directory | - | - | ||
encodings | Directory | - | - | |
ensurepip | Directory | - | - | |
html | Directory | - | - | |
http | Directory | - | - | |
idlelib | Directory | - | - | |
importlib | Directory | - | - | |
json | Directory | - | - | |
lib-dynload | Directory | - | - | |
lib2to3 | Directory | - | - | |
logging | Directory | - | - | |
multiprocessing | Directory | - | - | |
plat-linux | Directory | - | - | |
pydoc_data | Directory | - | - | |
site-packages | Directory | - | - | |
sqlite3 | Directory | - | - | |
test | Directory | - | - | |
unittest | Directory | - | - | |
urllib | Directory | - | - | |
venv | Directory | - | - | |
wsgiref | Directory | - | - | |
xml | Directory | - | - | |
xmlrpc | Directory | - | - | |
__future__.py | File | 4841 bytes | May 31 2024 13:51:46. | |
__phello__.foo.py | File | 64 bytes | May 31 2024 13:51:44. | |
_bootlocale.py | File | 1301 bytes | May 31 2024 13:51:40. | |
_collections_abc.py | File | 24794 bytes | May 31 2024 13:51:40. | |
_compat_pickle.py | File | 8556 bytes | May 31 2024 13:51:43. | |
_compression.py | File | 5340 bytes | May 31 2024 13:51:41. | |
_dummy_thread.py | File | 5118 bytes | May 31 2024 13:51:44. | |
_markupbase.py | File | 14598 bytes | May 31 2024 13:51:40. | |
_osx_support.py | File | 19115 bytes | May 31 2024 13:51:44. | |
_pydecimal.py | File | 228628 bytes | May 31 2024 13:51:40. | |
_pyio.py | File | 87968 bytes | May 31 2024 13:51:41. | |
_sitebuiltins.py | File | 3115 bytes | May 31 2024 13:51:41. | |
_strptime.py | File | 22185 bytes | May 31 2024 13:51:45. | |
_sysconfigdata.py | File | 26951 bytes | May 31 2024 13:51:44. | |
_threading_local.py | File | 7410 bytes | May 31 2024 13:51:40. | |
_weakrefset.py | File | 5705 bytes | May 31 2024 13:51:40. | |
abc.py | File | 8628 bytes | May 31 2024 13:51:40. | |
aifc.py | File | 31967 bytes | May 31 2024 13:51:45. | |
antigravity.py | File | 476 bytes | May 31 2024 13:51:40. | |
argparse.py | File | 90138 bytes | May 31 2024 13:51:44. | |
ast.py | File | 12001 bytes | May 31 2024 13:51:44. | |
asynchat.py | File | 11971 bytes | May 31 2024 13:51:44. | |
asyncore.py | File | 20104 bytes | May 31 2024 13:51:46. | |
base64.py | File | 20522 bytes | May 31 2024 13:51:40. | |
bdb.py | File | 23354 bytes | May 31 2024 13:51:43. | |
binhex.py | File | 13954 bytes | May 31 2024 13:51:40. | |
bisect.py | File | 2595 bytes | May 31 2024 13:51:40. | |
bz2.py | File | 12424 bytes | May 31 2024 13:51:44. | |
cProfile.py | File | 5324 bytes | May 31 2024 13:51:40. | |
calendar.py | File | 22998 bytes | May 31 2024 13:51:44. | |
cgi.py | File | 36046 bytes | May 31 2024 13:51:44. | |
cgitb.py | File | 12023 bytes | May 31 2024 13:51:46. | |
chunk.py | File | 5425 bytes | May 31 2024 13:51:41. | |
cmd.py | File | 14860 bytes | May 31 2024 13:51:40. | |
code.py | File | 10118 bytes | May 31 2024 13:51:40. | |
codecs.py | File | 36231 bytes | May 31 2024 13:51:40. | |
codeop.py | File | 5994 bytes | May 31 2024 13:51:40. | |
colorsys.py | File | 4064 bytes | May 31 2024 13:51:40. | |
compileall.py | File | 11711 bytes | May 31 2024 13:51:40. | |
configparser.py | File | 53452 bytes | May 31 2024 13:51:40. | |
contextlib.py | File | 12451 bytes | May 31 2024 13:51:40. | |
copy.py | File | 8946 bytes | May 31 2024 13:51:40. | |
copyreg.py | File | 6833 bytes | May 31 2024 13:51:44. | |
crypt.py | File | 1879 bytes | May 31 2024 13:51:40. | |
csv.py | File | 16128 bytes | May 31 2024 13:51:40. | |
datetime.py | File | 75899 bytes | May 31 2024 13:51:46. | |
decimal.py | File | 320 bytes | May 31 2024 13:51:44. | |
difflib.py | File | 84204 bytes | May 31 2024 13:51:41. | |
dis.py | File | 17350 bytes | May 31 2024 13:51:40. | |
doctest.py | File | 104036 bytes | May 31 2024 13:51:40. | |
dummy_threading.py | File | 2815 bytes | May 31 2024 13:51:40. | |
enum.py | File | 22226 bytes | May 31 2024 13:51:40. | |
filecmp.py | File | 9830 bytes | May 31 2024 13:51:40. | |
fileinput.py | File | 14259 bytes | May 31 2024 13:51:41. | |
fnmatch.py | File | 3163 bytes | May 31 2024 13:51:40. | |
formatter.py | File | 15143 bytes | May 31 2024 13:51:40. | |
fractions.py | File | 24612 bytes | May 31 2024 13:51:40. | |
ftplib.py | File | 34951 bytes | May 31 2024 13:51:40. | |
functools.py | File | 28944 bytes | May 31 2024 13:51:46. | |
genericpath.py | File | 4364 bytes | May 31 2024 13:51:46. | |
getopt.py | File | 7489 bytes | May 31 2024 13:51:44. | |
getpass.py | File | 5994 bytes | May 31 2024 13:51:40. | |
gettext.py | File | 21530 bytes | May 31 2024 13:51:44. | |
glob.py | File | 5072 bytes | May 31 2024 13:51:40. | |
gzip.py | File | 20260 bytes | May 31 2024 13:51:44. | |
hashlib.py | File | 7979 bytes | May 31 2024 13:51:46. | |
heapq.py | File | 22929 bytes | May 31 2024 13:51:40. | |
hmac.py | File | 5063 bytes | May 31 2024 13:51:41. | |
imaplib.py | File | 52183 bytes | May 31 2024 13:51:44. | |
imghdr.py | File | 3758 bytes | May 31 2024 13:51:44. | |
imp.py | File | 10676 bytes | May 31 2024 13:51:40. | |
inspect.py | File | 114199 bytes | May 31 2024 13:51:43. | |
io.py | File | 3396 bytes | May 31 2024 13:51:40. | |
ipaddress.py | File | 75733 bytes | May 31 2024 13:51:44. | |
keyword.py | File | 2222 bytes | May 31 2024 13:51:44. | |
linecache.py | File | 5312 bytes | May 31 2024 13:51:40. | |
locale.py | File | 74713 bytes | May 31 2024 13:51:44. | |
lzma.py | File | 12925 bytes | May 31 2024 13:51:45. | |
macpath.py | File | 5907 bytes | May 31 2024 13:51:40. | |
macurl2path.py | File | 2732 bytes | May 31 2024 13:51:40. | |
mailbox.py | File | 78418 bytes | May 31 2024 13:51:43. | |
mailcap.py | File | 8104 bytes | May 31 2024 13:51:40. | |
mimetypes.py | File | 20847 bytes | May 31 2024 13:51:44. | |
modulefinder.py | File | 23085 bytes | May 31 2024 13:51:40. | |
netrc.py | File | 5748 bytes | May 31 2024 13:51:41. | |
nntplib.py | File | 43078 bytes | May 31 2024 13:51:40. | |
ntpath.py | File | 22793 bytes | May 31 2024 13:51:40. | |
nturl2path.py | File | 2444 bytes | May 31 2024 13:51:44. | |
numbers.py | File | 10243 bytes | May 31 2024 13:51:45. | |
opcode.py | File | 5885 bytes | May 31 2024 13:51:46. | |
operator.py | File | 10863 bytes | May 31 2024 13:51:44. | |
optparse.py | File | 60344 bytes | May 31 2024 13:51:44. | |
os.py | File | 37033 bytes | May 31 2024 13:51:40. | |
pathlib.py | File | 47001 bytes | May 31 2024 13:51:44. | |
pdb.py | File | 61149 bytes | May 31 2024 13:51:40. | |
pickle.py | File | 56176 bytes | May 31 2024 13:51:41. | |
pickletools.py | File | 91761 bytes | May 31 2024 13:51:40. | |
pipes.py | File | 8916 bytes | May 31 2024 13:51:44. | |
pkgutil.py | File | 21355 bytes | May 31 2024 13:51:40. | |
platform.py | File | 46147 bytes | May 31 2024 13:51:40. | |
plistlib.py | File | 31810 bytes | May 31 2024 13:51:40. | |
poplib.py | File | 14717 bytes | May 31 2024 13:51:40. | |
posixpath.py | File | 14911 bytes | May 31 2024 13:51:40. | |
pprint.py | File | 20860 bytes | May 31 2024 13:51:40. | |
profile.py | File | 22032 bytes | May 31 2024 13:51:41. | |
pstats.py | File | 26564 bytes | May 31 2024 13:51:40. | |
pty.py | File | 4763 bytes | May 31 2024 13:51:40. | |
py_compile.py | File | 7181 bytes | May 31 2024 13:51:44. | |
pyclbr.py | File | 13564 bytes | May 31 2024 13:51:39. | |
pydoc.py | File | 103652 bytes | May 31 2024 13:51:40. | |
queue.py | File | 8780 bytes | May 31 2024 13:51:44. | |
quopri.py | File | 7265 bytes | May 31 2024 13:51:44. | |
random.py | File | 26463 bytes | May 31 2024 13:51:40. | |
re.py | File | 15501 bytes | May 31 2024 13:51:40. | |
reprlib.py | File | 5336 bytes | May 31 2024 13:51:40. | |
rlcompleter.py | File | 6307 bytes | May 31 2024 13:51:46. | |
runpy.py | File | 11959 bytes | May 31 2024 13:51:40. | |
sched.py | File | 6216 bytes | May 31 2024 13:51:44. | |
selectors.py | File | 19438 bytes | May 31 2024 13:51:40. | |
shelve.py | File | 8528 bytes | May 31 2024 13:51:44. | |
shlex.py | File | 11448 bytes | May 31 2024 13:51:46. | |
shutil.py | File | 40048 bytes | May 31 2024 13:51:44. | |
signal.py | File | 2123 bytes | May 31 2024 13:51:44. | |
site.py | File | 21509 bytes | May 31 2024 13:51:43. | |
smtpd.py | File | 35373 bytes | May 31 2024 13:51:40. | |
smtplib.py | File | 43635 bytes | May 31 2024 13:51:40. | |
sndhdr.py | File | 6418 bytes | May 31 2024 13:51:44. | |
socket.py | File | 27135 bytes | May 31 2024 13:51:45. | |
socketserver.py | File | 24666 bytes | May 31 2024 13:51:46. | |
sre_compile.py | File | 18410 bytes | May 31 2024 13:51:40. | |
sre_constants.py | File | 6821 bytes | May 31 2024 13:51:40. | |
sre_parse.py | File | 35117 bytes | May 31 2024 13:51:40. | |
ssl.py | File | 42352 bytes | May 31 2024 13:51:44. | |
stat.py | File | 5038 bytes | May 31 2024 13:51:44. | |
statistics.py | File | 19533 bytes | May 31 2024 13:51:40. | |
string.py | File | 11854 bytes | May 31 2024 13:51:44. | |
stringprep.py | File | 12917 bytes | May 31 2024 13:51:41. | |
struct.py | File | 257 bytes | May 31 2024 13:51:40. | |
subprocess.py | File | 58912 bytes | May 31 2024 13:51:40. | |
sunau.py | File | 18095 bytes | May 31 2024 13:51:40. | |
symbol.py | File | 2106 bytes | May 31 2024 13:51:40. | |
symtable.py | File | 7191 bytes | May 31 2024 13:51:44. | |
sysconfig.py | File | 24462 bytes | May 31 2024 13:51:44. | |
tabnanny.py | File | 11414 bytes | May 31 2024 13:51:44. | |
tarfile.py | File | 93070 bytes | May 31 2024 13:51:40. | |
telnetlib.py | File | 23016 bytes | May 31 2024 13:51:40. | |
tempfile.py | File | 26636 bytes | May 31 2024 13:51:40. | |
textwrap.py | File | 19558 bytes | May 31 2024 13:51:40. | |
this.py | File | 1003 bytes | May 31 2024 13:51:41. | |
threading.py | File | 49027 bytes | May 31 2024 13:51:44. | |
timeit.py | File | 12403 bytes | May 31 2024 13:51:40. | |
token.py | File | 3075 bytes | May 31 2024 13:51:40. | |
tokenize.py | File | 27790 bytes | May 31 2024 13:51:44. | |
trace.py | File | 31553 bytes | May 31 2024 13:51:40. | |
traceback.py | File | 22175 bytes | May 31 2024 13:51:44. | |
tracemalloc.py | File | 15641 bytes | May 31 2024 13:51:44. | |
tty.py | File | 879 bytes | May 31 2024 13:51:40. | |
types.py | File | 8799 bytes | May 31 2024 13:51:40. | |
typing.py | File | 80135 bytes | May 31 2024 13:51:44. | |
uu.py | File | 6766 bytes | May 31 2024 13:51:40. | |
uuid.py | File | 23261 bytes | May 31 2024 13:51:40. | |
warnings.py | File | 15850 bytes | May 31 2024 13:51:40. | |
wave.py | File | 17682 bytes | May 31 2024 13:51:40. | |
weakref.py | File | 20466 bytes | May 31 2024 13:51:44. | |
webbrowser.py | File | 21828 bytes | May 31 2024 13:51:44. | |
xdrlib.py | File | 5913 bytes | May 31 2024 13:51:46. | |
zipapp.py | File | 7157 bytes | May 31 2024 13:51:40. | |
zipfile.py | File | 73672 bytes | May 31 2024 13:51:46. |
# Copyright 2007 Google, Inc. All Rights Reserved. # Licensed to PSF under a Contributor Agreement. """Abstract Base Classes (ABCs) for collections, according to PEP 3119. Unit tests are in test_collections. """ from abc import ABCMeta, abstractmethod import sys __all__ = ["Awaitable", "Coroutine", "AsyncIterable", "AsyncIterator", "Hashable", "Iterable", "Iterator", "Generator", "Sized", "Container", "Callable", "Set", "MutableSet", "Mapping", "MutableMapping", "MappingView", "KeysView", "ItemsView", "ValuesView", "Sequence", "MutableSequence", "ByteString", ] # This module has been renamed from collections.abc to _collections_abc to # speed up interpreter startup. Some of the types such as MutableMapping are # required early but collections module imports a lot of other modules. # See issue #19218 __name__ = "collections.abc" # Private list of types that we want to register with the various ABCs # so that they will pass tests like: # it = iter(somebytearray) # assert isinstance(it, Iterable) # Note: in other implementations, these types might not be distinct # and they may have their own implementation specific types that # are not included on this list. bytes_iterator = type(iter(b'')) bytearray_iterator = type(iter(bytearray())) #callable_iterator = ??? dict_keyiterator = type(iter({}.keys())) dict_valueiterator = type(iter({}.values())) dict_itemiterator = type(iter({}.items())) list_iterator = type(iter([])) list_reverseiterator = type(iter(reversed([]))) range_iterator = type(iter(range(0))) longrange_iterator = type(iter(range(1 << 1000))) set_iterator = type(iter(set())) str_iterator = type(iter("")) tuple_iterator = type(iter(())) zip_iterator = type(iter(zip())) ## views ## dict_keys = type({}.keys()) dict_values = type({}.values()) dict_items = type({}.items()) ## misc ## mappingproxy = type(type.__dict__) generator = type((lambda: (yield))()) ## coroutine ## async def _coro(): pass _coro = _coro() coroutine = type(_coro) _coro.close() # Prevent ResourceWarning del _coro ### ONE-TRICK PONIES ### class Hashable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __hash__(self): return 0 @classmethod def __subclasshook__(cls, C): if cls is Hashable: for B in C.__mro__: if "__hash__" in B.__dict__: if B.__dict__["__hash__"]: return True break return NotImplemented class Awaitable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __await__(self): yield @classmethod def __subclasshook__(cls, C): if cls is Awaitable: for B in C.__mro__: if "__await__" in B.__dict__: if B.__dict__["__await__"]: return True break return NotImplemented class Coroutine(Awaitable): __slots__ = () @abstractmethod def send(self, value): """Send a value into the coroutine. Return next yielded value or raise StopIteration. """ raise StopIteration @abstractmethod def throw(self, typ, val=None, tb=None): """Raise an exception in the coroutine. Return next yielded value or raise StopIteration. """ if val is None: if tb is None: raise typ val = typ() if tb is not None: val = val.with_traceback(tb) raise val def close(self): """Raise GeneratorExit inside coroutine. """ try: self.throw(GeneratorExit) except (GeneratorExit, StopIteration): pass else: raise RuntimeError("coroutine ignored GeneratorExit") @classmethod def __subclasshook__(cls, C): if cls is Coroutine: mro = C.__mro__ for method in ('__await__', 'send', 'throw', 'close'): for base in mro: if method in base.__dict__: break else: return NotImplemented return True return NotImplemented Coroutine.register(coroutine) class AsyncIterable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __aiter__(self): return AsyncIterator() @classmethod def __subclasshook__(cls, C): if cls is AsyncIterable: if any("__aiter__" in B.__dict__ for B in C.__mro__): return True return NotImplemented class AsyncIterator(AsyncIterable): __slots__ = () @abstractmethod async def __anext__(self): """Return the next item or raise StopAsyncIteration when exhausted.""" raise StopAsyncIteration def __aiter__(self): return self @classmethod def __subclasshook__(cls, C): if cls is AsyncIterator: if (any("__anext__" in B.__dict__ for B in C.__mro__) and any("__aiter__" in B.__dict__ for B in C.__mro__)): return True return NotImplemented class Iterable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __iter__(self): while False: yield None @classmethod def __subclasshook__(cls, C): if cls is Iterable: if any("__iter__" in B.__dict__ for B in C.__mro__): return True return NotImplemented class Iterator(Iterable): __slots__ = () @abstractmethod def __next__(self): 'Return the next item from the iterator. When exhausted, raise StopIteration' raise StopIteration def __iter__(self): return self @classmethod def __subclasshook__(cls, C): if cls is Iterator: if (any("__next__" in B.__dict__ for B in C.__mro__) and any("__iter__" in B.__dict__ for B in C.__mro__)): return True return NotImplemented Iterator.register(bytes_iterator) Iterator.register(bytearray_iterator) #Iterator.register(callable_iterator) Iterator.register(dict_keyiterator) Iterator.register(dict_valueiterator) Iterator.register(dict_itemiterator) Iterator.register(list_iterator) Iterator.register(list_reverseiterator) Iterator.register(range_iterator) Iterator.register(longrange_iterator) Iterator.register(set_iterator) Iterator.register(str_iterator) Iterator.register(tuple_iterator) Iterator.register(zip_iterator) class Generator(Iterator): __slots__ = () def __next__(self): """Return the next item from the generator. When exhausted, raise StopIteration. """ return self.send(None) @abstractmethod def send(self, value): """Send a value into the generator. Return next yielded value or raise StopIteration. """ raise StopIteration @abstractmethod def throw(self, typ, val=None, tb=None): """Raise an exception in the generator. Return next yielded value or raise StopIteration. """ if val is None: if tb is None: raise typ val = typ() if tb is not None: val = val.with_traceback(tb) raise val def close(self): """Raise GeneratorExit inside generator. """ try: self.throw(GeneratorExit) except (GeneratorExit, StopIteration): pass else: raise RuntimeError("generator ignored GeneratorExit") @classmethod def __subclasshook__(cls, C): if cls is Generator: mro = C.__mro__ for method in ('__iter__', '__next__', 'send', 'throw', 'close'): for base in mro: if method in base.__dict__: break else: return NotImplemented return True return NotImplemented Generator.register(generator) class Sized(metaclass=ABCMeta): __slots__ = () @abstractmethod def __len__(self): return 0 @classmethod def __subclasshook__(cls, C): if cls is Sized: if any("__len__" in B.__dict__ for B in C.__mro__): return True return NotImplemented class Container(metaclass=ABCMeta): __slots__ = () @abstractmethod def __contains__(self, x): return False @classmethod def __subclasshook__(cls, C): if cls is Container: if any("__contains__" in B.__dict__ for B in C.__mro__): return True return NotImplemented class Callable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __call__(self, *args, **kwds): return False @classmethod def __subclasshook__(cls, C): if cls is Callable: if any("__call__" in B.__dict__ for B in C.__mro__): return True return NotImplemented ### SETS ### class Set(Sized, Iterable, Container): """A set is a finite, iterable container. This class provides concrete generic implementations of all methods except for __contains__, __iter__ and __len__. To override the comparisons (presumably for speed, as the semantics are fixed), redefine __le__ and __ge__, then the other operations will automatically follow suit. """ __slots__ = () def __le__(self, other): if not isinstance(other, Set): return NotImplemented if len(self) > len(other): return False for elem in self: if elem not in other: return False return True def __lt__(self, other): if not isinstance(other, Set): return NotImplemented return len(self) < len(other) and self.__le__(other) def __gt__(self, other): if not isinstance(other, Set): return NotImplemented return len(self) > len(other) and self.__ge__(other) def __ge__(self, other): if not isinstance(other, Set): return NotImplemented if len(self) < len(other): return False for elem in other: if elem not in self: return False return True def __eq__(self, other): if not isinstance(other, Set): return NotImplemented return len(self) == len(other) and self.__le__(other) @classmethod def _from_iterable(cls, it): '''Construct an instance of the class from any iterable input. Must override this method if the class constructor signature does not accept an iterable for an input. ''' return cls(it) def __and__(self, other): if not isinstance(other, Iterable): return NotImplemented return self._from_iterable(value for value in other if value in self) __rand__ = __and__ def isdisjoint(self, other): 'Return True if two sets have a null intersection.' for value in other: if value in self: return False return True def __or__(self, other): if not isinstance(other, Iterable): return NotImplemented chain = (e for s in (self, other) for e in s) return self._from_iterable(chain) __ror__ = __or__ def __sub__(self, other): if not isinstance(other, Set): if not isinstance(other, Iterable): return NotImplemented other = self._from_iterable(other) return self._from_iterable(value for value in self if value not in other) def __rsub__(self, other): if not isinstance(other, Set): if not isinstance(other, Iterable): return NotImplemented other = self._from_iterable(other) return self._from_iterable(value for value in other if value not in self) def __xor__(self, other): if not isinstance(other, Set): if not isinstance(other, Iterable): return NotImplemented other = self._from_iterable(other) return (self - other) | (other - self) __rxor__ = __xor__ def _hash(self): """Compute the hash value of a set. Note that we don't define __hash__: not all sets are hashable. But if you define a hashable set type, its __hash__ should call this function. This must be compatible __eq__. All sets ought to compare equal if they contain the same elements, regardless of how they are implemented, and regardless of the order of the elements; so there's not much freedom for __eq__ or __hash__. We match the algorithm used by the built-in frozenset type. """ MAX = sys.maxsize MASK = 2 * MAX + 1 n = len(self) h = 1927868237 * (n + 1) h &= MASK for x in self: hx = hash(x) h ^= (hx ^ (hx << 16) ^ 89869747) * 3644798167 h &= MASK h = h * 69069 + 907133923 h &= MASK if h > MAX: h -= MASK + 1 if h == -1: h = 590923713 return h Set.register(frozenset) class MutableSet(Set): """A mutable set is a finite, iterable container. This class provides concrete generic implementations of all methods except for __contains__, __iter__, __len__, add(), and discard(). To override the comparisons (presumably for speed, as the semantics are fixed), all you have to do is redefine __le__ and then the other operations will automatically follow suit. """ __slots__ = () @abstractmethod def add(self, value): """Add an element.""" raise NotImplementedError @abstractmethod def discard(self, value): """Remove an element. Do not raise an exception if absent.""" raise NotImplementedError def remove(self, value): """Remove an element. If not a member, raise a KeyError.""" if value not in self: raise KeyError(value) self.discard(value) def pop(self): """Return the popped value. Raise KeyError if empty.""" it = iter(self) try: value = next(it) except StopIteration: raise KeyError self.discard(value) return value def clear(self): """This is slow (creates N new iterators!) but effective.""" try: while True: self.pop() except KeyError: pass def __ior__(self, it): for value in it: self.add(value) return self def __iand__(self, it): for value in (self - it): self.discard(value) return self def __ixor__(self, it): if it is self: self.clear() else: if not isinstance(it, Set): it = self._from_iterable(it) for value in it: if value in self: self.discard(value) else: self.add(value) return self def __isub__(self, it): if it is self: self.clear() else: for value in it: self.discard(value) return self MutableSet.register(set) ### MAPPINGS ### class Mapping(Sized, Iterable, Container): __slots__ = () """A Mapping is a generic container for associating key/value pairs. This class provides concrete generic implementations of all methods except for __getitem__, __iter__, and __len__. """ @abstractmethod def __getitem__(self, key): raise KeyError def get(self, key, default=None): 'D.get(k[,d]) -> D[k] if k in D, else d. d defaults to None.' try: return self[key] except KeyError: return default def __contains__(self, key): try: self[key] except KeyError: return False else: return True def keys(self): "D.keys() -> a set-like object providing a view on D's keys" return KeysView(self) def items(self): "D.items() -> a set-like object providing a view on D's items" return ItemsView(self) def values(self): "D.values() -> an object providing a view on D's values" return ValuesView(self) def __eq__(self, other): if not isinstance(other, Mapping): return NotImplemented return dict(self.items()) == dict(other.items()) Mapping.register(mappingproxy) class MappingView(Sized): __slots__ = '_mapping', def __init__(self, mapping): self._mapping = mapping def __len__(self): return len(self._mapping) def __repr__(self): return '{0.__class__.__name__}({0._mapping!r})'.format(self) class KeysView(MappingView, Set): __slots__ = () @classmethod def _from_iterable(self, it): return set(it) def __contains__(self, key): return key in self._mapping def __iter__(self): yield from self._mapping KeysView.register(dict_keys) class ItemsView(MappingView, Set): __slots__ = () @classmethod def _from_iterable(self, it): return set(it) def __contains__(self, item): key, value = item try: v = self._mapping[key] except KeyError: return False else: return v == value def __iter__(self): for key in self._mapping: yield (key, self._mapping[key]) ItemsView.register(dict_items) class ValuesView(MappingView): __slots__ = () def __contains__(self, value): for key in self._mapping: if value == self._mapping[key]: return True return False def __iter__(self): for key in self._mapping: yield self._mapping[key] ValuesView.register(dict_values) class MutableMapping(Mapping): __slots__ = () """A MutableMapping is a generic container for associating key/value pairs. This class provides concrete generic implementations of all methods except for __getitem__, __setitem__, __delitem__, __iter__, and __len__. """ @abstractmethod def __setitem__(self, key, value): raise KeyError @abstractmethod def __delitem__(self, key): raise KeyError __marker = object() def pop(self, key, default=__marker): '''D.pop(k[,d]) -> v, remove specified key and return the corresponding value. If key is not found, d is returned if given, otherwise KeyError is raised. ''' try: value = self[key] except KeyError: if default is self.__marker: raise return default else: del self[key] return value def popitem(self): '''D.popitem() -> (k, v), remove and return some (key, value) pair as a 2-tuple; but raise KeyError if D is empty. ''' try: key = next(iter(self)) except StopIteration: raise KeyError value = self[key] del self[key] return key, value def clear(self): 'D.clear() -> None. Remove all items from D.' try: while True: self.popitem() except KeyError: pass def update(*args, **kwds): ''' D.update([E, ]**F) -> None. Update D from mapping/iterable E and F. If E present and has a .keys() method, does: for k in E: D[k] = E[k] If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v In either case, this is followed by: for k, v in F.items(): D[k] = v ''' if not args: raise TypeError("descriptor 'update' of 'MutableMapping' object " "needs an argument") self, *args = args if len(args) > 1: raise TypeError('update expected at most 1 arguments, got %d' % len(args)) if args: other = args[0] if isinstance(other, Mapping): for key in other: self[key] = other[key] elif hasattr(other, "keys"): for key in other.keys(): self[key] = other[key] else: for key, value in other: self[key] = value for key, value in kwds.items(): self[key] = value def setdefault(self, key, default=None): 'D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D' try: return self[key] except KeyError: self[key] = default return default MutableMapping.register(dict) ### SEQUENCES ### class Sequence(Sized, Iterable, Container): """All the operations on a read-only sequence. Concrete subclasses must override __new__ or __init__, __getitem__, and __len__. """ __slots__ = () @abstractmethod def __getitem__(self, index): raise IndexError def __iter__(self): i = 0 try: while True: v = self[i] yield v i += 1 except IndexError: return def __contains__(self, value): for v in self: if v == value: return True return False def __reversed__(self): for i in reversed(range(len(self))): yield self[i] def index(self, value, start=0, stop=None): '''S.index(value, [start, [stop]]) -> integer -- return first index of value. Raises ValueError if the value is not present. ''' if start is not None and start < 0: start = max(len(self) + start, 0) if stop is not None and stop < 0: stop += len(self) i = start while stop is None or i < stop: try: if self[i] == value: return i except IndexError: break i += 1 raise ValueError def count(self, value): 'S.count(value) -> integer -- return number of occurrences of value' return sum(1 for v in self if v == value) Sequence.register(tuple) Sequence.register(str) Sequence.register(range) Sequence.register(memoryview) class ByteString(Sequence): """This unifies bytes and bytearray. XXX Should add all their methods. """ __slots__ = () ByteString.register(bytes) ByteString.register(bytearray) class MutableSequence(Sequence): __slots__ = () """All the operations on a read-write sequence. Concrete subclasses must provide __new__ or __init__, __getitem__, __setitem__, __delitem__, __len__, and insert(). """ @abstractmethod def __setitem__(self, index, value): raise IndexError @abstractmethod def __delitem__(self, index): raise IndexError @abstractmethod def insert(self, index, value): 'S.insert(index, value) -- insert value before index' raise IndexError def append(self, value): 'S.append(value) -- append value to the end of the sequence' self.insert(len(self), value) def clear(self): 'S.clear() -> None -- remove all items from S' try: while True: self.pop() except IndexError: pass def reverse(self): 'S.reverse() -- reverse *IN PLACE*' n = len(self) for i in range(n//2): self[i], self[n-i-1] = self[n-i-1], self[i] def extend(self, values): 'S.extend(iterable) -- extend sequence by appending elements from the iterable' for v in values: self.append(v) def pop(self, index=-1): '''S.pop([index]) -> item -- remove and return item at index (default last). Raise IndexError if list is empty or index is out of range. ''' v = self[index] del self[index] return v def remove(self, value): '''S.remove(value) -- remove first occurrence of value. Raise ValueError if the value is not present. ''' del self[self.index(value)] def __iadd__(self, values): self.extend(values) return self MutableSequence.register(list) MutableSequence.register(bytearray) # Multiply inheriting, see ByteString
SILENT KILLER Tool