Skip to content

Changelog

All notable changes to this project are documented here.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

[Unreleased]

2.3.0 - 2024-09-14

See the blog post for this release that describes some of the most notable changes in detail.

Added

  • Add support for positional params in start_fn and finish_fn (#125)

Fixed

  • Forward lint suppression from #[allow()/expect()] attributes written by the user on the top-level to the generated items (#125)
  • Suppress the false-positive (clippy issue) clippy::future_not_send lint (#125)
  • Fix the cases where #[builder(derive(Debug, Clone))] didn't validate for all members to implement Clone/Debug if these members were of reference or generic types (#125)

2.2.1 - 2024-09-09

Changed

  • Lower MSRV from 1.70.0 to 1.59.0 (#120)

2.2.0 - 2024-09-08

See the blog post for this release that describes some of the most notable changes in detail.

Changed

  • The #[bon::builder] attribute was deprecated on structs. The new #[derive(bon::Builder)] should be used to derive a builder from a struct. Starting with bon 2.3 (next minor release) all usages of #[bon::builder] on structs will generate deprecation warnings. (#99).

    There is a CLI to assist in migrating to the new syntax. See the release blog post for details about that.

Added

  • Add the top-level #[builder(derive(...))] attribute to be able to derive Clone and Debug for the builder type itself (#113)

  • Add support for conditional compilation with cfg/cfg_attr (#99)

Fixed

  • Fix developer experience in Rust Rover. The new #[derive(Builder)] syntax should now be easier for Rust Rover to analyze (#99)
  • Fix a bug where a member of opaque Option type (i.e. the Option type that was renamed to make the builder macro not detect it as Option) was still optional. (#99)
  • Fix code generation for structs with default values for generic parameters (#108)

2.1.1 - 2024-09-03

Added

  • Set MSRV to 1.70.0. Note that we plan to set an even lower MSRV. This is just an initial attempt to define the MSRV that should be good enough in the meantime while we work on lowering it even more (#101)

Fixed

  • Fix lints triggered by generated code such as private_bounds, clippy::missing_const_for_fn (#101)
  • Add more context to the messages such that it's clear what member isn't set in Rust Analyzer error messages (#98)

2.1.0 - 2024-09-01

See the blog post for this release that describes some of the most notable changes in detail.

Added

  • #[must_use] on the build() method for structs and call() for functions (if the original function has #[must_use]) (#82). Thanks @EdJoPaTo for the contribution!

Changed

  • Optimize bon's generated code type-checking performance and improve error messages (#84)
  • Improve builder() method docs (#76). Thanks @EdJoPaTo for the contribution!

Fixed

  • Don't warn on clippy::impl_trait_in_params (#80). Thanks @EdJoPaTo for the contribution!
  • Fix typos in messages and code comments (#79). Thanks @EdJoPaTo for the contribution!

Other

  • Add more tests for #[must_use] (#87)

2.0.1 - 2024-08-28

Docs

  • Add a new section "None literals inference" to docs for "Into Conversions In-Depth"
  • Fix the docs about the comparison of Into conversions on the "Alternatives" page that were not updated during the v2 release

Fixed

  • Fix capturing of generic params that appear only in return types (#72)
  • Fix support for associated types (#72)

Internal

  • Add more tests for various edge cases (#70)

2.0.0 - 2024-08-26

See the blog post for details.

1.2.1 - 2024-08-12

Other

  • Remove unnecessary const block (#52)
  • Small cleanup (#51)

1.2.0 - 2024-08-09

Added

  • Add #[builder(skip)] attribute to skip generating setters (#44)
  • Add automatic docs for setters (#45)

Other

  • Remove dependencies on easy-ext, heck and itertools (#42)

1.1.0 - 2024-08-07

Added

  • Add no_std support (#36). Thanks @danielschemmel for the contribution!
  • Add asm comparison and benchmarks to docs (#29)
  • Add map!{} and set![] macros (#33). Thanks @korrat for the contribution!

Fixed

  • Fix missing_docs lint in the generated code (#39)

1.0.6 - 2024-08-01

Fixed

  • Explicitly specify the minimum required version of the darling dependency (#30)

1.0.5 - 2024-07-31

Added

  • Add #[must_use] to the builder and other small improvements (#26)

1.0.4 - 2024-07-30

Fixed

  • new() method is now hidden by default and the Builder type name is the same as when #[builder] is on top of a struct (#19)

1.0.3 - 2024-07-30

Fixed

  • Fix missing captured generics on an impl block that aren't referenced in the method (#17)

1.0.2 - 2024-07-29

Fixed

  • Fix a bug of the Default trait requirement for types under an Option (#13)
  • Fix the link to docs.rs to so that it references the latest version (#11)

1.0.1 - 2024-07-29

Fixed

  • Fix handling of raw identifiers (#9)

Other

  • Add example snippet to the docs for "adding builder to existing code" (#7)

1.0.0 - 2024-07-28

Added