From 1a2c90fdfd70bc64aea3410807a3139cd080f3dc Mon Sep 17 00:00:00 2001 From: Robbert van der Helm Date: Mon, 31 Jan 2022 13:33:30 +0100 Subject: [PATCH] Set the VST3 parameter step counts --- src/wrapper/vst3.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/wrapper/vst3.rs b/src/wrapper/vst3.rs index 3b91259e..70d8815e 100644 --- a/src/wrapper/vst3.rs +++ b/src/wrapper/vst3.rs @@ -488,7 +488,7 @@ impl IEditController for Wrapper<'_, P> { u16strlcpy(&mut info.title, "Bypass"); u16strlcpy(&mut info.short_title, "Bypass"); u16strlcpy(&mut info.units, ""); - info.step_count = 0; + info.step_count = 1; info.default_normalized_value = 0.0; info.unit_id = vst3_sys::vst::kRootUnitId; info.flags = vst3_sys::vst::ParameterFlags::kCanAutomate as i32 @@ -502,8 +502,13 @@ impl IEditController for Wrapper<'_, P> { u16strlcpy(&mut info.title, param_ptr.name()); u16strlcpy(&mut info.short_title, param_ptr.name()); u16strlcpy(&mut info.units, param_ptr.unit()); - // TODO: Don't forget this when we add enum parameters - info.step_count = 0; + info.step_count = match param_ptr { + ParamPtr::FloatParam(_) => 0, + ParamPtr::IntParam(p) => match (**p).range { + crate::params::Range::Linear { min, max } => max - min, + }, + ParamPtr::BoolParam(_) => 1, + }; info.default_normalized_value = *default_value as f64; info.unit_id = vst3_sys::vst::kRootUnitId; info.flags = vst3_sys::vst::ParameterFlags::kCanAutomate as i32;