Module rusty_results.prelude

Functions

def option_from(value: Optional[~T]) ‑> Union[Some[~T], Empty]

:param value: Value from any type to be converted to an Option :return: The value wrapped in an Option or the original Option if it is already an Option

Classes

class Empty

Empty()

Expand source code
@dataclass(eq=True, frozen=True)
class Empty(OptionProtocol):
    @property
    def is_some(self) -> bool:
        return False

    @property
    def is_empty(self) -> bool:
        return True

    def contains(self, item: T) -> bool:
        return False

    def expects(self, msg: str) -> T:
        raise UnwrapException(msg)

    def unwrap(self) -> T:
        raise UnwrapException("Tried to unwrap on an Empty value")

    def unwrap_or(self, default: T) -> T:
        return default

    def unwrap_or_else(self, f: Callable[[], T]) -> T:
        return f()

    def map(self, f: Callable[[T], U]) -> "Option[U]":
        return self

    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        return default

    def map_or_else(self, default: Callable[[], U], f: Callable[[T], U]) -> U:
        return default()

    def iter(self) -> Iterator[T]:
        return iter([])

    def filter(self, predicate: Callable[[T], bool]) -> "Option[T]":
        return self

    def ok_or(self, err: E) -> "Result[T, E]":
        return Err(err)

    def ok_or_else(self, err: Callable[[], E]) -> "Result[T, E]":
        return Err(err())

    def and_then(self, f: Callable[[T], "Option[T]"]) -> "Option[T]":
        return self

    def or_else(self, f: Callable[[], "Option[T]"]) -> "Option[T]":
        return f()

    def xor(self, optb: "Option[T]") -> "Option[T]":
        return optb if optb.is_some else Empty()

    def zip(self, value: "Option[U]") -> "Option[Tuple[T, U]]":
        return Empty()

    def zip_with(self, other: "Option[U]", f: Callable[[Tuple[T, U]], R]) -> "Option[R]":
        return Empty()

    def expect_empty(self, msg: str):
        ...

    def unwrap_empty(self):
        ...

    def flatten_one(self) -> "Option[T]":
        return self

    def flatten(self) -> "Option[T]":
        return self

    def transpose(self) -> "Result[Option[T], E]":
        return Ok(self)

    def early_return(self) -> T:
        raise EarlyReturnException(self)

    def __bool__(self) -> bool:
        return False

    @classmethod
    def __get_validators__(cls):
        yield from OptionProtocol.__get_validators__()

Ancestors

Inherited members

class Err (Error: ~E)

Err(Error: ~E)

Expand source code
@dataclass(eq=True, frozen=True)
class Err(ResultProtocol[T, E]):
    Error: E

    @property
    def is_ok(self) -> bool:
        return False

    @property
    def is_err(self) -> bool:
        return True

    def contains(self, value: T) -> bool:
        return False

    def contains_err(self, err: E) -> bool:
        return self.Error == err

    def ok(self) -> Option:
        return Empty()

    def err(self) -> Option:
        return Some(self.Error)

    def map(self, f: Callable[[T], U]) -> "Result[U, E]":
        # Type ignored here. In this case U is the same type as T, but mypy cannot understand that match.
        return self  # type: ignore

    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        return default

    def map_or_else(self, default: Callable[[E], U], f: Callable[[T], U]) -> U:
        return default(self.Error)

    def map_err(self, f: Callable[[E], U]) -> "Result[T, U]":
        return Err(f(self.Error))

    def iter(self) -> Iterator[T]:
        return iter(tuple())

    def and_then(self, op: Callable[[T], "Result[U, E]"]) -> "Result[U, E]":
        # Type ignored here. In this case U is the same type as T, but mypy cannot understand that match.
        return self  # type: ignore

    def or_else(self, op: Callable[[E], U]) -> "Result[T, U]":
        return Err(op(self.Error))

    def unwrap(self) -> T:
        raise UnwrapException(self.Error)

    def unwrap_or(self, default: T) -> T:
        return default

    def unwrap_or_else(self, default: Callable[[], T]) -> T:
        return default()

    def expect(self, msg: str) -> T:
        raise UnwrapException(msg)

    def unwrap_err(self) -> E:
        return self.Error

    def expect_err(self, msg: str) -> E:
        return self.Error

    def flatten_one(self) -> "Result[T, E]":
        return self

    def flatten(self) -> "Result[T, E]":
        return self

    def transpose(self) -> Option["Result[T, E]"]:
        return Some(self)

    def early_return(self) -> T:
        raise EarlyReturnException(self)

    def __repr__(self):
        return f"Err({self.Error})"

    def __bool__(self):
        return False

    @classmethod
    def __get_validators__(cls):
        yield from ResultProtocol.__get_validators__()

Ancestors

Class variables

var Error : ~E

Inherited members

class Ok (Ok: ~T)

Ok(Ok: ~T)

