import attr from trio._util import NoPublicConstructor class TrioInternalError(Exception): """Raised by :func:`run` if we encounter a bug in Trio, or (possibly) a misuse of one of the low-level :mod:`trio.lowlevel` APIs. This should never happen! If you get this error, please file a bug. Unfortunately, if you get this error it also means that all bets are off – Trio doesn't know what is going on and its normal invariants may be void. (For example, we might have "lost track" of a task. Or lost track of all tasks.) Again, though, this shouldn't happen. """ class RunFinishedError(RuntimeError): """Raised by `trio.from_thread.run` and similar functions if the corresponding call to :func:`trio.run` has already finished. """ class WouldBlock(Exception): """Raised by ``X_nowait`` functions if ``X`` would block.""" class Cancelled(BaseException, metaclass=NoPublicConstructor): """Raised by blocking calls if the surrounding scope has been cancelled. You should let this exception propagate, to be caught by the relevant cancel scope. To remind you of this, it inherits from :exc:`BaseException` instead of :exc:`Exception`, just like :exc:`KeyboardInterrupt` and :exc:`SystemExit` do. This means that if you write something like:: try: ... except Exception: ... then this *won't* catch a :exc:`Cancelled` exception. You cannot raise :exc:`Cancelled` yourself. Attempting to do so will produce a :exc:`TypeError`. Use :meth:`cancel_scope.cancel() ` instead. .. note:: In the US it's also common to see this word spelled "canceled", with only one "l". This is a `recent `__ and `US-specific `__ innovation, and even in the US both forms are still commonly used. So for consistency with the rest of the world and with "cancellation" (which always has two "l"s), Trio uses the two "l" spelling everywhere. """ def __str__(self): return "Cancelled" class BusyResourceError(Exception): """Raised when a task attempts to use a resource that some other task is already using, and this would lead to bugs and nonsense. For example, if two tasks try to send data through the same socket at the same time, Trio will raise :class:`BusyResourceError` instead of letting the data get scrambled. """ class ClosedResourceError(Exception): """Raised when attempting to use a resource after it has been closed. Note that "closed" here means that *your* code closed the resource, generally by calling a method with a name like ``close`` or ``aclose``, or by exiting a context manager. If a problem arises elsewhere – for example, because of a network failure, or because a remote peer closed their end of a connection – then that should be indicated by a different exception class, like :exc:`BrokenResourceError` or an :exc:`OSError` subclass. """ class BrokenResourceError(Exception): """Raised when an attempt to use a resource fails due to external circumstances. For example, you might get this if you try to send data on a stream where the remote side has already closed the connection. You *don't* get this error if *you* closed the resource – in that case you get :class:`ClosedResourceError`. This exception's ``__cause__`` attribute will often contain more information about the underlying error. """ class EndOfChannel(Exception): """Raised when trying to receive from a :class:`trio.abc.ReceiveChannel` that has no more data to receive. This is analogous to an "end-of-file" condition, but for channels. """