Current Path: > > opt > alt > python37 > lib64 > python3.7 > >
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.7m | 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 | - | - | |
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 | 5101 bytes | April 17 2024 17:36:08. | |
__phello__.foo.py | File | 64 bytes | April 17 2024 17:36:07. | |
_bootlocale.py | File | 1801 bytes | April 17 2024 17:36:03. | |
_collections_abc.py | File | 26424 bytes | April 17 2024 17:36:03. | |
_compat_pickle.py | File | 8749 bytes | April 17 2024 17:36:07. | |
_compression.py | File | 5340 bytes | April 17 2024 17:36:04. | |
_dummy_thread.py | File | 6027 bytes | April 17 2024 17:36:07. | |
_markupbase.py | File | 14598 bytes | April 17 2024 17:36:03. | |
_osx_support.py | File | 19600 bytes | April 17 2024 17:36:07. | |
_py_abc.py | File | 6186 bytes | April 17 2024 17:36:08. | |
_pydecimal.py | File | 228690 bytes | April 17 2024 17:36:03. | |
_pyio.py | File | 91616 bytes | April 17 2024 17:36:04. | |
_sitebuiltins.py | File | 3115 bytes | April 17 2024 17:36:04. | |
_strptime.py | File | 25504 bytes | April 17 2024 17:36:08. | |
_sysconfigdata_dm_linux_x86_64-linux-gnu.py | File | 31329 bytes | April 17 2024 17:36:03. | |
_sysconfigdata_m_linux_x86_64-linux-gnu.py | File | 28600 bytes | April 17 2024 17:36:08. | |
_threading_local.py | File | 7214 bytes | April 17 2024 17:36:03. | |
_weakrefset.py | File | 5679 bytes | April 17 2024 17:36:03. | |
abc.py | File | 5580 bytes | April 17 2024 17:36:03. | |
aifc.py | File | 32814 bytes | April 17 2024 17:36:08. | |
antigravity.py | File | 477 bytes | April 17 2024 17:36:04. | |
argparse.py | File | 95372 bytes | April 17 2024 17:36:07. | |
ast.py | File | 12842 bytes | April 17 2024 17:36:07. | |
asynchat.py | File | 11328 bytes | April 17 2024 17:36:07. | |
asyncore.py | File | 20118 bytes | April 17 2024 17:36:08. | |
base64.py | File | 20393 bytes | April 17 2024 17:36:04. | |
bdb.py | File | 31730 bytes | April 17 2024 17:36:07. | |
binhex.py | File | 13954 bytes | April 17 2024 17:36:03. | |
bisect.py | File | 2557 bytes | April 17 2024 17:36:03. | |
bz2.py | File | 12410 bytes | April 17 2024 17:36:07. | |
cProfile.py | File | 6253 bytes | April 17 2024 17:36:03. | |
calendar.py | File | 24826 bytes | April 17 2024 17:36:07. | |
cgi.py | File | 35050 bytes | April 17 2024 17:36:07. | |
cgitb.py | File | 12018 bytes | April 17 2024 17:36:08. | |
chunk.py | File | 5435 bytes | April 17 2024 17:36:04. | |
cmd.py | File | 14860 bytes | April 17 2024 17:36:03. | |
code.py | File | 10622 bytes | April 17 2024 17:36:04. | |
codecs.py | File | 36615 bytes | April 17 2024 17:36:03. | |
codeop.py | File | 6275 bytes | April 17 2024 17:36:03. | |
colorsys.py | File | 4064 bytes | April 17 2024 17:36:03. | |
compileall.py | File | 13788 bytes | April 17 2024 17:36:03. | |
configparser.py | File | 54283 bytes | April 17 2024 17:36:03. | |
contextlib.py | File | 24763 bytes | April 17 2024 17:36:03. | |
contextvars.py | File | 129 bytes | April 17 2024 17:36:07. | |
copy.py | File | 8856 bytes | April 17 2024 17:36:03. | |
copyreg.py | File | 7017 bytes | April 17 2024 17:36:07. | |
crypt.py | File | 3346 bytes | April 17 2024 17:36:03. | |
csv.py | File | 16180 bytes | April 17 2024 17:36:03. | |
dataclasses.py | File | 49520 bytes | April 17 2024 17:36:07. | |
datetime.py | File | 86544 bytes | April 17 2024 17:36:08. | |
decimal.py | File | 320 bytes | April 17 2024 17:36:07. | |
difflib.py | File | 84393 bytes | April 17 2024 17:36:04. | |
dis.py | File | 19888 bytes | April 17 2024 17:36:03. | |
doctest.py | File | 104560 bytes | April 17 2024 17:36:03. | |
dummy_threading.py | File | 2815 bytes | April 17 2024 17:36:03. | |
enum.py | File | 35043 bytes | April 17 2024 17:36:04. | |
filecmp.py | File | 9830 bytes | April 17 2024 17:36:03. | |
fileinput.py | File | 14625 bytes | April 17 2024 17:36:04. | |
fnmatch.py | File | 4056 bytes | April 17 2024 17:36:03. | |
formatter.py | File | 15143 bytes | April 17 2024 17:36:03. | |
fractions.py | File | 23752 bytes | April 17 2024 17:36:03. | |
ftplib.py | File | 35618 bytes | April 17 2024 17:36:03. | |
functools.py | File | 32932 bytes | April 17 2024 17:36:08. | |
genericpath.py | File | 4912 bytes | April 17 2024 17:36:08. | |
getopt.py | File | 7489 bytes | April 17 2024 17:36:07. | |
getpass.py | File | 5994 bytes | April 17 2024 17:36:03. | |
gettext.py | File | 21967 bytes | April 17 2024 17:36:07. | |
glob.py | File | 5638 bytes | April 17 2024 17:36:03. | |
gzip.py | File | 20637 bytes | April 17 2024 17:36:07. | |
hashlib.py | File | 9534 bytes | April 17 2024 17:36:08. | |
heapq.py | File | 23017 bytes | April 17 2024 17:36:03. | |
hmac.py | File | 6517 bytes | April 17 2024 17:36:04. | |
imaplib.py | File | 53292 bytes | April 17 2024 17:36:07. | |
imghdr.py | File | 3795 bytes | April 17 2024 17:36:07. | |
imp.py | File | 10536 bytes | April 17 2024 17:36:03. | |
inspect.py | File | 117635 bytes | April 17 2024 17:36:07. | |
io.py | File | 3517 bytes | April 17 2024 17:36:03. | |
ipaddress.py | File | 73578 bytes | April 17 2024 17:36:07. | |
keyword.py | File | 2256 bytes | April 17 2024 17:36:07. | |
linecache.py | File | 5330 bytes | April 17 2024 17:36:04. | |
locale.py | File | 78191 bytes | April 17 2024 17:36:07. | |
lzma.py | File | 12983 bytes | April 17 2024 17:36:08. | |
macpath.py | File | 6123 bytes | April 17 2024 17:36:03. | |
mailbox.py | File | 78654 bytes | April 17 2024 17:36:07. | |
mailcap.py | File | 9067 bytes | April 17 2024 17:36:03. | |
mimetypes.py | File | 21496 bytes | April 17 2024 17:36:07. | |
modulefinder.py | File | 23035 bytes | April 17 2024 17:36:03. | |
netrc.py | File | 5566 bytes | April 17 2024 17:36:04. | |
nntplib.py | File | 43087 bytes | April 17 2024 17:36:03. | |
ntpath.py | File | 22340 bytes | April 17 2024 17:36:03. | |
nturl2path.py | File | 2584 bytes | April 17 2024 17:36:07. | |
numbers.py | File | 10244 bytes | April 17 2024 17:36:08. | |
opcode.py | File | 5824 bytes | April 17 2024 17:36:08. | |
operator.py | File | 10863 bytes | April 17 2024 17:36:07. | |
optparse.py | File | 60371 bytes | April 17 2024 17:36:07. | |
os.py | File | 37901 bytes | April 17 2024 17:36:03. | |
pathlib.py | File | 50329 bytes | April 17 2024 17:36:07. | |
pdb.py | File | 62505 bytes | April 17 2024 17:36:04. | |
pickle.py | File | 57994 bytes | April 17 2024 17:36:04. | |
pickletools.py | File | 91220 bytes | April 17 2024 17:36:03. | |
pipes.py | File | 8916 bytes | April 17 2024 17:36:07. | |
pkgutil.py | File | 21461 bytes | April 17 2024 17:36:03. | |
platform.py | File | 46994 bytes | April 17 2024 17:36:03. | |
plistlib.py | File | 30709 bytes | April 17 2024 17:36:03. | |
poplib.py | File | 14964 bytes | April 17 2024 17:36:03. | |
posixpath.py | File | 15771 bytes | April 17 2024 17:36:04. | |
pprint.py | File | 20884 bytes | April 17 2024 17:36:03. | |
profile.py | File | 22494 bytes | April 17 2024 17:36:04. | |
pstats.py | File | 27315 bytes | April 17 2024 17:36:03. | |
pty.py | File | 4763 bytes | April 17 2024 17:36:03. | |
py_compile.py | File | 8001 bytes | April 17 2024 17:36:07. | |
pyclbr.py | File | 15137 bytes | April 17 2024 17:36:03. | |
pydoc.py | File | 105876 bytes | April 17 2024 17:36:03. | |
queue.py | File | 11359 bytes | April 17 2024 17:36:07. | |
quopri.py | File | 7265 bytes | April 17 2024 17:36:07. | |
random.py | File | 27557 bytes | April 17 2024 17:36:03. | |
re.py | File | 15306 bytes | April 17 2024 17:36:04. | |
reprlib.py | File | 5267 bytes | April 17 2024 17:36:03. | |
rlcompleter.py | File | 7097 bytes | April 17 2024 17:36:08. | |
runpy.py | File | 11959 bytes | April 17 2024 17:36:03. | |
sched.py | File | 6442 bytes | April 17 2024 17:36:07. | |
secrets.py | File | 2038 bytes | April 17 2024 17:36:04. | |
selectors.py | File | 18561 bytes | April 17 2024 17:36:03. | |
shelve.py | File | 8527 bytes | April 17 2024 17:36:07. | |
shlex.py | File | 13100 bytes | April 17 2024 17:36:08. | |
shutil.py | File | 41950 bytes | April 17 2024 17:36:07. | |
signal.py | File | 2123 bytes | April 17 2024 17:36:07. | |
site.py | File | 21575 bytes | April 17 2024 17:36:07. | |
smtpd.py | File | 34722 bytes | April 17 2024 17:36:04. | |
smtplib.py | File | 44443 bytes | April 17 2024 17:36:03. | |
sndhdr.py | File | 7086 bytes | April 17 2024 17:36:07. | |
socket.py | File | 27469 bytes | April 17 2024 17:36:08. | |
socketserver.py | File | 26923 bytes | April 17 2024 17:36:08. | |
sre_compile.py | File | 26872 bytes | April 17 2024 17:36:03. | |
sre_constants.py | File | 7177 bytes | April 17 2024 17:36:03. | |
sre_parse.py | File | 39156 bytes | April 17 2024 17:36:04. | |
ssl.py | File | 45495 bytes | April 17 2024 17:36:07. | |
stat.py | File | 5391 bytes | April 17 2024 17:36:07. | |
statistics.py | File | 20651 bytes | April 17 2024 17:36:03. | |
string.py | File | 11564 bytes | April 17 2024 17:36:07. | |
stringprep.py | File | 12917 bytes | April 17 2024 17:36:04. | |
struct.py | File | 257 bytes | April 17 2024 17:36:04. | |
subprocess.py | File | 72649 bytes | April 17 2024 17:36:03. | |
sunau.py | File | 18375 bytes | April 17 2024 17:36:03. | |
symbol.py | File | 2142 bytes | April 17 2024 17:36:03. | |
symtable.py | File | 7279 bytes | April 17 2024 17:36:07. | |
sysconfig.py | File | 24440 bytes | April 17 2024 17:36:07. | |
tabnanny.py | File | 11419 bytes | April 17 2024 17:36:07. | |
tarfile.py | File | 92675 bytes | April 17 2024 17:36:03. | |
telnetlib.py | File | 23135 bytes | April 17 2024 17:36:03. | |
tempfile.py | File | 26730 bytes | April 17 2024 17:36:03. | |
textwrap.py | File | 19407 bytes | April 17 2024 17:36:03. | |
this.py | File | 1003 bytes | April 17 2024 17:36:04. | |
threading.py | File | 49284 bytes | April 17 2024 17:36:07. | |
timeit.py | File | 13493 bytes | April 17 2024 17:36:03. | |
token.py | File | 3763 bytes | April 17 2024 17:36:03. | |
tokenize.py | File | 27031 bytes | April 17 2024 17:36:07. | |
trace.py | File | 28903 bytes | April 17 2024 17:36:03. | |
traceback.py | File | 23437 bytes | April 17 2024 17:36:07. | |
tracemalloc.py | File | 17076 bytes | April 17 2024 17:36:07. | |
tty.py | File | 879 bytes | April 17 2024 17:36:03. | |
types.py | File | 9897 bytes | April 17 2024 17:36:03. | |
typing.py | File | 56438 bytes | April 17 2024 17:36:07. | |
uu.py | File | 7277 bytes | April 17 2024 17:36:03. | |
uuid.py | File | 29518 bytes | April 17 2024 17:36:03. | |
warnings.py | File | 20080 bytes | April 17 2024 17:36:03. | |
wave.py | File | 18230 bytes | April 17 2024 17:36:03. | |
weakref.py | File | 21508 bytes | April 17 2024 17:36:07. | |
webbrowser.py | File | 23715 bytes | April 17 2024 17:36:07. | |
xdrlib.py | File | 5913 bytes | April 17 2024 17:36:08. | |
zipapp.py | File | 7535 bytes | April 17 2024 17:36:03. | |
zipfile.py | File | 81094 bytes | April 17 2024 17:36:08. |
# 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", "AsyncGenerator", "Hashable", "Iterable", "Iterator", "Generator", "Reversible", "Sized", "Container", "Callable", "Collection", "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 ## asynchronous generator ## async def _ag(): yield _ag = _ag() async_generator = type(_ag) del _ag ### ONE-TRICK PONIES ### def _check_methods(C, *methods): mro = C.__mro__ for method in methods: for B in mro: if method in B.__dict__: if B.__dict__[method] is None: return NotImplemented break else: return NotImplemented return True class Hashable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __hash__(self): return 0 @classmethod def __subclasshook__(cls, C): if cls is Hashable: return _check_methods(C, "__hash__") return NotImplemented class Awaitable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __await__(self): yield @classmethod def __subclasshook__(cls, C): if cls is Awaitable: return _check_methods(C, "__await__") 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: return _check_methods(C, '__await__', 'send', 'throw', 'close') 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: return _check_methods(C, "__aiter__") 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: return _check_methods(C, "__anext__", "__aiter__") return NotImplemented class AsyncGenerator(AsyncIterator): __slots__ = () async def __anext__(self): """Return the next item from the asynchronous generator. When exhausted, raise StopAsyncIteration. """ return await self.asend(None) @abstractmethod async def asend(self, value): """Send a value into the asynchronous generator. Return next yielded value or raise StopAsyncIteration. """ raise StopAsyncIteration @abstractmethod async def athrow(self, typ, val=None, tb=None): """Raise an exception in the asynchronous generator. Return next yielded value or raise StopAsyncIteration. """ if val is None: if tb is None: raise typ val = typ() if tb is not None: val = val.with_traceback(tb) raise val async def aclose(self): """Raise GeneratorExit inside coroutine. """ try: await self.athrow(GeneratorExit) except (GeneratorExit, StopAsyncIteration): pass else: raise RuntimeError("asynchronous generator ignored GeneratorExit") @classmethod def __subclasshook__(cls, C): if cls is AsyncGenerator: return _check_methods(C, '__aiter__', '__anext__', 'asend', 'athrow', 'aclose') return NotImplemented AsyncGenerator.register(async_generator) class Iterable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __iter__(self): while False: yield None @classmethod def __subclasshook__(cls, C): if cls is Iterable: return _check_methods(C, "__iter__") 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: return _check_methods(C, '__iter__', '__next__') 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 Reversible(Iterable): __slots__ = () @abstractmethod def __reversed__(self): while False: yield None @classmethod def __subclasshook__(cls, C): if cls is Reversible: return _check_methods(C, "__reversed__", "__iter__") return NotImplemented 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: return _check_methods(C, '__iter__', '__next__', 'send', 'throw', 'close') 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: return _check_methods(C, "__len__") return NotImplemented class Container(metaclass=ABCMeta): __slots__ = () @abstractmethod def __contains__(self, x): return False @classmethod def __subclasshook__(cls, C): if cls is Container: return _check_methods(C, "__contains__") return NotImplemented class Collection(Sized, Iterable, Container): __slots__ = () @classmethod def __subclasshook__(cls, C): if cls is Collection: return _check_methods(C, "__len__", "__iter__", "__contains__") return NotImplemented class Callable(metaclass=ABCMeta): __slots__ = () @abstractmethod def __call__(self, *args, **kwds): return False @classmethod def __subclasshook__(cls, C): if cls is Callable: return _check_methods(C, "__call__") return NotImplemented ### SETS ### class Set(Collection): """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 from None 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(Collection): __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()) __reversed__ = None 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 is value or v == value def __iter__(self): for key in self._mapping: yield (key, self._mapping[key]) ItemsView.register(dict_items) class ValuesView(MappingView, Collection): __slots__ = () def __contains__(self, value): for key in self._mapping: v = self._mapping[key] if v is value or v == value: 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 from None 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(Reversible, Collection): """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 is value or 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. Supporting start and stop arguments is optional, but recommended. ''' 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: v = self[i] if v is value or v == 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 is value or 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