Expand source code
@dataclass(eq=True, frozen=True)
class Ok(ResultProtocol[T, E]):
    Ok: T

    @property
    def is_ok(self) -> bool:
        return True

    @property
    def is_err(self) -> bool:
        return False

    def contains(self, value: T) -> bool:
        return self.Ok == value

    def contains_err(self, err: E) -> bool:
        return False

    def ok(self) -> Option[T]:
        return Some(self.Ok)

    def err(self) -> Option[E]:
        return Empty()

    def map(self, f: Callable[[T], U]) -> "Result[U, E]":
        return Ok(f(self.Ok))

    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        return f(self.Ok)

    def map_or_else(self, default: Callable[[E], U], f: Callable[[T], U]) -> U:
        return f(self.Ok)

    def map_err(self, f: Callable[[E], U]) -> "Result[T, U]":
        # Type ignored here. It complains that we do not transform error to U (E -> U)
        # since we do not really have an error, generic type remains the same.
        return self  # type: ignore

    def iter(self) -> Iterator[T]:
        def _iter():
            yield self.Ok
        return iter(_iter())

    def and_then(self, op: Callable[[T], "Result[U, E]"]) -> "Result[U, E]":
        return op(self.Ok)

    def or_else(self, op: Callable[[E], U]) -> "Result[T, U]":
        # Type ignored here. It complains that we do not transform error to U (E -> U)
        # since we do not really have an error, generic type remains the same.
        return self  # type: ignore

    def unwrap(self) -> T:
        return self.Ok

    def unwrap_or(self, default: T) -> T:
        return self.Ok

    def unwrap_or_else(self, default: Callable[[], T]) -> T:
        return self.Ok

    def expect(self, msg: str) -> T:
        return self.Ok

    def unwrap_err(self) -> E:
        raise UnwrapException(f"{self.Ok}")

    def expect_err(self, msg: str) -> E:
        raise UnwrapException(msg)

    def flatten_one(self) -> "Result[T, E]":
        if isinstance(self.Ok, ResultProtocol):
            return cast(Result, self.unwrap())
        return self

    def flatten(self) -> "Result[T, E]":
        this: Result[T, E] = self
        inner: Result[T, E] = self.flatten_one()
        while inner is not this:
            this, inner = (inner, inner.flatten_one())
        return this

    def transpose(self) -> Option["Result[T, E]"]:
        if not isinstance(self.Ok, OptionProtocol):
            raise TypeError("Inner value is not of type Option")
        return cast(Option, self.unwrap()).map(Ok)

    def early_return(self) -> T:
        # safe to unwrap here as we know it is Ok
        return self.unwrap()

    def __repr__(self):
        return f"Ok({self.Ok})"

    def __bool__(self):
        return True

    @classmethod
    def __get_validators__(cls):
        yield from ResultProtocol.__get_validators__()

Ancestors

Class variables

var Ok : ~T

Inherited members

class OptionProtocol

Abstract base class for generic types.

A generic type is typically declared by inheriting from this class parameterized with one or more type variables. For example, a generic mapping type might be defined as::

class Mapping(Generic[KT, VT]): def getitem(self, key: KT) -> VT: … # Etc.

This class can then be used as follows::

def lookup_name(mapping: Mapping[KT, VT], key: KT, default: VT) -> VT: try: return mapping[key] except KeyError: return default

