Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /opt/alt/python34/lib64/python3.4/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python34/lib64/python3.4/contextlib.py
"""Utilities for with-statement contexts.  See PEP 343."""

import sys
from collections import deque
from functools import wraps

__all__ = ["contextmanager", "closing", "ContextDecorator", "ExitStack",
           "redirect_stdout", "suppress"]


class ContextDecorator(object):
    "A base class or mixin that enables context managers to work as decorators."

    def _recreate_cm(self):
        """Return a recreated instance of self.

        Allows an otherwise one-shot context manager like
        _GeneratorContextManager to support use as
        a decorator via implicit recreation.

        This is a private interface just for _GeneratorContextManager.
        See issue #11647 for details.
        """
        return self

    def __call__(self, func):
        @wraps(func)
        def inner(*args, **kwds):
            with self._recreate_cm():
                return func(*args, **kwds)
        return inner


class _GeneratorContextManager(ContextDecorator):
    """Helper for @contextmanager decorator."""

    def __init__(self, func, args, kwds):
        self.gen = func(*args, **kwds)
        self.func, self.args, self.kwds = func, args, kwds
        # Issue 19330: ensure context manager instances have good docstrings
        doc = getattr(func, "__doc__", None)
        if doc is None:
            doc = type(self).__doc__
        self.__doc__ = doc
        # Unfortunately, this still doesn't provide good help output when
        # inspecting the created context manager instances, since pydoc
        # currently bypasses the instance docstring and shows the docstring
        # for the class instead.
        # See http://bugs.python.org/issue19404 for more details.

    def _recreate_cm(self):
        # _GCM instances are one-shot context managers, so the
        # CM must be recreated each time a decorated function is
        # called
        return self.__class__(self.func, self.args, self.kwds)

    def __enter__(self):
        try:
            return next(self.gen)
        except StopIteration:
            raise RuntimeError("generator didn't yield") from None

    def __exit__(self, type, value, traceback):
        if type is None:
            try:
                next(self.gen)
            except StopIteration:
                return
            else:
                raise RuntimeError("generator didn't stop")
        else:
            if value is None:
                # Need to force instantiation so we can reliably
                # tell if we get the same exception back
                value = type()
            try:
                self.gen.throw(type, value, traceback)
                raise RuntimeError("generator didn't stop after throw()")
            except StopIteration as exc:
                # Suppress the exception *unless* it's the same exception that
                # was passed to throw().  This prevents a StopIteration
                # raised inside the "with" statement from being suppressed
                return exc is not value
            except:
                # only re-raise if it's *not* the exception that was
                # passed to throw(), because __exit__() must not raise
                # an exception unless __exit__() itself failed.  But throw()
                # has to raise the exception to signal propagation, so this
                # fixes the impedance mismatch between the throw() protocol
                # and the __exit__() protocol.
                #
                if sys.exc_info()[1] is not value:
                    raise


def contextmanager(func):
    """@contextmanager decorator.

    Typical usage:

        @contextmanager
        def some_generator(<arguments>):
            <setup>
            try:
                yield <value>
            finally:
                <cleanup>

    This makes this:

        with some_generator(<arguments>) as <variable>:
            <body>

    equivalent to this:

        <setup>
        try:
            <variable> = <value>
            <body>
        finally:
            <cleanup>

    """
    @wraps(func)
    def helper(*args, **kwds):
        return _GeneratorContextManager(func, args, kwds)
    return helper


class closing(object):
    """Context to automatically close something at the end of a block.

    Code like this:

        with closing(<module>.open(<arguments>)) as f:
            <block>

    is equivalent to this:

        f = <module>.open(<arguments>)
        try:
            <block>
        finally:
            f.close()

    """
    def __init__(self, thing):
        self.thing = thing
    def __enter__(self):
        return self.thing
    def __exit__(self, *exc_info):
        self.thing.close()

