summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2019-04-26 18:03:23 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-04-29 13:03:31 -0700
commitd498fcad61253591c653e6285173b653483926bf (patch)
tree9b8b7f338b00376f7c636f778509003d86d7a5a7
parentaf00361929c00febea42d067785ea1a76c493e7b (diff)
downloadsubsurface-d498fcad61253591c653e6285173b653483926bf.tar.gz
Printing: fix memory leak
For printing, DiveObjectHelpers are allocated and pointers to these are stored in a QVariantList. The objects are never freed. To fix this leak, keep the objects in a std::list<>. std::list<> was chosen because 1) Pointers to elements stay valid during its lifetime. 2) Objects can be constructed directly in the list with emplace_back() Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r--desktop-widgets/templatelayout.cpp15
1 files changed, 11 insertions, 4 deletions
diff --git a/desktop-widgets/templatelayout.cpp b/desktop-widgets/templatelayout.cpp
index 27afbac65..06039dbf2 100644
--- a/desktop-widgets/templatelayout.cpp
+++ b/desktop-widgets/templatelayout.cpp
@@ -1,6 +1,7 @@
// SPDX-License-Identifier: GPL-2.0
#include <QFileDevice>
#include <string>
+#include <list>
#include "templatelayout.h"
#include "core/display.h"
@@ -141,12 +142,18 @@ QString TemplateLayout::generate()
Grantlee::registerMetaType<template_options>();
Grantlee::registerMetaType<print_options>();
+ // Note: Currently, this should not be transformed into a QVector<> or std::vector<>,
+ // as diveList contains pointers to elements in this list. But vectors might relocate
+ // and thus invalidate the pointers! std::list<> is used here, because the new elements
+ // can be directly constructed in the list with the emplace_back() call.
+ // Ultimately, the memory management should be fixed.
+ std::list<DiveObjectHelper> diveObjectList;
QVariantList diveList;
struct dive *dive;
if (in_planner()) {
- DiveObjectHelper *d = new DiveObjectHelper(&displayed_dive);
- diveList.append(QVariant::fromValue(d));
+ diveObjectList.emplace_back(&displayed_dive);
+ diveList.append(QVariant::fromValue(&diveObjectList.back()));
emit progressUpdated(100.0);
} else {
int i;
@@ -154,8 +161,8 @@ QString TemplateLayout::generate()
//TODO check for exporting selected dives only
if (!dive->selected && printOptions->print_selected)
continue;
- DiveObjectHelper *d = new DiveObjectHelper(dive);
- diveList.append(QVariant::fromValue(d));
+ diveObjectList.emplace_back(dive);
+ diveList.append(QVariant::fromValue(&diveObjectList.back()));
progress++;
emit progressUpdated(lrint(progress * 100.0 / totalWork));
}