diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2014-07-02 21:31:55 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-07-03 09:37:55 -0700 |
commit | 20d9fafd7cc5d5b0fde5a4ace8c59d6bfed20c75 (patch) | |
tree | e56f70bc960c10874af1620b048b9c1bb04d15c8 | |
parent | 2cfe97e4dd5093b13301ed98a97b6edd41da56c7 (diff) | |
download | subsurface-20d9fafd7cc5d5b0fde5a4ace8c59d6bfed20c75.tar.gz |
UI restructure: improve memory handling in maintab
Free strings before overwriting them. Use copy_dive() instead of just
copying the dive structure.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | qt-ui/maintab.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp index 09f3e5a06..049ad7fb7 100644 --- a/qt-ui/maintab.cpp +++ b/qt-ui/maintab.cpp @@ -265,8 +265,8 @@ void MainTab::enableEdition(EditMode newEditMode) if (MainWindow::instance() && MainWindow::instance()->dive_list()->selectedTrips().count() == 1) { // we are editing trip location and notes displayMessage(tr("This trip is being edited.")); - displayed_dive.location = current_dive->divetrip->location; - displayed_dive.notes = current_dive->divetrip->notes; + displayed_dive.location = copy_string(current_dive->divetrip->location); + displayed_dive.notes = copy_string(current_dive->divetrip->notes); ui.dateEdit->setEnabled(false); editMode = TRIP; } else { @@ -842,7 +842,7 @@ void MainTab::rejectChanges() DivePlannerPointsModel::instance()->restoreBackupDive(); } if (selected_dive >= 0) { - displayed_dive = *get_dive(selected_dive); + copy_dive(current_dive, &displayed_dive); cylindersModel->setDive(&displayed_dive); weightModel->setDive(&displayed_dive); } else { @@ -851,6 +851,7 @@ void MainTab::rejectChanges() setEnabled(false); } } +#if 0 // this makes no sense anymore - but let's make sure I think this through // now let's avoid memory leaks if (MainWindow::instance() && MainWindow::instance()->dive_list()->selectedTrips().count() == 1) { if (displayed_dive.location != current_dive->divetrip->location) @@ -866,6 +867,7 @@ void MainTab::rejectChanges() FREE_IF_DIFFERENT(notes); FREE_IF_DIFFERENT(suit); } +#endif hideMessage(); MainWindow::instance()->dive_list()->setEnabled(true); ui.dateEdit->setEnabled(true); @@ -904,6 +906,7 @@ void MainTab::on_buddy_textChanged() for (int i = 0; i < text_list.size(); i++) text_list[i] = text_list[i].trimmed(); QString text = text_list.join(", "); + free(displayed_dive.buddy); displayed_dive.buddy = strdup(text.toUtf8().data()); markChangedWidget(ui.buddy); } @@ -916,6 +919,7 @@ void MainTab::on_divemaster_textChanged() for (int i = 0; i < text_list.size(); i++) text_list[i] = text_list[i].trimmed(); QString text = text_list.join(", "); + free(displayed_dive.divemaster); displayed_dive.divemaster = strdup(text.toUtf8().data()); markChangedWidget(ui.divemaster); } @@ -1036,6 +1040,7 @@ void MainTab::on_location_textChanged(const QString &text) { if (editMode == NONE) return; + free(displayed_dive.location); displayed_dive.location = strdup(ui.location->text().toUtf8().data()); markChangedWidget(ui.location); } @@ -1044,6 +1049,7 @@ void MainTab::on_suit_textChanged(const QString &text) { if (editMode == NONE) return; + free(displayed_dive.suit); displayed_dive.suit = strdup(text.toUtf8().data()); markChangedWidget(ui.suit); } @@ -1052,6 +1058,7 @@ void MainTab::on_notes_textChanged() { if (editMode == NONE) return; + free(displayed_dive.notes); displayed_dive.notes = strdup(ui.notes->toPlainText().toUtf8().data()); markChangedWidget(ui.notes); } |