class redirect_stdout:
    """Context manager for temporarily redirecting stdout to another file

        # How to send help() to stderr
        with redirect_stdout(sys.stderr):
            help(dir)

        # How to write help() to a file
        with open('help.txt', 'w') as f:
            with redirect_stdout(f):
                help(pow)
    """

    def __init__(self, new_target):
        self._new_target = new_target
        # We use a list of old targets to make this CM re-entrant
        self._old_targets = []

    def __enter__(self):
        self._old_targets.append(sys.stdout)
        sys.stdout = self._new_target
        return self._new_target

    def __exit__(self, exctype, excinst, exctb):
        sys.stdout = self._old_targets.pop()


class suppress:
    """Context manager to suppress specified exceptions

    After the exception is suppressed, execution proceeds with the next
    statement following the with statement.

         with suppress(FileNotFoundError):
             os.remove(somefile)
         # Execution still resumes here if the file was already removed
    """

    def __init__(self, *exceptions):
        self._exceptions = exceptions

    def __enter__(self):
        pass

    def __exit__(self, exctype, excinst, exctb):
        # Unlike isinstance and issubclass, CPython exception handling
        # currently only looks at the concrete type hierarchy (ignoring
        # the instance and subclass checking hooks). While Guido considers
        # that a bug rather than a feature, it's a fairly hard one to fix
        # due to various internal implementation details. suppress provides
        # the simpler issubclass based semantics, rather than trying to
        # exactly reproduce the limitations of the CPython interpreter.
        #
        # See http://bugs.python.org/issue12029 for more details
        return exctype is not None and issubclass(exctype, self._exceptions)


# Inspired by discussions on http://bugs.python.org/issue13585
class ExitStack(object):
    """Context manager for dynamic management of a stack of exit callbacks

    For example:

        with ExitStack() as stack:
            files = [stack.enter_context(open(fname)) for fname in filenames]
            # All opened files will automatically be closed at the end of
            # the with statement, even if attempts to open files later
            # in the list raise an exception

    """
    def __init__(self):
        self._exit_callbacks = deque()

    def pop_all(self):
        """Preserve the context stack by transferring it to a new instance"""
        new_stack = type(self)()
        new_stack._exit_callbacks = self._exit_callbacks
        self._exit_callbacks = deque()
        return new_stack

    def _push_cm_exit(self, cm, cm_exit):
        """Helper to correctly register callbacks to __exit__ methods"""
        def _exit_wrapper(*exc_details):
            return cm_exit(cm, *exc_details)
        _exit_wrapper.__self__ = cm
        self.push(_exit_wrapper)

    def push(self, exit):
        """Registers a callback with the standard __exit__ method signature

        Can suppress exceptions the same way __exit__ methods can.

        Also accepts any object with an __exit__ method (registering a call
        to the method instead of the object itself)
        """
        # We use an unbound method rather than a bound method to follow
        # the standard lookup behaviour for special methods
        _cb_type = type(exit)
        try:
            exit_method = _cb_type.__exit__
        except AttributeError:
            # Not a context manager, so assume its a callable
            self._exit_callbacks.append(exit)
        else:
            self._push_cm_exit(exit, exit_method)
        return exit # Allow use as a decorator

    def callback(self, callback, *args, **kwds):
        """Registers an arbitrary callback and arguments.

        Cannot suppress exceptions.
        """
        def _exit_wrapper(exc_type, exc, tb):
            callback(*args, **kwds)
        # We changed the signature, so using @wraps is not appropriate, but
        # setting __wrapped__ may still help with introspection
        _exit_wrapper.__wrapped__ = callback
        self.push(_exit_wrapper)
        return callback # Allow use as a decorator

    def enter_context(self, cm):
        """Enters the supplied context manager

        If successful, also pushes its __exit__ method as a callback and
        returns the result of the __enter__ method.
        """
        # We look up the special methods on the type to match the with statement
        _cm_type = type(cm)
        _exit = _cm_type.__exit__
        result = _cm_type.__enter__(cm)
        self._push_cm_exit(cm, _exit)
        return result

    def close(self):
        """Immediately unwind the context stack"""
        self.__exit__(None, None, None)

    def __enter__(self):
        return self

    def __exit__(self, *exc_details):
        received_exc = exc_details[0] is not None

        # We manipulate the exception state so it behaves as though
        # we were actually nesting multiple with statements
        frame_exc = sys.exc_info()[1]
        def _fix_exception_context(new_exc, old_exc):
            # Context may not be correct, so find the end of the chain
            while 1:
                exc_context = new_exc.__context__
                if exc_context is old_exc:
                    # Context is already set correctly (see issue 20317)
                    return
                if exc_context is None or exc_context is frame_exc:
                    break
                new_exc = exc_context
            # Change the end of the chain to point to the exception
            # we expect it to reference
            new_exc.__context__ = old_exc

        # Callbacks are invoked in LIFO order to match the behaviour of
        # nested context managers
        suppressed_exc = False
        pending_raise = False
        while self._exit_callbacks:
            cb = self._exit_callbacks.pop()
            try:
                if cb(*exc_details):
                    suppressed_exc = True
                    pending_raise = False
                    exc_details = (None, None, None)
            except:
                new_exc_details = sys.exc_info()
                # simulate the stack of exceptions by setting the context
                _fix_exception_context(new_exc_details[1], exc_details[1])
                pending_raise = True
                exc_details = new_exc_details
        if pending_raise:
            try:
                # bare "raise exc_details[1]" replaces our carefully
                # set-up context
                fixed_ctx = exc_details[1].__context__
                raise exc_details[1]
            except BaseException:
                exc_details[1].__context__ = fixed_ctx
                raise
        return received_exc and suppressed_exc
