Source code for returns.pipeline

from typing import ClassVar

from typing_extensions import Protocol

from returns._generated.pipeline.flow import _flow as flow
from returns._generated.pipeline.managed import _managed as managed
from returns._generated.pipeline.pipe import _pipe as pipe


class _HasSuccessAndFailureTypes(Protocol):
    """This protocol enforces container to have a ``.success_type`` field."""

    success_type: ClassVar[type]


[docs]def is_successful(container: _HasSuccessAndFailureTypes) -> bool: """ Determins if a container was successful or not. .. code:: python >>> from returns.maybe import Some, Nothing >>> from returns.result import Failure, Success >>> from returns.io import IOSuccess, IOFailure >>> assert is_successful(Some(1)) >>> assert not is_successful(Nothing) >>> assert is_successful(Success(1)) >>> assert not is_successful(Failure(1)) >>> assert is_successful(IOSuccess(1)) >>> assert not is_successful(IOFailure(1)) This function can work with containers that have ``.success_type`` class field. """ return isinstance(container, container.success_type)