View Source MyApp.Cldr (Cldr v2.37.2)
Provides the core functions to retrieve and manage the CLDR data that supports formatting and localisation.
It provides the core functions to access formatted CLDR data, set and retrieve a current locale and validate certain core data types such as locales, currencies and territories.
Link to this section Summary
Functions
Returns the default locale.
Returns the default territory when a locale does not specify one and none can be inferred.
Add locale-specific ellipsis to a string.
Return the current locale to be used for Cldr functions that
take an optional locale parameter for which a locale is not supplied.
Returns either the Gettext locale_name in Cldr format or
false based upon whether the locale name is configured in
Gettext.
Returns a boolean indicating if the specified locale name is configured and available in Gettext.
Returns a list of Gettext locale names but in CLDR format with
underscore replaced by hyphen in order to facilitate comparisons
with Cldr locale names.
Returns either the locale_name or false based upon
whether the locale name is configured in Cldr.
Returns a boolean indicating if the specified locale name is configured and available in Cldr.
Returns a list of the known locale names.
Returns a list of atoms representing the number systems types known to Cldr.
Returns either the RBNF locale_name or false based upon
whether the locale name is configured in Cldr
and has RBNF rules defined.
Returns a boolean indicating if the specified locale name is configured and available in Cldr and supports rules based number formats (RBNF).
Returns a list of locale names which have rules-based number formats (RBNF).
Normalizes a string by applying transliteration of common symbols in numbers, currencies and dates
Set the current locale to be used for Cldr functions that
take an optional locale parameter for which a locale is not supplied.
Add locale-specific quotation marks around a string.
Returns a list of the locales names that are configured, but not known in CLDR.
Normalise and validate a locale name.
Normalise and validate a number system type.
Execute a function with a locale ensuring that the current locale is restored after the function.
Link to this section Functions
@spec default_locale() :: Cldr.LanguageTag.t() | no_return()
Returns the default locale.
  
  example
  
  Example
iex> MyApp.Cldr.default_locale()
%Cldr.LanguageTag{
  backend: MyApp.Cldr,
  canonical_locale_name: "en-001",
  cldr_locale_name: :"en-001",
  language_subtags: [],
  extensions: %{},
  gettext_locale_name: "en",
  language: "en",
  locale: %{},
  private_use: [],
  rbnf_locale_name: :en,
  requested_locale_name: "en-001",
  script: :Latn,
  territory: :"001",
  transform: %{},
  language_variants: []
}@spec default_territory() :: Cldr.Locale.territory_code()
Returns the default territory when a locale does not specify one and none can be inferred.
  
  example
  
  Example
iex> MyApp.Cldr.default_territory()
:"001"Add locale-specific ellipsis to a string.
  
  arguments
  
  Arguments
- stringis any- String.tor a 2-element list of- String.tbetween which the ellipsis is inserted.
- backendis any module that includes- use Cldrand therefore is a- Cldrbackend module. The default is- Cldr.default_backend!/0. Note that- Cldr.default_backend!/0will raise an exception if no- :default_backendis configured under the- :ex_cldrkey in- config.exs.
- optionsis a keyword list of options
  
  options
  
  Options
- :localeis any valid locale name returned by- Cldr.known_locale_names/1. The default is- Cldr.get_locale/0.
- :locationdetermines where to place the ellipsis. The options are- :after(the default for a single string argument),- :between(the default and only valid location for an argument that is a list of two strings) and- :before.
- :formatformats based upon whether the ellipsis is inserted between words or sentences. The valid options are- :wordor- :sentence. The default is- :sentence.
  
  examples
  
  Examples
iex> MyApp.Cldr.ellipsis "And furthermore"
"And furthermore…"
iex> MyApp.Cldr.ellipsis ["And furthermore", "there is much to be done"], locale: :ja
"And furthermore…there is much to be done"
iex> MyApp.Cldr.ellipsis "And furthermore", format: :word
"And furthermore …"
iex> MyApp.Cldr.ellipsis ["And furthermore", "there is much to be done"], locale: :ja, format: :word
"And furthermore … there is much to be done"@spec get_locale() :: Cldr.LanguageTag.t()
Return the current locale to be used for Cldr functions that
take an optional locale parameter for which a locale is not supplied.
  
  example
  
  Example
