Skip to content

Commit

Permalink
Only send parameter gestures if a parameter is connected to a juce::A…
Browse files Browse the repository at this point in the history
…udioProcessor
  • Loading branch information
jatinchowdhury18 committed Nov 26, 2023
1 parent d095de4 commit 445b6e0
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,11 @@ class PluginState

/** Initialises the plugin state with a given set of parameters. */
void initialise (ParamHolder& parameters,
juce::AudioProcessor* processor = nullptr,
juce::AudioProcessor* proc = nullptr,
juce::UndoManager* um = nullptr)
{
params = &parameters;
processor = proc;
undoManager = um;
listeners.emplace (parameters);
if (processor != nullptr)
Expand Down Expand Up @@ -80,6 +81,7 @@ class PluginState
mainThreadAction.call (std::forward<Callable> (func), couldBeAudioThread);
}

juce::AudioProcessor* processor = nullptr;
juce::UndoManager* undoManager = nullptr;

private:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,11 @@ namespace chowdsp
{
template <typename Param, typename Callback>
ParameterAttachment<Param, Callback>::ParameterAttachment (Param& parameter,
PluginState& pluginState,
PluginState& plugState,
Callback&& callback)
: ParameterAttachment (parameter, pluginState.getParameterListeners(), std::forward<Callback> (callback))
: ParameterAttachment (parameter, plugState.getParameterListeners(), std::forward<Callback> (callback))
{
pluginState = &plugState;
}

template <typename Param, typename Callback>
Expand All @@ -28,14 +29,14 @@ ParameterAttachment<Param, Callback>::ParameterAttachment (Param& parameter,
template <typename Param, typename Callback>
void ParameterAttachment<Param, Callback>::beginGesture()
{
if (param != nullptr)
if (param != nullptr && pluginState != nullptr && pluginState->processor != nullptr)

Check warning on line 32 in modules/plugin/chowdsp_plugin_state/Frontend/chowdsp_ParameterAttachment.cpp

View check run for this annotation

Codecov / codecov/patch

modules/plugin/chowdsp_plugin_state/Frontend/chowdsp_ParameterAttachment.cpp#L32

Added line #L32 was not covered by tests
param->beginChangeGesture();
}

template <typename Param, typename Callback>
void ParameterAttachment<Param, Callback>::endGesture()
{
if (param != nullptr)
if (param != nullptr && pluginState != nullptr && pluginState->processor != nullptr)

Check warning on line 39 in modules/plugin/chowdsp_plugin_state/Frontend/chowdsp_ParameterAttachment.cpp

View check run for this annotation

Codecov / codecov/patch

modules/plugin/chowdsp_plugin_state/Frontend/chowdsp_ParameterAttachment.cpp#L39

Added line #L39 was not covered by tests
param->endChangeGesture();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ class ParameterAttachment
void setValueAsPartOfGesture (ParamElementType newValue);

ParamType* param = nullptr;
PluginState* pluginState = nullptr;

private:
template <typename Func>
Expand Down

0 comments on commit 445b6e0

Please sign in to comment.