# `Mnemosyne.Errors`
[🔗](https://github.com/edlontech/mnemosyne/blob/main/lib/mnemosyne/errors.ex#L1)

Top-level Splode error aggregator for Mnemosyne.

Provides error classes for invalid input, framework-level failures,
and unknown/unrecognized errors.

# `class`

```elixir
@type class() :: %{
  :__struct__ =&gt; class_module(),
  :__exception__ =&gt; true,
  :errors =&gt; [t()],
  :class =&gt; error_class(),
  :bread_crumbs =&gt; [String.t()],
  :vars =&gt; Keyword.t(),
  :stacktrace =&gt; Splode.Stacktrace.t() | nil,
  :context =&gt; map(),
  optional(atom()) =&gt; any()
}
```

# `class_module`

```elixir
@type class_module() ::
  Mnemosyne.Errors.Unknown
  | Mnemosyne.Errors.Framework
  | Mnemosyne.Errors.Invalid
```

# `error`

```elixir
@type error() ::
  Mnemosyne.Errors.Invalid.ConfigError.t()
  | Mnemosyne.Errors.Invalid.EpisodeError.t()
  | Mnemosyne.Errors.Invalid.PromptError.t()
  | Mnemosyne.Errors.Framework.SessionError.t()
  | Mnemosyne.Errors.Framework.PipelineError.t()
  | Mnemosyne.Errors.Framework.StorageError.t()
  | Mnemosyne.Errors.Framework.AdapterError.t()
  | Mnemosyne.Errors.Framework.NotFoundError.t()
  | Mnemosyne.Errors.Framework.RepoError.t()
  | Mnemosyne.Errors.Unknown.Unknown.t()
```

# `error_class`

```elixir
@type error_class() :: :unknown | :framework | :invalid
```

# `t`

```elixir
@type t() :: %{
  :__struct__ =&gt; module(),
  :__exception__ =&gt; true,
  :class =&gt; error_class(),
  :bread_crumbs =&gt; [String.t()],
  :vars =&gt; Keyword.t(),
  :stacktrace =&gt; Splode.Stacktrace.t() | nil,
  :context =&gt; map(),
  optional(atom()) =&gt; any()
}
```

# `splode_error?`

# `traverse_errors`

Traverses errors, calling `fun` for each leaf error, and returns a nested
map of results grouped by each error's `path`.

See `Splode.traverse_errors/2` for full documentation.

## Example

    iex> Elixir.Mnemosyne.Errors.traverse_errors(error, fn error ->
    ...>   Exception.message(error)
    ...> end)
    %{name: ["name is required"]}

# `unwrap!`

Raises an error if the result is an error, otherwise returns the result

Alternatively, you can use the `defsplode` macro, which does this automatically.

### Options

- `:error_opts` - Options to pass to `to_error/2` when converting the returned error
- `:unknown_error_opts` - Options to pass to the unknown error if the function returns only `:error`.
  not necessary if your function always returns `{:error, error}`.

### Examples

  def function(arg) do
    case do_something(arg) do
      :success -> :ok
      {:success, result} -> {:ok, result}
      {:error, error} -> {:error, error}
    end
  end

  def function!(arg) do
    YourErrors.unwrap!(function(arg))
  end

---

*Consult [api-reference.md](api-reference.md) for complete listing*