iex> MyApp.Cldr.put_locale("pl")
iex> MyApp.Cldr.get_locale
%Cldr.LanguageTag{
   backend: Elixir.MyApp.Cldr,
   canonical_locale_name: "pl",
   cldr_locale_name: :pl,
   extensions: %{},
   language: "pl",
   locale: %{},
   private_use: [],
   rbnf_locale_name: :pl,
   territory: :PL,
   requested_locale_name: "pl",
   script: :Latn,
   transform: %{},
   language_variants: []
 }Returns either the Gettext locale_name in Cldr format or
false based upon whether the locale name is configured in
Gettext.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_gettext_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_gettext_locale_name "en"
"en"
iex> MyApp.Cldr.known_gettext_locale_name "en-SA"
falseReturns a boolean indicating if the specified locale name is configured and available in Gettext.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_gettext_locale_name?("en")
true
iex> MyApp.Cldr.known_gettext_locale_name?("!!")
false@spec known_gettext_locale_names() :: [String.t()]
Returns a list of Gettext locale names but in CLDR format with
underscore replaced by hyphen in order to facilitate comparisons
with Cldr locale names.
@spec known_locale_name(Cldr.Locale.locale_name()) :: String.t() | false
Returns either the locale_name or false based upon
whether the locale name is configured in Cldr.
This is helpful when building a list of or expressions
to return the first known locale name from a list.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_locale_name :"en-AU"
:"en-AU"
iex> MyApp.Cldr.known_locale_name :"en-SA"
false@spec known_locale_name?(Cldr.Locale.locale_name()) :: boolean()
Returns a boolean indicating if the specified locale name is configured and available in Cldr.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_locale_name?(:en)
true
iex> MyApp.Cldr.known_locale_name?(:"!!")
falseReturns a list of the known locale names.
Known locales are those locales which
are the subset of all CLDR locales that
have been configured for use either
in this module or in Gettext.
Returns a list of atoms representing the number systems types known to Cldr.
  
  example
  
  Example
iex> MyApp.Cldr.known_number_system_types
[:default, :finance, :native, :traditional]@spec known_rbnf_locale_name(Cldr.Locale.locale_name()) :: String.t() | false
Returns either the RBNF locale_name or false based upon
whether the locale name is configured in Cldr
and has RBNF rules defined.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_rbnf_locale_name :en
:en
iex> MyApp.Cldr.known_rbnf_locale_name :"en-SA"
false@spec known_rbnf_locale_name?(Cldr.Locale.locale_name()) :: boolean()
Returns a boolean indicating if the specified locale name is configured and available in Cldr and supports rules based number formats (RBNF).
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0
  
  examples
  
  Examples
iex> MyApp.Cldr.known_rbnf_locale_name?(:en)
true
iex> MyApp.Cldr.known_rbnf_locale_name?(:"!!")
false@spec known_rbnf_locale_names() :: [Cldr.Locale.locale_name()]
Returns a list of locale names which have rules-based number formats (RBNF).
Normalizes a string by applying transliteration of common symbols in numbers, currencies and dates
@spec put_locale(Cldr.Locale.locale_reference()) :: {:ok, Cldr.LanguageTag.t()} | {:error, {module(), String.t()}}
Set the current locale to be used for Cldr functions that
take an optional locale parameter for which a locale is not supplied.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0or a- t:Cldr.LanguageTagstruct returned by- MyApp.Cldr.Locale.new!/1
See rfc5646 for the specification of a language tag.
  
  examples
  
  Examples
iex> MyApp.Cldr.put_locale("en")
{:ok,
 %Cldr.LanguageTag{
   backend: MyApp.Cldr,
   canonical_locale_name: "en",
   cldr_locale_name: :en,
   language_subtags: [],
   extensions: %{},
   gettext_locale_name: "en",
   language: "en",
   locale: %{},
   private_use: [],
   rbnf_locale_name: :en,
   requested_locale_name: "en",
   script: :Latn,
   territory: :US,
   transform: %{},
   language_variants: []
 }}
