2022-05-22 12:37:30 +02:00
|
|
|
# Breaking changes
|
|
|
|
|
|
|
|
Since there is no stable release yet, there is also no proper changelog yet. But
|
|
|
|
since not everyone might want to dive through commit messages to find out what's
|
|
|
|
new and what's changed, this document lists all breaking changes in reverse
|
|
|
|
chronological order. If a new feature did not require any changes to existing
|
|
|
|
code then it will not be listed here.
|
|
|
|
|
2022-07-02 19:10:56 +02:00
|
|
|
## [2022-07-02]
|
|
|
|
|
|
|
|
- The `Params::serialize_fields()` and `Params::deserialize_fields()` methods
|
|
|
|
and the `State` struct now use `BTreeMap`s instead of `HashMap`s so the order
|
|
|
|
is consistent the plugin's state to JSON multiple times. These things are part
|
|
|
|
of NIH-plug's internals, so unless you're implementing the `Params` trait by
|
|
|
|
hand you will not notice any changes.
|
|
|
|
|
2022-06-02 01:16:30 +02:00
|
|
|
## [2022-06-01]
|
|
|
|
|
|
|
|
- The `ClapPlugin::CLAP_FEATURES` field now uses an array of `ClapFeature`
|
|
|
|
values instead of `&'static str`s. CLAP 0.26 contains many new predefined
|
|
|
|
features, and the existing ones now use dashes instead of underscores. Custom
|
|
|
|
features are still possible using `ClapFeature::Custom`.
|
|
|
|
|
|
|
|
## [2022-05-27]
|
2022-05-27 01:17:15 +02:00
|
|
|
|
|
|
|
- The `Plugin::initialize()` method now takes a `&mut impl InitContext` instead
|
2022-05-27 02:30:57 +02:00
|
|
|
of a `&mut impl ProcessContext`.
|
|
|
|
- `Plugin::process()` now takes a new `aux: &mut AuxiliaryBuffers` parameter.
|
|
|
|
This was needed to allow auxiliary (sidechain) inputs and outputs.
|
2022-05-27 01:17:15 +02:00
|
|
|
|
2022-05-22 12:37:30 +02:00
|
|
|
## [2022-05-22]
|
|
|
|
|
|
|
|
- Previously calling `param.non_automatable()` when constructing a parameter
|
|
|
|
also made the parameter hidden. Hiding a parameter is now done through
|
|
|
|
`param.hide()`, while `param.non_automatable()` simply makes it so that the
|
|
|
|
parameter can only be changed manually and not through automation or
|
|
|
|
modulation.
|
2022-05-22 13:33:38 +02:00
|
|
|
- The current processing mode is now stored in `BufferConfig`. Previously this
|
|
|
|
could be fetched through a function on the `ProcessContext`, but this makes
|
|
|
|
more sense as it remains constant until a plugin is deactivated. The
|
|
|
|
`BufferConfig` now contains a field for the minimum buffer size that may or
|
|
|
|
may not be set depending on the plugin API.
|
2022-05-22 12:37:30 +02:00
|
|
|
|
|
|
|
## ...
|
|
|
|
|
|
|
|
Who knows what happened at this point!
|