Skip to content

Commit

Permalink
Fix a VST3 off-by-one error in a stepped param (#259)
Browse files Browse the repository at this point in the history
* fix: #258

* Fix a VST3 off-by-one error in a stepped param

The step count is not +1, but rather just the range, as
demonstrated by the clap-first distortion plugin compared in
bitwig.

Closes #258

---------

Co-authored-by: defiantnerd <[email protected]>
  • Loading branch information
baconpaul and defiantnerd authored Jun 11, 2024
1 parent 6fa9e1c commit f4ee4ea
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 6 deletions.
8 changes: 4 additions & 4 deletions src/detail/vst3/parameter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,7 @@ Vst3Parameter* Vst3Parameter::create(
v.defaultNormalizedValue = (info->default_value - info->min_value) / param_range;
if ((info->flags & CLAP_PARAM_IS_STEPPED) || (info->flags & CLAP_PARAM_IS_ENUM))
{
auto steps = param_range + 1;
auto steps = param_range;
v.stepCount = steps;
}
else
Expand Down Expand Up @@ -166,15 +166,15 @@ Vst3Parameter* Vst3Parameter::create(uint8_t bus, uint8_t channel, uint8_t cc, V
if (cc == Vst::ControllerNumbers::kCtrlProgramChange)
{
v.flags |= Vst::ParameterInfo::kIsProgramChange | Vst::ParameterInfo::kCanAutomate;
v.stepCount = 128;
v.stepCount = 127;
}

v.defaultNormalizedValue = 0;
v.stepCount = 128;
v.stepCount = 127;

if (cc == Vst::ControllerNumbers::kPitchBend)
{
v.stepCount = 16384;
v.stepCount = 16383;
}

auto result = new Vst3Parameter(v, bus, channel, cc);
Expand Down
4 changes: 2 additions & 2 deletions src/detail/vst3/parameter.h
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ class Vst3Parameter : public Steinberg::Vst::Parameter
{
if (info.stepCount > 0)
{
return (vst3value * info.stepCount) + min_value;
return (vst3value * info.stepCount + 1) + min_value;
}
return (vst3value * (max_value - min_value)) + min_value;
}
Expand All @@ -63,7 +63,7 @@ class Vst3Parameter : public Steinberg::Vst::Parameter
auto& info = this->getInfo();
if (info.stepCount > 0)
{
return (clapvalue - min_value) / float(info.stepCount);
return (clapvalue - min_value) / float(info.stepCount + 1);
}
return (clapvalue - min_value) / (max_value - min_value);
}
Expand Down

0 comments on commit f4ee4ea

Please sign in to comment.