Expand source code
class OptionProtocol(Generic[T]):
    @property
    @abstractmethod
    def is_some(self) -> bool:
        """
        :return: True if the option is `Some`.
        """
        ...  # pragma: no cover

    @property
    @abstractmethod
    def is_empty(self) -> bool:
        """
        :return: True if the option is `Empty`.
        """
        ...  # pragma: no cover

    @abstractmethod
    def contains(self, item: T) -> bool:
        """
        :param item: The value to check.
        :return: True if the option is `Some` containing the given value.
        """
        ...  # pragma: no cover

    @abstractmethod
    def expects(self, msg: str) -> T:
        """
        :param msg: Attached message for `UnwrapException` if raised.
        :return: The contained `Some` value
        :raises: `UnwrapException` if option is Empty.
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap(self) -> T:
        """
        Because this function may panic, its use is generally discouraged.
        Instead, prefer to use pattern matching and handle the None case explicitly, or call unwrap_or, unwrap_or_else,
        or unwrap_or_default

        :return: The contained Some value, consuming the self value.
        :raises: `UnwrapException` if option is `Empty`
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_or(self, default: T) -> T:
        """
        Arguments passed to unwrap_or are eagerly evaluated; if you are passing the result of a function call,
        it is recommended to use unwrap_or_else, which is lazily evaluated.

        :param default: default value.
        :return: The contained `Some` value or a provided default.
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_or_else(self, f: Callable[[], T]) -> T:
        """
        :param f: Compute function in case option is `Empty`.
        :return: The contained `Some` value or computed value from the closure.
        """
        ...  # pragma: no cover

    @abstractmethod
    def map(self, f: Callable[[T], U]) -> "Option[U]":
        """
        Maps an `Option[T]` to `Option[U]` by applying a function to a contained value.
        :param f: Function to apply.
        :return: `Some(f(value))` if option is `Some(value)` else `Empty`
        """
        ...  # pragma: no cover

    @abstractmethod
    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        """
        Applies a function to the contained value (if any), or returns the provided default (if not).

        Arguments passed to map_or are eagerly evaluated; if you are passing the result of a function call,
        it is recommended to use map_or_else, which is lazily evaluated.

        :param default: default value
        :param f: function to apply
        :return: f(value)` if option is `Some(value)` else `default`
        """
        ...  # pragma: no cover

    @abstractmethod
    def map_or_else(self, default: Callable[[], U], f: Callable[[T], U]) -> U:
        """
        Applies a function to the contained value (if any), or computes a default (if not).

        :param default: Default value.
        :param f: Function to apply to the map
        :return: `Some(f(value))` if option is `Some(value)` else `default()`
        """
        ...  # pragma: no cover

    @abstractmethod
    def iter(self) -> Iterator[T]:
        """
        :return: An iterator over the contained value if option is `Some(T)` or an empty iterator if not.
        """
        ...  # pragma: no cover

    @abstractmethod
    def filter(self, predicate: Callable[[T], bool]) -> "Option[T]":
        """
        :param predicate:
        :return: `Some(T)` if predicate returns `True` (where T is the wrapped value), `Empty` if predicate returns `False`
        """
        ...  # pragma: no cover

    @abstractmethod
    def ok_or(self, err: E) -> "Result[T, E]":
        """
        Transforms the `Option[T]` into a `Result[T, E]`, mapping `Some(v)` to `Ok(v)` and `None` to `Err(err)`.

        Arguments passed to ok_or are eagerly evaluated; if you are passing the result of a function call,
        it is recommended to use ok_or_else, which is lazily evaluated.

        :param err: `Err` value
        :return: `Ok(T)` if option is `Some(T)` else `Err(err)`
        """
        ...  # pragma: no cover

    @abstractmethod
    def ok_or_else(self, err: Callable[[], E]) -> "Result[T, E]":
        """
        Transforms the `Option[T]` into a `Result[T, E]`, mapping `Some(v)` to `Ok(v)` and `None` to `Err(err())`.
        :param err: Callable that return the `Err` value
        :return: `Ok(T)` if option is `Some(T)` else `Err(err())`
        """
        ...  # pragma: no cover

    @abstractmethod
    def and_then(self, f: Callable[[T], "Option[T]"]) -> "Option[T]":
        """
        Some languages call this operation flatmap.

        :param f: The function to call.
        :return: `Empty` if the option is `Empty`, otherwise calls f with the wrapped value and returns the result.
        """
        ...  # pragma: no cover

    @abstractmethod
    def or_else(self, f: Callable[[], "Option[T]"]) -> "Option[T]":
        """

        :param f: The function to call.
        :return: The option if it contains a value, otherwise calls f and returns the result.
        """
        ...  # pragma: no cover

    @abstractmethod
    def xor(self, optb: "Option[T]") -> "Option[T]":
        """

        :param optb: `Option` to compare with.
        :return: `Some` if exactly one of self or optb is `Some`, otherwise returns `Empty`.
        """
        ...  # pragma: no cover

    @abstractmethod
    def zip(self, value: "Option[U]") -> "Option[Tuple[T, U]]":
        """
        Zips self with another Option.
        :param value: `Option` to zip with.
        :return: If self is `Some[s]` and other is `Some[o]`, this method returns `Some[[s], [o]]`.
        Otherwise, `Empty` is returned.
        """
        ...  # pragma: no cover

    @abstractmethod
    def zip_with(self, other: "Option[U]", f: Callable[[Tuple[T, U]], R]) -> "Option[R]":
        """
        Zips self and another Option with function f.

        :param other: `Option` to zip with.
        :param f: Function to apply to the zipped options values.
        :return: If self is `Some[s]` and other is `Some[o]`, this method returns `Some[f(s, o)]`.
        Otherwise, `Empty` is returned.
        """
        ...  # pragma: no cover

    @abstractmethod
    def expect_empty(self, msg: str):
        """
        :param msg: Message to be wrapped by `UnwrapException` if raised
        :raises: `UnwrapException` if option is `Some`
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_empty(self):
        """
        :raises: `UnwrapException` if option is `Some`
        """
        ...  # pragma: no cover

    @abstractmethod
    def flatten_one(self) -> "Option[T]":
        """
        Removes one level from a nested `Option` structure.
        E.g.:
        * `Some(Some(1))` becomes `Some(1)`.
        * `Some(Some(Some(1)))` becomes `Some(Some(1))`.
        :return: `Option[T]` if self is `Option[Option[T]]`, otherwise `self`
        """
        ...  # pragma: no cover

    @abstractmethod
    def flatten(self) -> "Option[T]":
        """
        Removes all levels of nesting from a nested `Option` structure.
        E.g.:
        * `Some(Some(1))` becomes `Some(1)`.
        * `Some(Some(Some(1)))` becomes `Some(1)`.
        * `Some(Some(Some(Empty())))` becomes `Empty()`.
        :return: `Option[T]` if self is `Option[ ... Option[T] ...]`, otherwise `self`
        """
        ...  # pragma: no cover

    @abstractmethod
    def transpose(self) -> "Result[Option[T], E]":
        """
        Transposes an Option of a Result into a Result of an Option.
        Empty will be mapped to Ok(Empty). Some(Ok(_)) and Some(Err(_)) will be mapped to Ok(Some(_)) and Err(_).
        :return: `Result[Option[T], E]`
        :raises TypeError if inner value is not a `Result`
        """
        ...  # pragma: no cover

    @abstractmethod
    def early_return(self) -> T:
        """
        Access hook for `early_return` wrapper style.
        :return: Self if self is Some(T) otherwise
        :raises: EarlyReturnException(Empty)
        """
        ...  # pragma: no cover

    @abstractmethod
    def __bool__(self) -> bool:
        ...  # pragma: no cover

    def __contains__(self, item: T) -> bool:
        return self.contains(item)

    def __iter__(self):
        return self.iter()

    def __invert__(self) -> T:
        """
        Access hook for `early_return` wrapper style.
        :return: Self if self is Some(T) otherwise
        :raises: EarlyReturnException(Empty)
        """
        return self.early_return()

Ancestors

  • typing.Generic

Subclasses

Instance variables

prop is_empty : bool

:return: True if the option is Empty.

Expand source code
@property
@abstractmethod
def is_empty(self) -> bool:
    """
    :return: True if the option is `Empty`.
    """
    ...  # pragma: no cover
prop is_some : bool

:return: True if the option is Some.

Expand source code
@property
@abstractmethod
def is_some(self) -> bool:
    """
    :return: True if the option is `Some`.
    """
    ...  # pragma: no cover

Methods

def and_then(self, f: Callable[[~T], ForwardRef('Option[T]')]) ‑> Union[Some[~T], Empty]

Some languages call this operation flatmap.

:param f: The function to call. :return: Empty if the option is Empty, otherwise calls f with the wrapped value and returns the result.

def contains(self, item: ~T) ‑> bool

:param item: The value to check. :return: True if the option is Some containing the given value.

def early_return(self) ‑> ~T

Access hook for early_return wrapper style. :return: Self if self is Some(T) otherwise :raises: EarlyReturnException(Empty)

def expect_empty(self, msg: str)

:param msg: Message to be wrapped by UnwrapException if raised :raises: UnwrapException if option is Some

def expects(self, msg: str) ‑> ~T

:param msg: Attached message for UnwrapException if raised. :return: The contained Some value :raises: UnwrapException if option is Empty.

def filter(self, predicate: Callable[[~T], bool]) ‑> Union[Some[~T], Empty]

:param predicate: :return: Some(T) if predicate returns True (where T is the wrapped value), Empty if predicate returns False

def flatten(self) ‑> Union[Some[~T], Empty]

Removes all levels of nesting from a nested Option structure. E.g.: * Some(Some(1)) becomes Some(1). * Some(Some(Some(1))) becomes Some(1). * Some(Some(Some(Empty))) becomes Empty. :return: Option[T] if self is Option[ … Option[T] …], otherwise self

def flatten_one(self) ‑> Union[Some[~T], Empty]

Removes one level from a nested Option structure. E.g.: * Some(Some(1)) becomes Some(1). * Some(Some(Some(1))) becomes Some(Some(1)). :return: Option[T] if self is Option[Option[T]], otherwise self

def iter(self) ‑> Iterator[~T]

:return: An iterator over the contained value if option is Some(T) or an empty iterator if not.

def map(self, f: Callable[[~T], ~U]) ‑> Union[Some[~U], Empty]

Maps an Option[T] to Option[U] by applying a function to a contained value. :param f: Function to apply. :return: Some(f(value)) if option is Some(value) else Empty

def map_or(self, default: ~U, f: Callable[[~T], ~U]) ‑> ~U

Applies a function to the contained value (if any), or returns the provided default (if not).

Arguments passed to map_or are eagerly evaluated; if you are passing the result of a function call, it is recommended to use map_or_else, which is lazily evaluated.

:param default: default value :param f: function to apply :return: f(value) if option is Some(value) else default`