Name
Size
Permissions
Options
__pycache__
--
drwxr-xr-x
asyncio
--
drwxr-xr-x
collections
--
drwxr-xr-x
concurrent
--
drwxr-xr-x
config-3.4m
--
drwxr-xr-x
ctypes
--
drwxr-xr-x
curses
--
drwxr-xr-x
dbm
--
drwxr-xr-x
distutils
--
drwxr-xr-x
email
--
drwxr-xr-x
encodings
--
drwxr-xr-x
ensurepip
--
drwxr-xr-x
html
--
drwxr-xr-x
http
--
drwxr-xr-x
idlelib
--
drwxr-xr-x
importlib
--
drwxr-xr-x
json
--
drwxr-xr-x
lib-dynload
--
drwxr-xr-x
lib2to3
--
drwxr-xr-x
logging
--
drwxr-xr-x
multiprocessing
--
drwxr-xr-x
plat-linux
--
drwxr-xr-x
pydoc_data
--
drwxr-xr-x
site-packages
--
drwxr-xr-x
sqlite3
--
drwxr-xr-x
test
--
drwxr-xr-x
unittest
--
drwxr-xr-x
urllib
--
drwxr-xr-x
venv
--
drwxr-xr-x
wsgiref
--
drwxr-xr-x
xml
--
drwxr-xr-x
xmlrpc
--
drwxr-xr-x
__future__.py
4.477 KB
-rw-r--r--
__phello__.foo.py
0.063 KB
-rw-r--r--
_bootlocale.py
1.271 KB
-rw-r--r--
_collections_abc.py
19.432 KB
-rw-r--r--
_compat_pickle.py
8.123 KB
-rw-r--r--
_dummy_thread.py
4.758 KB
-rw-r--r--
_markupbase.py
14.256 KB
-rw-r--r--
_osx_support.py
18.653 KB
-rw-r--r--
_pyio.py
72.161 KB
-rw-r--r--
_sitebuiltins.py
3.042 KB
-rw-r--r--
_strptime.py
21.536 KB
-rw-r--r--
_sysconfigdata.py
28.055 KB
-rw-r--r--
_threading_local.py
7.236 KB
-rw-r--r--
_weakrefset.py
5.571 KB
-rw-r--r--
abc.py
8.422 KB
-rw-r--r--
aifc.py
30.838 KB
-rw-r--r--
antigravity.py
0.464 KB
-rw-r--r--
argparse.py
87.917 KB
-rw-r--r--
ast.py
11.752 KB
-rw-r--r--
asynchat.py
11.548 KB
-rw-r--r--
asyncore.py
20.506 KB
-rw-r--r--
base64.py
19.707 KB
-rwxr-xr-x
bdb.py
22.807 KB
-rw-r--r--
binhex.py
13.602 KB
-rw-r--r--
bisect.py
2.534 KB
-rw-r--r--
bz2.py
18.418 KB
-rw-r--r--
cProfile.py
5.199 KB
-rwxr-xr-x
calendar.py
22.403 KB
-rw-r--r--
cgi.py
35.099 KB
-rwxr-xr-x
cgitb.py
11.759 KB
-rw-r--r--
chunk.py
5.298 KB
-rw-r--r--
cmd.py
14.512 KB
-rw-r--r--
code.py
9.802 KB
-rw-r--r--
codecs.py
35.068 KB
-rw-r--r--
codeop.py
5.854 KB
-rw-r--r--
colorsys.py
3.969 KB
-rw-r--r--
compileall.py
9.393 KB
-rw-r--r--
configparser.py
48.533 KB
-rw-r--r--
contextlib.py
11.366 KB
-rw-r--r--
copy.py
8.794 KB
-rw-r--r--
copyreg.py
6.673 KB
-rw-r--r--
crypt.py
1.835 KB
-rw-r--r--
csv.py
15.806 KB
-rw-r--r--
datetime.py
74.027 KB
-rw-r--r--
decimal.py
223.328 KB
-rw-r--r--
difflib.py
79.77 KB
-rw-r--r--
dis.py
16.758 KB
-rw-r--r--
doctest.py
102.043 KB
-rw-r--r--
dummy_threading.py
2.749 KB
-rw-r--r--
enum.py
21.033 KB
-rw-r--r--
filecmp.py
9.6 KB
-rw-r--r--
fileinput.py
14.517 KB
-rw-r--r--
fnmatch.py
3.089 KB
-rw-r--r--
formatter.py
14.817 KB
-rw-r--r--
fractions.py
22.659 KB
-rw-r--r--
ftplib.py
37.629 KB
-rw-r--r--
functools.py
27.843 KB
-rw-r--r--
genericpath.py
3.791 KB
-rw-r--r--
getopt.py
7.313 KB
-rw-r--r--
getpass.py
5.927 KB
-rw-r--r--
gettext.py
20.28 KB
-rw-r--r--
glob.py
3.38 KB
-rw-r--r--
gzip.py
23.744 KB
-rw-r--r--
hashlib.py
9.619 KB
-rw-r--r--
heapq.py
17.575 KB
-rw-r--r--
hmac.py
4.944 KB
-rw-r--r--
imaplib.py
49.089 KB
-rw-r--r--
imghdr.py
3.445 KB
-rw-r--r--
imp.py
9.75 KB
-rw-r--r--
inspect.py
102.188 KB
-rw-r--r--
io.py
3.316 KB
-rw-r--r--
ipaddress.py
69.92 KB
-rw-r--r--
keyword.py
2.17 KB
-rwxr-xr-x
linecache.py
3.86 KB
-rw-r--r--
locale.py
72.783 KB
-rw-r--r--
lzma.py
18.917 KB
-rw-r--r--
macpath.py
5.487 KB
-rw-r--r--
macurl2path.py
2.668 KB
-rw-r--r--
mailbox.py
76.545 KB
-rw-r--r--
mailcap.py
7.263 KB
-rw-r--r--
mimetypes.py
20.294 KB
-rw-r--r--
modulefinder.py
22.872 KB
-rw-r--r--
netrc.py
5.613 KB
-rw-r--r--
nntplib.py
42.072 KB
-rw-r--r--
ntpath.py
19.997 KB
-rw-r--r--
nturl2path.py
2.387 KB
-rw-r--r--
numbers.py
10.003 KB
-rw-r--r--
opcode.py
5.314 KB
-rw-r--r--
operator.py
8.979 KB
-rw-r--r--
optparse.py
58.932 KB
-rw-r--r--
os.py
33.088 KB
-rw-r--r--
pathlib.py
41.472 KB
-rw-r--r--
pdb.py
59.563 KB
-rwxr-xr-x
pickle.py
54.677 KB
-rw-r--r--
pickletools.py
89.611 KB
-rw-r--r--
pipes.py
8.707 KB
-rw-r--r--
pkgutil.py
20.718 KB
-rw-r--r--
platform.py
45.665 KB
-rwxr-xr-x
plistlib.py
31.046 KB
-rw-r--r--
poplib.py
13.983 KB
-rw-r--r--
posixpath.py
13.133 KB
-rw-r--r--
pprint.py
14.569 KB
-rw-r--r--
profile.py
21.516 KB
-rwxr-xr-x
pstats.py
25.699 KB
-rw-r--r--
pty.py
4.651 KB
-rw-r--r--
py_compile.py
6.937 KB
-rw-r--r--
pyclbr.py
13.203 KB
-rw-r--r--
pydoc.py
100.597 KB
-rwxr-xr-x
queue.py
8.628 KB
-rw-r--r--
quopri.py
7.095 KB
-rwxr-xr-x
random.py
25.473 KB
-rw-r--r--
re.py
15.238 KB
-rw-r--r--
reprlib.py
4.99 KB
-rw-r--r--
rlcompleter.py
5.927 KB
-rw-r--r--
runpy.py
10.563 KB
-rw-r--r--
sched.py
6.205 KB
-rw-r--r--
selectors.py
16.696 KB
-rw-r--r--
shelve.py
8.328 KB
-rw-r--r--
shlex.py
11.277 KB
-rw-r--r--
shutil.py
38.967 KB
-rw-r--r--
site.py
21.048 KB
-rw-r--r--
smtpd.py
29.288 KB
-rwxr-xr-x
smtplib.py
38.058 KB
-rwxr-xr-x
sndhdr.py
6.109 KB
-rw-r--r--
socket.py
18.62 KB
-rw-r--r--
socketserver.py
23.801 KB
-rw-r--r--
sre_compile.py
19.437 KB
-rw-r--r--
sre_constants.py
7.097 KB
-rw-r--r--
sre_parse.py
30.692 KB
-rw-r--r--
ssl.py
33.933 KB
-rw-r--r--
stat.py
4.297 KB
-rw-r--r--
statistics.py
19.098 KB
-rw-r--r--
string.py
11.177 KB
-rw-r--r--
stringprep.py
12.614 KB
-rw-r--r--
struct.py
0.251 KB
-rw-r--r--
subprocess.py
63.036 KB
-rw-r--r--
sunau.py
17.671 KB
-rw-r--r--
symbol.py
2.005 KB
-rwxr-xr-x
symtable.py
7.23 KB
-rw-r--r--
sysconfig.py
24.055 KB
-rw-r--r--
tabnanny.py
11.143 KB
-rwxr-xr-x
tarfile.py
89.411 KB
-rwxr-xr-x
telnetlib.py
22.533 KB
-rw-r--r--
tempfile.py
21.997 KB
-rw-r--r--
textwrap.py
18.83 KB
-rw-r--r--
this.py
0.979 KB
-rw-r--r--
threading.py
47.658 KB
-rw-r--r--
timeit.py
11.691 KB
-rwxr-xr-x
token.py
2.963 KB
-rw-r--r--
tokenize.py
24.996 KB
-rw-r--r--
trace.py
30.749 KB
-rwxr-xr-x
traceback.py
10.905 KB
-rw-r--r--
tracemalloc.py
15.284 KB
-rw-r--r--
tty.py
0.858 KB
-rw-r--r--
types.py
5.284 KB
-rw-r--r--
uu.py
6.607 KB
-rwxr-xr-x
uuid.py
23.168 KB
-rw-r--r--
warnings.py
13.968 KB
-rw-r--r--
wave.py
17.268 KB
-rw-r--r--
weakref.py
18.93 KB
-rw-r--r--
webbrowser.py
20.93 KB
-rwxr-xr-x
xdrlib.py
5.774 KB
-rw-r--r--
zipfile.py
66.94 KB
-rw-r--r--