iex> MyApp.Cldr.put_locale("invalid-locale!")
{:error, {Cldr.LanguageTag.ParseError,
  "Expected a BCP47 language tag. Could not parse the remaining \"!\" starting at position 15"}}Add locale-specific quotation marks around a string.
  
  arguments
  
  Arguments
- stringis any valid Elixir string
- optionsis a keyword list of options
  
  options
  
  Options
- localeis any valid locale name returned by- Cldr.known_locale_names/1. The default is- Cldr.get_locale/0
  
  examples
  
  Examples
iex> MyApp.Cldr.quote "Quoted String"
"“Quoted String”"
iex> MyApp.Cldr.quote "Quoted String", locale: :ja
"「Quoted String」"@spec unknown_locale_names() :: [Cldr.Locale.locale_name()]
Returns a list of the locales names that are configured, but not known in CLDR.
Since there is a compile-time exception raised if there are any unknown locales this function should always return an empty list.
@spec validate_locale(Cldr.Locale.locale_name() | Cldr.LanguageTag.t() | String.t()) :: {:ok, Cldr.LanguageTag.t()} | {:error, {module(), String.t()}}
Normalise and validate a locale name.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- MyApp.Cldr.known_locale_names/0or a- Cldr.LanguageTagstruct returned by- MyApp.Cldr.Locale.new!/1
  
  returns
  
  Returns
- {:ok, language_tag}
- {:error, reason}
  
  notes
  
  Notes
See rfc5646 for the specification of a language tag.
  
  examples
  
  Examples
iex> MyApp.Cldr.validate_locale(:en)
{:ok,
%Cldr.LanguageTag{
  backend: MyApp.Cldr,
  canonical_locale_name: "en",
  cldr_locale_name: :en,
  extensions: %{},
  gettext_locale_name: "en",
  language: "en",
  locale: %{},
  private_use: [],
  rbnf_locale_name: :en,
  requested_locale_name: "en",
  script: :Latn,
  territory: :US,
  transform: %{},
  language_variants: []
}}
iex> MyApp.Cldr.validate_locale MyApp.Cldr.default_locale()
{:ok,
%Cldr.LanguageTag{
  backend: MyApp.Cldr,
  canonical_locale_name: "en-001",
  cldr_locale_name: :"en-001",
  extensions: %{},
  gettext_locale_name: "en",
  language: "en",
  locale: %{},
  private_use: [],
  rbnf_locale_name: :en,
  requested_locale_name: "en-001",
  script: :Latn,
  territory: :"001",
  transform: %{},
  language_variants: []
}}
iex> MyApp.Cldr.validate_locale("zzz")
{:error, {Cldr.InvalidLanguageError, "The language \"zzz\" is invalid"}}@spec validate_number_system_type(String.t() | atom()) :: {:ok, atom()} | {:error, {module(), String.t()}}
Normalise and validate a number system type.
  
  arguments
  
  Arguments
- number_system_typeis any number system type returned by- Cldr.known_number_system_types/1
  
  returns
  
  Returns
- {:ok, normalized_number_system_type}or
- {:error, {exception, message}}
  
  examples
  
  Examples
iex> MyApp.Cldr.validate_number_system_type :default
{:ok, :default}
iex> MyApp.Cldr.validate_number_system_type :traditional
{:ok, :traditional}
iex> MyApp.Cldr.validate_number_system_type :latn
{
  :error,
  {Cldr.UnknownNumberSystemTypeError, "The number system type :latn is unknown"}
}
iex> MyApp.Cldr.validate_number_system_type "bork"
{
  :error,
  {Cldr.UnknownNumberSystemTypeError, "The number system type \"bork\" is invalid"}
}@spec with_locale(Cldr.LanguageTag.t(), (... -> any())) :: any()
@spec with_locale(Cldr.Locale.locale_name(), (... -> any())) :: any()
Execute a function with a locale ensuring that the current locale is restored after the function.
  
  arguments
  
  Arguments
- localeis any valid locale name returned by- Cldr.known_locale_names/1.
- funis any 0-arity function or function capture.
  
  returns
  
  Returns
- The value returned by the function - fun/0or
- {:error, {exception, reason}}if the locale is invalid or
- raises an exception if the current locale cannot be identified. 
