Localize.LocaleCacheDirError exception (Localize v0.41.0)

Copy Markdown View Source

Exception raised when the :locale_cache_dir or :otp_app application environment keys are misconfigured.

Three failure modes:

  • :relative_path:locale_cache_dir is a relative string and no :otp_app is configured to anchor it. A relative path with no anchor resolves against the BEAM's current working directory, which differs between mix tasks (CWD = project root), mix test, and a release (CWD = release root) — one value cannot be correct in all phases.

  • :invalid_form:locale_cache_dir is set but is not a string.

  • :invalid_otp_app:otp_app is set but is not an atom.

Supported configurations

Three forms are accepted:

  1. :otp_app only (recommended) — caches in Application.app_dir(<otp_app>, "priv/localize/locales"):

     config :localize, otp_app: :my_app
  2. :otp_app + relative :locale_cache_dir — caches in Application.app_dir(<otp_app>, <relative>):

     config :localize,
       otp_app: :my_app,
       locale_cache_dir: "priv/i18n/cache"
  3. Absolute :locale_cache_dir — used verbatim; :otp_app is ignored:

     config :localize, locale_cache_dir: "/var/lib/localize/locales"

:otp_app follows the Elixir/Phoenix/Ecto/Gettext convention. Application.app_dir/2 is re-resolved at every read, so the same config value produces the correct path in mix tasks (_build/<env>/lib/<app>/priv/...) and in releases (/path/to/release/lib/<app>-X.Y.Z/priv/...) without per-phase duplication.

Summary

Types

reason()

@type reason() :: :relative_path | :invalid_form | :invalid_otp_app

t()

@type t() :: %Localize.LocaleCacheDirError{
  __exception__: term(),
  detail: String.t() | nil,
  reason: reason() | nil,
  value: term() | nil
}