# Changelog ## v1.1.1 (2024-05-25) * Fix typespecs to avoid Dialyzer warnings * Do not list default values as part of received options * Mark structs in backticks for doc references * List deprecations in docs ## 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.