def map_or_else(self, default: Callable[[], ~U], f: Callable[[~T], ~U]) ‑> ~U

Applies a function to the contained value (if any), or computes a default (if not).

:param default: Default value. :param f: Function to apply to the map :return: Some(f(value)) if option is Some(value) else default()

def ok_or(self, err: ~E) ‑> Union[Ok[~T, ~E], Err[~T, ~E]]

Transforms the Option[T] into a Result[T, E], mapping Some(v) to Ok(v) and None to Err(err).

Arguments passed to ok_or are eagerly evaluated; if you are passing the result of a function call, it is recommended to use ok_or_else, which is lazily evaluated.

:param err: Err value :return: Ok(T) if option is Some(T) else Err(err)

def ok_or_else(self, err: Callable[[], ~E]) ‑> Union[Ok[~T, ~E], Err[~T, ~E]]

Transforms the Option[T] into a Result[T, E], mapping Some(v) to Ok(v) and None to Err(err()). :param err: Callable that return the Err value :return: Ok(T) if option is Some(T) else Err(err())

def or_else(self, f: Callable[[], ForwardRef('Option[T]')]) ‑> Union[Some[~T], Empty]

:param f: The function to call. :return: The option if it contains a value, otherwise calls f and returns the result.

def transpose(self) ‑> Union[Ok[Union[Some[~T], Empty], ~E], Err[Union[Some[~T], Empty], ~E]]

