2022-01-31 03:17:34 +11:00
|
|
|
//! Utilities for saving a [crate::plugin::Plugin]'s state.
|
2022-01-30 00:20:14 +11:00
|
|
|
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use std::collections::HashMap;
|
|
|
|
|
2022-01-30 00:54:48 +11:00
|
|
|
/// A plain, unnormalized value for a parameter.
|
2022-01-30 00:20:14 +11:00
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
|
|
#[serde(rename_all = "snake_case")]
|
|
|
|
pub(crate) enum ParamValue {
|
|
|
|
F32(f32),
|
|
|
|
I32(i32),
|
2022-01-30 12:04:35 +11:00
|
|
|
Bool(bool),
|
2022-01-30 00:20:14 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// A plugin's state so it can be restored at a later point.
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
|
|
pub(crate) struct State {
|
|
|
|
/// The plugin's parameter values. These are stored unnormalized. This mean sthe old values will
|
|
|
|
/// be recalled when when the parameter's range gets increased. Doing so may still mess with
|
|
|
|
/// parmaeter automation though, depending on how the host impelments that.
|
2022-01-30 02:42:20 +11:00
|
|
|
pub params: HashMap<String, ParamValue>,
|
2022-01-31 03:09:18 +11:00
|
|
|
/// Arbitrary fields that should be persisted together with the plugin's parameters. Any field
|
2022-02-05 22:56:03 +11:00
|
|
|
/// on the [crate::param::internals::Params] struct that's annotated with `#[persist =
|
|
|
|
/// "stable_name"]` will be persisted this way.
|
2022-01-31 03:29:25 +11:00
|
|
|
///
|
2022-01-31 04:23:13 +11:00
|
|
|
/// The individual fields are also serialized as JSON so they can safely be restored
|
|
|
|
/// independently of the other fields.
|
|
|
|
pub fields: HashMap<String, String>,
|
2022-01-31 04:15:01 +11:00
|
|
|
}
|