CHANGELOG.md

# Changelog

## v1.1.0 (2023-12-13)

  * Add a `:type_spec` option to specify a quoted type spec for options.

## v1.0.2 (2023-04-21)

  * Improve typespec generation for ranges and structs.

## v1.0.1 (2023-03-13)

  * Make the `NimbleOptions.t/0` type *public* (instead of opaque). This helps with Dialyzer issues when ysing `NimbleOptions.new!/1` at compile time.

## v1.0.0 (2023-03-08)

  * Add support for a `{:struct, struct_name}` type specifier
  * Add support for the `:type_doc` option
  * Turn `t:NimbleOptions.t/0` into an *opaque* type

## v0.5.1 (2020-11-05)

  * Support generating typespecs for `:tuple`, `:map`, and `{:map, key, value}` options

## v0.5.0 (2020-09-20)

  * Support `:map` which accepts the same `:keys` specification as keyword lists
  * Normalize all error messages to include the key and expected value out of the box
  * Do not nest options when rendered in Markdown and make sure multiline content is properly indented
  * Handle \r\n style of line breaks in docs
  * Automatically add types to generated docs
  * Support lists of keyword lists in `:list`
  * Add the `:reference` option type
  * Add the `:tuple` option type

## v0.4.0 (2020-10-28)

  * Add support for all enumerables in `{:in, choices}` instead of just lists. You can now do things such as `{:in, 1..10}`.
  * Deprecate the `:rename_to` schema option and emit a warning when used.
  * Remove the `{:one_of, choices}` type which was deprecated in v0.3.3.

## v0.3.7 (2021-09-11)

  * Add `NimbleOptions.new!/1` to validate the schema once.

## v0.3.6 (2021-07-13)

  * Add `:float` type.
  * Fix docs generation when custom key type has no keys.

## v0.3.5 (2020-11-09)

  * Add support for the `{:list, subtype}` type.

## v0.3.4 (2020-11-05)

  * Support nested schemas in the `{:or, subtypes}` type as `{:or, [:string, keyword_list: [enabled: [type: :boolean]]]}`.
  * Improve validation of the return value of `{:custom, module, function, args}` functions.
  * Support options in `NimbleOptions.docs/2`. For now only the `:nest_level` option is supported.

## v0.3.3 (2020-11-02)

  * Add the `{:or, subtypes}` type.
  * Deprecate the `{:one_of, choices}` and replace it with `{:in, choices}`. Using `{:one_of, choices}` emits a warning now.

## v0.3.2 (2020-10-26)

  * Fix a small bug with docs for nested schemas.

## v0.3.1 (2020-10-25)

  * Return `:key` and `:value` on `%NimbleOptions.ValidationError{}` to allow programmatic use of errors.
  * Validate default values according to the specified type.

## v0.3.0 (2020-06-14)

  * **Breaking change**: return `{:error, %NimbleOptions.ValidationError{}}` tuples when there's a validation error in `NimbleOptions.validate/2` instead of `{:error, message}` (with `message` being a string). You can use `Exception.message/1` to turn the `NimbleOptions.ValidationError` struct into a string.
  * Add the `:pid` type.

## v0.2.1 (2020-05-08)

  * Add `NimbleOptions.validate!/2`.

## v0.2.0 (2020-04-11)

  * Change the behavior of `NimbleOptions.docs/1` to accept a normal schema and produce documentation for that.
  * Add support for `doc: false` as a schema option to hide an option or an option and its subsection.

## v0.1.0 (2020-04-07)

  * First release.