Transposes an Option of a Result into a Result of an Option. Empty will be mapped to Ok(Empty). Some(Ok()) and Some(Err()) will be mapped to Ok(Some()) and Err(). :return: Result[Option[T], E] :raises TypeError if inner value is not a Result

def unwrap(self) ‑> ~T

Because this function may panic, its use is generally discouraged. Instead, prefer to use pattern matching and handle the None case explicitly, or call unwrap_or, unwrap_or_else, or unwrap_or_default

:return: The contained Some value, consuming the self value. :raises: UnwrapException if option is Empty

def unwrap_empty(self)

:raises: UnwrapException if option is Some

def unwrap_or(self, default: ~T) ‑> ~T

Arguments passed to unwrap_or are eagerly evaluated; if you are passing the result of a function call, it is recommended to use unwrap_or_else, which is lazily evaluated.

:param default: default value. :return: The contained Some value or a provided default.

def unwrap_or_else(self, f: Callable[[], ~T]) ‑> ~T

:param f: Compute function in case option is Empty. :return: The contained Some value or computed value from the closure.

def xor(self, optb: Option[T]) ‑> Union[Some[~T], Empty]

:param optb: Option to compare with. :return: Some if exactly one of self or optb is Some, otherwise returns Empty.

def zip(self, value: Option[U]) ‑> Union[Some[Tuple[~T, ~U]], Empty]

Zips self with another Option. :param value: Option to zip with. :return: If self is Some[s] and other is Some[o], this method returns Some[[s], [o]]. Otherwise, Empty is returned.

def zip_with(self, other: Option[U], f: Callable[[Tuple[~T, ~U]], ~R]) ‑> Union[Some[~R], Empty]

Zips self and another Option with function f.

:param other: Option to zip with. :param f: Function to apply to the zipped options values. :return: If self is Some[s] and other is Some[o], this method returns Some[f(s, o)]. Otherwise, Empty is returned.

class ResultProtocol

Abstract base class for generic types.

A generic type is typically declared by inheriting from this class parameterized with one or more type variables. For example, a generic mapping type might be defined as::

class Mapping(Generic[KT, VT]): def getitem(self, key: KT) -> VT: … # Etc.

This class can then be used as follows::

def lookup_name(mapping: Mapping[KT, VT], key: KT, default: VT) -> VT: try: return mapping[key] except KeyError: return default

