From ad9d5f31fdd4dffc040df20fb87cc1df303aedcc Mon Sep 17 00:00:00 2001 From: David Lowndes Date: Fri, 22 Nov 2024 14:45:21 +0000 Subject: [PATCH] =?UTF-8?q?Remove=20null=20pointer=20checks=20when=20the?= =?UTF-8?q?=20pointer=20had=20already=20been=20used.=20Th=E2=80=A6=20(#785?= =?UTF-8?q?2)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Remove null pointer checks when the pointer had already been used. The code would have caused a crash before the null pointer test if it'd ever occur, so presumably it doesn't. * Correct a static analyzer result * more storage checks downstream --------- Co-authored-by: David Lowndes Co-authored-by: Paul Walker --- src/common/PatchDB.cpp | 20 ++++++++++++++++---- src/common/SurgeStorage.cpp | 5 ----- src/surge-xt/gui/overlays/LuaEditors.cpp | 4 ++-- src/surge-xt/gui/overlays/MSEGEditor.cpp | 18 ++++++------------ 4 files changed, 24 insertions(+), 23 deletions(-) diff --git a/src/common/PatchDB.cpp b/src/common/PatchDB.cpp index 6ca8ff82af7..e669b2c97d1 100644 --- a/src/common/PatchDB.cpp +++ b/src/common/PatchDB.cpp @@ -803,7 +803,10 @@ CREATE TABLE IF NOT EXISTS Favorites ( } catch (const SQL::Exception &e) { - storage->reportError(e.what(), "PatchDB - Load Check"); + if (storage) + { + storage->reportError(e.what(), "PatchDB - Load Check"); + } return; } @@ -832,7 +835,10 @@ CREATE TABLE IF NOT EXISTS Favorites ( } catch (const SQL::Exception &e) { - storage->reportError(e.what(), "PatchDB - Insert Patch"); + if (storage) + { + storage->reportError(e.what(), "PatchDB - Insert Patch"); + } return; } @@ -934,7 +940,10 @@ CREATE TABLE IF NOT EXISTS Favorites ( } catch (const SQL::Exception &e) { - storage->reportError(e.what(), "PatchDB - FXP Features"); + if (storage) + { + storage->reportError(e.what(), "PatchDB - FXP Features"); + } return; } @@ -950,7 +959,10 @@ CREATE TABLE IF NOT EXISTS Favorites ( } catch (const SQL::Exception &e) { - storage->reportError(e.what(), "PatchDB - FXP Features"); + if (storage) + { + storage->reportError(e.what(), "PatchDB - FXP Features"); + } return; } } diff --git a/src/common/SurgeStorage.cpp b/src/common/SurgeStorage.cpp index 5a04f9ba92c..890e5c472c8 100644 --- a/src/common/SurgeStorage.cpp +++ b/src/common/SurgeStorage.cpp @@ -1332,11 +1332,6 @@ void SurgeStorage::load_wt(int id, Wavetable *wt, OscillatorStorage *osc) return; } - if (!wt) - { - return; - } - load_wt(path_to_string(wt_list[id].path), wt, osc); if (osc) diff --git a/src/surge-xt/gui/overlays/LuaEditors.cpp b/src/surge-xt/gui/overlays/LuaEditors.cpp index 6d5a253b68e..a923d27b84d 100644 --- a/src/surge-xt/gui/overlays/LuaEditors.cpp +++ b/src/surge-xt/gui/overlays/LuaEditors.cpp @@ -292,7 +292,7 @@ struct ExpandingFormulaDebugger : public juce::Component, public Surge::GUI::Ski stepLfoDebugger(); - if (editor && editor->editor) + if (editor->editor) editor->editor->enqueueAccessibleAnnouncement("Reset Debugger"); } @@ -339,7 +339,7 @@ struct ExpandingFormulaDebugger : public juce::Component, public Surge::GUI::Ski debugTable->repaint(); } - if (editor && editor->editor) + if (editor->editor) editor->editor->enqueueAccessibleAnnouncement("Stepped Debugger"); } diff --git a/src/surge-xt/gui/overlays/MSEGEditor.cpp b/src/surge-xt/gui/overlays/MSEGEditor.cpp index 55eb2555c30..10581fb0a6a 100644 --- a/src/surge-xt/gui/overlays/MSEGEditor.cpp +++ b/src/surge-xt/gui/overlays/MSEGEditor.cpp @@ -2943,14 +2943,11 @@ void MSEGControlRegion::valueChanged(Surge::GUI::IComponentTagValue *p) Surge::MSEG::modifyEditMode(this->ms, editMode); // zoom to fit - if (canvas) - { - canvas->ms->axisStart = 0.f; - canvas->ms->axisWidth = editMode ? 1.f : ms->envelopeModeDuration; + canvas->ms->axisStart = 0.f; + canvas->ms->axisWidth = editMode ? 1.f : ms->envelopeModeDuration; - canvas->modelChanged(0, false); - canvas->repaint(); - } + canvas->modelChanged(0, false); + canvas->repaint(); repaint(); break; @@ -2961,11 +2958,8 @@ void MSEGControlRegion::valueChanged(Surge::GUI::IComponentTagValue *p) canvas->pushToUndo(); int m = floor((val * 2) + 0.1) + 1; ms->loopMode = (MSEGStorage::LoopMode)m; - if (canvas) - { - canvas->modelChanged(); - canvas->repaint(); - } + canvas->modelChanged(); + canvas->repaint(); repaint(); break; }