diff options
author | Robert C. Helling <helling@atdotde.de> | 2013-07-05 23:42:35 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-08-05 16:59:29 +0200 |
commit | 7293885178de700558f7954725ef9d8965cdb17a (patch) | |
tree | be2f33b3e0ebdb4fd37536183c9b869ebbf7d81b | |
parent | aa5365eb3fc49e6b7ffa2897b7bbd801b173b26b (diff) | |
download | subsurface-7293885178de700558f7954725ef9d8965cdb17a.tar.gz |
Delte the temporary dive from the divelist after calculating deco.
This bug manifested itself as too long deco obligation when moving
waypoints to later and then back to earlier times as all intermedite
versions were created as dives in the divelist (and the saturation of
these "previous dives" was taken into account.
It is not entirely clear to me how the dive will be permanently added to
the divelist once ok is pressed: One could in createDecoStops allocate
struct dive from the heap rather than from the stack and return a pointer
to it and which is then added to the dive list upon pressing ok.
[Dirk Hohndel: add include file to make this compile]
Signed-off-by: Robert C. Helling <helling@atdotde.de>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | dive.h | 1 | ||||
-rw-r--r-- | qt-ui/diveplanner.cpp | 2 |
2 files changed, 3 insertions, 0 deletions
@@ -726,6 +726,7 @@ void get_gas_string(int o2, int he, char *buf, int len); struct divedatapoint *create_dp(int time_incr, int depth, int o2, int he, int po2); void dump_plan(struct diveplan *diveplan); void plan(struct diveplan *diveplan, char **cached_datap, struct dive **divep, char **error_string_p); +void delete_single_dive(int idx); struct event *get_next_event(struct event *event, char *name); diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 25d5df11d..95b6c211c 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -2,6 +2,7 @@ #include "graphicsview-common.h" #include "../dive.h" +#include "../divelist.h" #include <cmath> #include <QMouseEvent> #include <QDebug> @@ -497,6 +498,7 @@ void DivePlannerGraphics::createDecoStops() diveBg->setBrush(pat); deleteTemporaryDivePlan(diveplan.dp); + delete_single_dive(get_divenr(dive)); } void DivePlannerGraphics::deleteTemporaryDivePlan(divedatapoint* dp) |