From 1168afba5921cd9090e67bd58ee4ab516cf21a9b Mon Sep 17 00:00:00 2001 From: Paul Walker Date: Sat, 11 Sep 2021 11:06:46 -0400 Subject: [PATCH] Fix an ownership probelm which caused WS Crash WaveShaper is owned by SGE not by the SGE Skin Map, which is fine, but it could lead to a RMB recreating a widget then accidetntally deleting self from underneath. Fix Closes #5056 --- src/gui/SurgeGUIEditor.cpp | 51 ++++++++++++++++++++++++++------------ 1 file changed, 35 insertions(+), 16 deletions(-) diff --git a/src/gui/SurgeGUIEditor.cpp b/src/gui/SurgeGUIEditor.cpp index 3009d56b990..3b73a7e0503 100644 --- a/src/gui/SurgeGUIEditor.cpp +++ b/src/gui/SurgeGUIEditor.cpp @@ -4463,8 +4463,8 @@ SurgeGUIEditor::layoutComponentForSkin(std::shared_ptrctrlgroup_entry - ms_lfo1; if ((lfo_id >= 0) && (lfo_id < n_lfos)) { - lfoDisplay = - componentForSkinSession(skinCtrl->sessionid); + if (!lfoDisplay) + lfoDisplay = std::make_unique(); lfoDisplay->setBounds(skinCtrl->getRect()); lfoDisplay->setSkin(currentSkin, bitmapStore, skinCtrl); lfoDisplay->setTag(p->id + start_paramtags); @@ -4550,7 +4550,22 @@ SurgeGUIEditor::layoutComponentForSkin(std::shared_ptrdefaultComponent == Surge::Skin::Components::NumberField) { - auto pbd = componentForSkinSession(skinCtrl->sessionid); + // some are managed outside of the skin session management + std::unique_ptr pbd; + switch (p->ctrltype) + { + case ct_polylimit: + pbd = std::move(polydisp); + break; + case ct_midikey_or_channel: + pbd = std::move(splitpointControl); + break; + default: + break; + } + + if (!pbd) + pbd = componentForSkinSession(skinCtrl->sessionid); pbd->addListener(this); pbd->setSkin(currentSkin, bitmapStore, skinCtrl); pbd->setTag(tag); @@ -4731,24 +4746,28 @@ SurgeGUIEditor::layoutComponentForSkin(std::shared_ptrgetRect(); - auto hsw = componentForSkinSession(skinCtrl->sessionid); - hsw->addListener(this); - hsw->setStorage(&(synth->storage)); - hsw->setSkin(currentSkin, bitmapStore, skinCtrl); - hsw->setTag(p->id + start_paramtags); - hsw->setBounds(rect); - hsw->setValue(p->get_value_f01()); + + if (!waveshaperSelector) + waveshaperSelector = std::make_unique(); + + waveshaperSelector->addListener(this); + waveshaperSelector->setStorage(&(synth->storage)); + waveshaperSelector->setSkin(currentSkin, bitmapStore, skinCtrl); + waveshaperSelector->setTag(p->id + start_paramtags); + waveshaperSelector->setBounds(rect); + waveshaperSelector->setValue(p->get_value_f01()); auto *parm = dynamic_cast(p->user_data); if (parm && parm->supportsTotalIndexOrdering()) - hsw->setIntOrdering(parm->totalIndexOrdering()); - - setAccessibilityInformationByParameter(hsw.get(), p, "Select"); - frame->getControlGroupLayer(cg_FILTER)->addAndMakeVisible(*hsw); - nonmod_param[paramIndex] = hsw.get(); + waveshaperSelector->setIntOrdering(parm->totalIndexOrdering()); - waveshaperSelector = std::move(hsw); + setAccessibilityInformationByParameter(waveshaperSelector.get(), p, "Select"); + frame->getControlGroupLayer(cg_FILTER)->addAndMakeVisible(*waveshaperSelector); + nonmod_param[paramIndex] = waveshaperSelector.get(); return dynamic_cast(waveshaperSelector.get()); }