mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Check error code of get_cylider_idx_by_use()
If not cylinder with type DILUENT or OXYGEN is defined, this function returns -1 which should not be used as an index to an array. This patch adds code to check for this return value and exit gracefully. On line I marked with a comment. Someone more knowledgeable of that part of code than me should double check that return is here what we want. [Dirk Hohndel: fixed small oversight...] Signed-off-by: Robert C. Helling <helling@atdotde.de> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
38bbed978a
commit
13934b0f02
3 changed files with 11 additions and 2 deletions
6
dive.c
6
dive.c
|
@ -722,6 +722,8 @@ void per_cylinder_mean_depth(struct dive *dive, struct divecomputer *dc, int *me
|
|||
if (dc->dctype == CCR) {
|
||||
// Do the same for the O2 cylinder
|
||||
int o2_cyl = get_cylinder_idx_by_use(dive, OXYGEN);
|
||||
if (o2_cyl < 0)
|
||||
return;
|
||||
mean[o2_cyl] = dc->meandepth.mm;
|
||||
duration[o2_cyl] = dc->duration.seconds;
|
||||
}
|
||||
|
@ -775,6 +777,8 @@ static void fixup_pressure(struct dive *dive, struct sample *sample, enum cylind
|
|||
pressure = sample->o2cylinderpressure.mbar;
|
||||
index = get_cylinder_idx_by_use(dive, OXYGEN);
|
||||
}
|
||||
if (index < 0)
|
||||
return;
|
||||
if (!pressure)
|
||||
return;
|
||||
|
||||
|
@ -846,7 +850,7 @@ int explicit_first_cylinder(struct dive *dive, struct divecomputer *dc)
|
|||
if (ev && dc && dc->sample && ev->time.seconds == dc->sample[0].time.seconds)
|
||||
return get_cylinder_index(dive, ev);
|
||||
else if (dc->dctype == CCR)
|
||||
return get_cylinder_idx_by_use(dive, DILUENT);
|
||||
return MAX(get_cylinder_idx_by_use(dive, DILUENT), 0);
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue