summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/profile.c23
-rw-r--r--core/profile.h1
-rw-r--r--core/save-profiledata.c2
-rw-r--r--profile-widget/profilewidget2.cpp3
4 files changed, 12 insertions, 17 deletions
diff --git a/core/profile.c b/core/profile.c
index 5f8be02ac..1492949c4 100644
--- a/core/profile.c
+++ b/core/profile.c
@@ -398,11 +398,10 @@ static void check_setpoint_events(const struct dive *dive, struct divecomputer *
}
-struct plot_info calculate_max_limits_new(struct dive *dive, struct divecomputer *given_dc)
+static void calculate_max_limits_new(struct dive *dive, struct divecomputer *given_dc, struct plot_info *pi)
{
struct divecomputer *dc = &(dive->dc);
bool seen = false;
- static struct plot_info pi;
int maxdepth = dive->maxdepth.mm;
int maxtime = 0;
int maxpressure = 0, minpressure = INT_MAX;
@@ -478,16 +477,15 @@ struct plot_info calculate_max_limits_new(struct dive *dive, struct divecomputer
if (minhr > maxhr)
minhr = maxhr;
- memset(&pi, 0, sizeof(pi));
- pi.maxdepth = maxdepth;
- pi.maxtime = maxtime;
- pi.maxpressure = maxpressure;
- pi.minpressure = minpressure;
- pi.minhr = minhr;
- pi.maxhr = maxhr;
- pi.mintemp = mintemp;
- pi.maxtemp = maxtemp;
- return pi;
+ memset(pi, 0, sizeof(*pi));
+ pi->maxdepth = maxdepth;
+ pi->maxtime = maxtime;
+ pi->maxpressure = maxpressure;
+ pi->minpressure = minpressure;
+ pi->minhr = minhr;
+ pi->maxhr = maxhr;
+ pi->mintemp = mintemp;
+ pi->maxtemp = maxtemp;
}
/* copy the previous entry (we know this exists), update time and depth
@@ -1337,6 +1335,7 @@ void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plo
UNUSED(planner_ds);
#endif
free_plot_info_data(pi);
+ calculate_max_limits_new(dive, dc, pi);
get_dive_gas(dive, &o2, &he, &o2max);
if (dc->divemode == FREEDIVE){
pi->dive_type = FREEDIVE;
diff --git a/core/profile.h b/core/profile.h
index 125e349a8..d9a0ed731 100644
--- a/core/profile.h
+++ b/core/profile.h
@@ -73,7 +73,6 @@ struct ev_select {
bool plot_ev;
};
-struct plot_info calculate_max_limits_new(struct dive *dive, struct divecomputer *given_dc);
void compare_samples(struct plot_data *e1, struct plot_data *e2, char *buf, int bufsize, int sum);
struct plot_info *analyze_plot_info(struct plot_info *pi);
void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool fast, struct deco_state *planner_ds);
diff --git a/core/save-profiledata.c b/core/save-profiledata.c
index d999d4b49..a88ce8ae1 100644
--- a/core/save-profiledata.c
+++ b/core/save-profiledata.c
@@ -202,7 +202,6 @@ static void save_profiles_buffer(struct membuffer *b, bool select_only)
for_each_dive(i, dive) {
if (select_only && !dive->selected)
continue;
- pi = calculate_max_limits_new(dive, &dive->dc);
create_plot_info_new(dive, &dive->dc, &pi, false, planner_deco_state);
put_headers(b);
put_format(b, "\n");
@@ -221,7 +220,6 @@ void save_subtitles_buffer(struct membuffer *b, struct dive *dive, int offset, i
struct plot_info pi;
struct deco_state *planner_deco_state = NULL;
- pi = calculate_max_limits_new(dive, &dive->dc);
create_plot_info_new(dive, &dive->dc, &pi, false, planner_deco_state);
put_format(b, "[Script Info]\n");
diff --git a/profile-widget/profilewidget2.cpp b/profile-widget/profilewidget2.cpp
index f377eeb8e..ca6ce3950 100644
--- a/profile-widget/profilewidget2.cpp
+++ b/profile-widget/profilewidget2.cpp
@@ -636,8 +636,7 @@ void ProfileWidget2::plotDive(const struct dive *d, bool force, bool doClearPict
* shown.
*/
- free_plot_info_data(&plotInfo);
- plotInfo = calculate_max_limits_new(&displayed_dive, currentdc);
+ // create_plot_info_new() automatically frees old plot data
#ifndef SUBSURFACE_MOBILE
create_plot_info_new(&displayed_dive, currentdc, &plotInfo, !shouldCalculateMaxDepth, &DivePlannerPointsModel::instance()->final_deco_state);
#else