Expand source code
class ResultProtocol(Generic[T, E]):
    @property
    @abstractmethod
    def is_ok(self) -> bool:
        """
        :return: True if the result is Ok
        """
        ...  # pragma: no cover

    @property
    @abstractmethod
    def is_err(self) -> bool:
        """
        :return: True if the result is Err
        """
        ...  # pragma: no cover

    @abstractmethod
    def contains(self, value: T) -> bool:
        """
        :param value: Value to be checked
        :return: True if the result is an Ok value containing the given value
        """
        ...  # pragma: no cover

    @abstractmethod
    def contains_err(self, err: E) -> bool:
        """
        :param err: Value to be checked
        :return: True if the result is an Err containing the given err value
        """
        ...  # pragma: no cover

    @abstractmethod
    def ok(self) -> Option[T]:
        """
        Converts from `Result[T, E]` to `Option[T]`
        :return: `Some(T)` if result is `Ok(T)` otherwise `Empty` discarding the error, if any.
        """
        ...  # pragma: no cover

    @abstractmethod
    def err(self) -> Option[E]:
        """
        Converts from `Result[T, E]` to `Option[E]`
        :return: `Some(E)` if result is `Err(E)` otherwise `Empty` discarding the success value, if any.
        """
        ...  # pragma: no cover

    @abstractmethod
    def map(self, f: Callable[[T], U]) -> "Result[U, E]":
        """
        Maps a `Result[T, E]` to `Result[U, E]` by applying a function to a contained Ok value, leaving an Err value untouched.

        This function can be used to compose the results of two functions.
        :param f: Function to apply to the `Ok(T)`
        :return: A new result wrapping the new value, if applied.
        """
        ...  # pragma: no cover

    @abstractmethod
    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        """
        Applies a function to the contained value (if Ok), or returns the provided default (if Err).

        Arguments passed to map_or are eagerly evaluated; if you are passing the result of a function call,
        it is recommended to use map_or_else, which is lazily evaluated.
        :param default: Default value to be returned if result ir Err
        :param f: Function to apply to the `Ok(T)`
        :return: A new value with the result of applying the function to the Ok(value) or the default value.
        """
        ...  # pragma: no cover

    @abstractmethod
    def map_or_else(self, default: Callable[[E], U], f: Callable[[T], U]) -> U:
        """
        Maps a `Result[T, E]` to `U` by applying a function to a contained Ok value,
        or a fallback function to a contained Err value.

        This function can be used to unpack a successful result while handling an error.
        :param default: Callable to lazy load the default return value
        :param f: Function to apply to the `Ok(T)`
        :return: A new value with the result of applying the function to the Ok(value) or the default value loaded from the default function call.
        """
        ...  # pragma: no cover

    @abstractmethod
    def map_err(self, f: Callable[[E], U]) -> "Result[T, U]":
        """
        Maps a `Result[T, E]` to `Result[T, F]` by applying a function to a contained `Err` value,
        leaving an Ok value untouched.

        This function can be used to pass through a successful result while handling an error.
        :param f: Function to apply to the `E`
        :return: A new result with the modified `Err` value if applies.
        """
        ...  # pragma: no cover

    @abstractmethod
    def iter(self) -> Iterator[T]:
        """
        :return: An iterator with a value if the result is `Ok` otherwise an empty iterator.
        """
        ...  # pragma: no cover

    @abstractmethod
    def and_then(self, op: Callable[[T], "Result[T, E]"]) -> "Result[T, E]":
        """
        Calls op if the result is `Ok`, otherwise returns the `Err` value of self.

        This function can be used for control flow based on Result values.
        :param op: Callable to apply if result value if is `Ok`
        :return: A result from applying op if `Ok`, original `Err` if not
        """
        ...  # pragma: no cover

    @abstractmethod
    def or_else(self, op: Callable[[E], U]) -> "Result[T, U]":
        """
        Calls op if the result is `Err`, otherwise returns the `Ok` value of self.

        This function can be used for control flow based on Result values.
        :param op: Callable to apply if result value if is `Err`
        :return: A result from applying op if `Err`, original `Ok` if not
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap(self) -> T:
        """
        Returns the contained `Ok` value.

        Because this function may raise an exception, its use is generally discouraged. Instead, prefer to use
        pattern matching and handle the `Err` case explicitly, or call unwrap_or, unwrap_or_else, or unwrap_or_default.
        :return: Contained `Ok` value
        :raises: `UnwrapException` if resutl is `Err`
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_or(self, default: T) -> T:
        """
        Returns the contained `Ok` value or a provided default.

        Arguments passed to unwrap_or are eagerly evaluated; if you are passing the result of a function call,
        it is recommended to use unwrap_or_else, which is lazily evaluated.
        :param default: Value to be returned if result is `Err`
        :return: `Ok` value or `default`
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_or_else(self, default: Callable[[], T]) -> T:
        """
        :param default: Function to call for the default value
        :return: The contained `Ok` value or computes it from a closure.
        """
        ...  # pragma: no cover

    @abstractmethod
    def expect(self, msg: str) -> T:
        """
        :param msg: Attached message in case result is `Err` and `UnwrapException` is raised
        :return: The contained `Ok` value
        :raises: `UnwrapException`
        """
        ...  # pragma: no cover

    @abstractmethod
    def unwrap_err(self) -> E:
        """
        :return: The contained `Err` value.
        :raises: `UnwrapException` if result is `Ok`.
        """
        ...  # pragma: no cover

    @abstractmethod
    def expect_err(self, msg: str) -> E:
        """
        :param msg: Attached message in case result is `Ok` and `UnwrapException` is raised
        :return: The contained `Err` value.
        :raises: `UnwrapException` if result is `Ok`.
        """
        ...  # pragma: no cover

    @abstractmethod
    def flatten_one(self) -> "Result[T, E]":
        """
        Converts from Result[Result[T, E], E] to Result<T, E>, one nested level.
        :return: Flattened Result[T, E]
        """
        ...  # pragma: no cover

    @abstractmethod
    def flatten(self) -> "Result[T, E]":
        """
        Converts from Result[Result[T, E], E] to Result<T, E>, any nested level
        :return: Flattened Result[T, E]
        """
        ...  # pragma: no cover

    @abstractmethod
    def transpose(self) -> Option["Result[T, E]"]:
        """
        Transposes a Result of an Option into an Option of a Result.
        Ok(Empty) will be mapped to Empty. Ok(Some(_)) and Err(_) will be mapped to Some(Ok(_)) and Some(Err(_))
        :return: Option[Result[T, E]] as per the mapping above
        :raises TypeError if inner value is not an `Option`
        """
        ...  # pragma: no cover

    @abstractmethod
    def early_return(self) -> T:
        """
        Access hook for `early_return` wrapper style.
        :return: T if self is Ok(T) otherwise
        :raises: EarlyReturnException(Err(e))
        """
        ...  # pragma: no cover

    def __invert__(self) -> T:
        """
        Access hook for `early_return` wrapper style.
        :return: T if self is Ok(T) otherwise
        :raises: EarlyReturnException(Err(e))
        """
        return self.early_return()

    @abstractmethod
    def __bool__(self) -> bool:
        ...  # pragma: no cover

    def __contains__(self, item: T) -> bool:
        return self.contains(item)

    def __iter__(self) -> Iterator[T]:
        return self.iter()

Ancestors

  • typing.Generic

Subclasses

Instance variables

prop is_err : bool

:return: True if the result is Err

Expand source code
@property
@abstractmethod
def is_err(self) -> bool:
    """
    :return: True if the result is Err
    """
    ...  # pragma: no cover
prop is_ok : bool

:return: True if the result is Ok

Expand source code
@property
@abstractmethod
def is_ok(self) -> bool:
    """
    :return: True if the result is Ok
    """
    ...  # pragma: no cover

Methods

def and_then(self, op: Callable[[~T], ForwardRef('Result[T, E]')]) ‑> Union[Ok[~T, ~E], Err[~T, ~E]]

Calls op if the result is Ok, otherwise returns the Err value of self.

This function can be used for control flow based on Result values. :param op: Callable to apply if result value if is Ok :return: A result from applying op if Ok, original Err if not

def contains(self, value: ~T) ‑> bool

:param value: Value to be checked :return: True if the result is an Ok value containing the given value

def contains_err(self, err: ~E) ‑> bool

:param err: Value to be checked :return: True if the result is an Err containing the given err value

def early_return(self) ‑> ~T

Access hook for early_return wrapper style. :return: T if self is Ok(T) otherwise :raises: EarlyReturnException(Err(e))

def err(self) ‑> Union[Some[~E], Empty]

Converts from Result[T, E] to Option[E] :return: Some(E) if result is Err(E) otherwise Empty discarding the success value, if any.

def expect(self, msg: str) ‑> ~T

:param msg: Attached message in case result is Err and UnwrapException is raised :return: The contained Ok value :raises: UnwrapException

def expect_err(self, msg: str) ‑> ~E

:param msg: Attached message in case result is Ok and UnwrapException is raised :return: The contained Err value. :raises: UnwrapException if result is Ok.

def flatten(self) ‑> Union[Ok[~T, ~E], Err[~T, ~E]]

Converts from Result[Result[T, E], E] to Result, any nested level :return: Flattened Result[T, E]

def flatten_one(self) ‑> Union[Ok[~T, ~E], Err[~T, ~E]]

Converts from Result[Result[T, E], E] to Result, one nested level. :return: Flattened Result[T, E]

def iter(self) ‑> Iterator[~T]

:return: An iterator with a value if the result is Ok otherwise an empty iterator.

def map(self, f: Callable[[~T], ~U]) ‑> Union[Ok[~U, ~E], Err[~U, ~E]]

Maps a Result[T, E] to Result[U, E] by applying a function to a contained Ok value, leaving an Err value untouched.

This function can be used to compose the results of two functions. :param f: Function to apply to the Ok(T) :return: A new result wrapping the new value, if applied.

def map_err(self, f: Callable[[~E], ~U]) ‑> Union[Ok[~T, ~U], Err[~T, ~U]]

Maps a Result[T, E] to Result[T, F] by applying a function to a contained Err value, leaving an Ok value untouched.

This function can be used to pass through a successful result while handling an error. :param f: Function to apply to the E :return: A new result with the modified Err value if applies.

def map_or(self, default: ~U, f: Callable[[~T], ~U]) ‑> ~U

Applies a function to the contained value (if Ok), or returns the provided default (if Err).

Arguments passed to map_or are eagerly evaluated; if you are passing the result of a function call, it is recommended to use map_or_else, which is lazily evaluated. :param default: Default value to be returned if result ir Err :param f: Function to apply to the Ok(T) :return: A new value with the result of applying the function to the Ok(value) or the default value.

def map_or_else(self, default: Callable[[~E], ~U], f: Callable[[~T], ~U]) ‑> ~U

Maps a Result[T, E] to U by applying a function to a contained Ok value, or a fallback function to a contained Err value.

This function can be used to unpack a successful result while handling an error. :param default: Callable to lazy load the default return value :param f: Function to apply to the Ok(T) :return: A new value with the result of applying the function to the Ok(value) or the default value loaded from the default function call.

def ok(self) ‑> Union[Some[~T], Empty]

Converts from Result[T, E] to Option[T] :return: Some(T) if result is Ok(T) otherwise Empty discarding the error, if any.

def or_else(self, op: Callable[[~E], ~U]) ‑> Union[Ok[~T, ~U], Err[~T, ~U]]

Calls op if the result is Err, otherwise returns the Ok value of self.

This function can be used for control flow based on Result values. :param op: Callable to apply if result value if is Err :return: A result from applying op if Err, original Ok if not

def transpose(self) ‑> Union[Some[Union[Ok[~T, ~E], Err[~T, ~E]]], Empty]

Transposes a Result of an Option into an Option of a Result. Ok(Empty) will be mapped to Empty. Ok(Some()) and Err() will be mapped to Some(Ok()) and Some(Err()) :return: Option[Result[T, E]] as per the mapping above :raises TypeError if inner value is not an Option

def unwrap(self) ‑> ~T

Returns the contained Ok value.

Because this function may raise an exception, its use is generally discouraged. Instead, prefer to use pattern matching and handle the Err case explicitly, or call unwrap_or, unwrap_or_else, or unwrap_or_default. :return: Contained Ok value :raises: UnwrapException if resutl is Err

def unwrap_err(self) ‑> ~E

:return: The contained Err value. :raises: UnwrapException if result is Ok.

def unwrap_or(self, default: ~T) ‑> ~T

Returns the contained Ok value or a provided default.

Arguments passed to unwrap_or are eagerly evaluated; if you are passing the result of a function call, it is recommended to use unwrap_or_else, which is lazily evaluated. :param default: Value to be returned if result is Err :return: Ok value or default

def unwrap_or_else(self, default: Callable[[], ~T]) ‑> ~T

:param default: Function to call for the default value :return: The contained Ok value or computes it from a closure.

class Some (Some: ~T)

Some(Some: ~T)

Expand source code
@dataclass(eq=True, frozen=True)
class Some(OptionProtocol[T]):
    Some: T

    @property
    def is_some(self) -> bool:
        return True

    @property
    def is_empty(self) -> bool:
        return False

    def contains(self, item: T) -> bool:
        return item == self.Some

    def expects(self, msg: str) -> T:
        return self.Some

    def unwrap(self) -> T:
        return self.Some

    def unwrap_or(self, default: T) -> T:
        return self.Some

    def unwrap_or_else(self, f: Callable[[], T]) -> T:
        return self.Some

    def map(self, f: Callable[[T], U]) -> "Option[U]":
        return Some(f(self.Some))

    def map_or(self, default: U, f: Callable[[T], U]) -> U:
        return f(self.Some)

    def map_or_else(self, default: Callable[[], U], f: Callable[[T], U]) -> U:
        return f(self.Some)

    def iter(self) -> Iterator[T]:
        def _iter():
            yield self.Some
        return iter(_iter())

    def filter(self, predicate: Callable[[T], bool]) -> "Option[T]":
        return self if predicate(self.Some) else Empty()

    def ok_or(self, err: E) -> "Result[T, E]":
        return Ok(self.Some)

    def ok_or_else(self, err: Callable[[], E]) -> "Result[T, E]":
        return Ok(self.Some)

    def and_then(self, f: Callable[[T], "Option[T]"]) -> "Option[T]":
        return f(self.Some)

    def or_else(self, f: Callable[[], "Option[T]"]) -> "Option[T]":
        return self

    def xor(self, optb: "Option[T]") -> "Option[T]":
        return self if optb.is_empty else Empty()

    def zip(self, other: "Option[U]") -> "Option[Tuple[T, U]]":
        if other.is_some:
            # function typing is correct, we really return an Option[Tuple] but mypy complains that
            # other may not have a Value attribute because it do not understand the previous line check.
            return Some((self.Some, other.Some))  # type: ignore[union-attr]

        return Empty()

    def zip_with(self, other: "Option[U]", f: Callable[[Tuple[T, U]], R]) -> "Option[R]":
        return self.zip(other).map(f)

    def expect_empty(self, msg: str):
        raise UnwrapException(msg)

    def unwrap_empty(self):
        self.expect_empty("")

    def flatten_one(self) -> "Option[T]":
        inner: T = self.unwrap()
        if isinstance(inner, OptionProtocol):
            return cast(Option, inner)
        return self

    def flatten(self) -> "Option[T]":
        this: Option[T] = self
        inner: Option[T] = self.flatten_one()
        while inner is not this:
            this, inner = (inner, inner.flatten_one())
        return this

    def transpose(self) -> "Result[Option[T], E]":
        if not isinstance(self.Some, ResultProtocol):
            raise TypeError("Inner value is not a Result")
        value: "ResultProtocol[T, E]" = self.Some
        return value.map(Some)

    def early_return(self) -> T:
        # it is safe to unwrap here as we know we are Some
        return self.unwrap()

    def __bool__(self) -> bool:
        return True

    @classmethod
    def __get_validators__(cls):
        yield from OptionProtocol.__get_validators__()

Ancestors

Class variables

var Some : ~T

Inherited members