mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-30 22:20:21 +00:00
core: make calculate_cns() member of dive_table
This function implicitely accessed the global divelog. To make that explicit make it a member of dive_table, such that the caller must access it via the global variable. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
f3b8e3c4aa
commit
b34116e2e2
8 changed files with 68 additions and 67 deletions
|
@ -1101,7 +1101,7 @@ void AddCylinder::undo()
|
||||||
{
|
{
|
||||||
for (size_t i = 0; i < dives.size(); ++i) {
|
for (size_t i = 0; i < dives.size(); ++i) {
|
||||||
remove_cylinder(dives[i], indexes[i]);
|
remove_cylinder(dives[i], indexes[i]);
|
||||||
update_cylinder_related_info(dives[i]);
|
divelog.dives.update_cylinder_related_info(dives[i]);
|
||||||
emit diveListNotifier.cylinderRemoved(dives[i], indexes[i]);
|
emit diveListNotifier.cylinderRemoved(dives[i], indexes[i]);
|
||||||
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
||||||
}
|
}
|
||||||
|
@ -1114,7 +1114,7 @@ void AddCylinder::redo()
|
||||||
int index = first_hidden_cylinder(d);
|
int index = first_hidden_cylinder(d);
|
||||||
indexes.push_back(index);
|
indexes.push_back(index);
|
||||||
add_cylinder(&d->cylinders, index, cyl);
|
add_cylinder(&d->cylinders, index, cyl);
|
||||||
update_cylinder_related_info(d);
|
divelog.dives.update_cylinder_related_info(d);
|
||||||
emit diveListNotifier.cylinderAdded(d, index);
|
emit diveListNotifier.cylinderAdded(d, index);
|
||||||
invalidate_dive_cache(d); // Ensure that dive is written in git_save()
|
invalidate_dive_cache(d); // Ensure that dive is written in git_save()
|
||||||
}
|
}
|
||||||
|
@ -1201,7 +1201,7 @@ void RemoveCylinder::undo()
|
||||||
std::vector<int> mapping = get_cylinder_map_for_add(dives[i]->cylinders.size(), indexes[i]);
|
std::vector<int> mapping = get_cylinder_map_for_add(dives[i]->cylinders.size(), indexes[i]);
|
||||||
add_cylinder(&dives[i]->cylinders, indexes[i], cyl[i]);
|
add_cylinder(&dives[i]->cylinders, indexes[i], cyl[i]);
|
||||||
cylinder_renumber(*dives[i], &mapping[0]);
|
cylinder_renumber(*dives[i], &mapping[0]);
|
||||||
update_cylinder_related_info(dives[i]);
|
divelog.dives.update_cylinder_related_info(dives[i]);
|
||||||
emit diveListNotifier.cylinderAdded(dives[i], indexes[i]);
|
emit diveListNotifier.cylinderAdded(dives[i], indexes[i]);
|
||||||
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
||||||
}
|
}
|
||||||
|
@ -1213,7 +1213,7 @@ void RemoveCylinder::redo()
|
||||||
std::vector<int> mapping = get_cylinder_map_for_remove(dives[i]->cylinders.size(), indexes[i]);
|
std::vector<int> mapping = get_cylinder_map_for_remove(dives[i]->cylinders.size(), indexes[i]);
|
||||||
remove_cylinder(dives[i], indexes[i]);
|
remove_cylinder(dives[i], indexes[i]);
|
||||||
cylinder_renumber(*dives[i], &mapping[0]);
|
cylinder_renumber(*dives[i], &mapping[0]);
|
||||||
update_cylinder_related_info(dives[i]);
|
divelog.dives.update_cylinder_related_info(dives[i]);
|
||||||
emit diveListNotifier.cylinderRemoved(dives[i], indexes[i]);
|
emit diveListNotifier.cylinderRemoved(dives[i], indexes[i]);
|
||||||
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
||||||
}
|
}
|
||||||
|
@ -1273,7 +1273,7 @@ void EditCylinder::redo()
|
||||||
const std::string &name = cyl[i].type.description;
|
const std::string &name = cyl[i].type.description;
|
||||||
set_tank_info_data(tank_info_table, name, cyl[i].type.size, cyl[i].type.workingpressure);
|
set_tank_info_data(tank_info_table, name, cyl[i].type.size, cyl[i].type.workingpressure);
|
||||||
std::swap(*get_cylinder(dives[i], indexes[i]), cyl[i]);
|
std::swap(*get_cylinder(dives[i], indexes[i]), cyl[i]);
|
||||||
update_cylinder_related_info(dives[i]);
|
divelog.dives.update_cylinder_related_info(dives[i]);
|
||||||
emit diveListNotifier.cylinderEdited(dives[i], indexes[i]);
|
emit diveListNotifier.cylinderEdited(dives[i], indexes[i]);
|
||||||
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
invalidate_dive_cache(dives[i]); // Ensure that dive is written in git_save()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1092,7 +1092,7 @@ struct dive *fixup_dive(struct dive *dive)
|
||||||
if (same_rounded_pressure(cyl.sample_end, cyl.end))
|
if (same_rounded_pressure(cyl.sample_end, cyl.end))
|
||||||
cyl.end.mbar = 0;
|
cyl.end.mbar = 0;
|
||||||
}
|
}
|
||||||
update_cylinder_related_info(dive);
|
divelog.dives.update_cylinder_related_info(dive);
|
||||||
for (auto &ws: dive->weightsystems)
|
for (auto &ws: dive->weightsystems)
|
||||||
add_weightsystem_description(ws);
|
add_weightsystem_description(ws);
|
||||||
/* we should always have a uniq ID as that gets assigned during dive creation,
|
/* we should always have a uniq ID as that gets assigned during dive creation,
|
||||||
|
|
|
@ -181,15 +181,15 @@ static int calculate_otu(const struct dive *dive)
|
||||||
po2 for each segment. Empirical testing showed that, for large changes in depth, the cns calculation for the mean po2
|
po2 for each segment. Empirical testing showed that, for large changes in depth, the cns calculation for the mean po2
|
||||||
value is extremely close, if not identical to the additive calculations for 0.1 bar increments in po2 from the start
|
value is extremely close, if not identical to the additive calculations for 0.1 bar increments in po2 from the start
|
||||||
to the end of the segment, assuming a constant rate of change in po2 (i.e. depth) with time. */
|
to the end of the segment, assuming a constant rate of change in po2 (i.e. depth) with time. */
|
||||||
static double calculate_cns_dive(const struct dive *dive)
|
static double calculate_cns_dive(const struct dive &dive)
|
||||||
{
|
{
|
||||||
const struct divecomputer *dc = &dive->dcs[0];
|
const struct divecomputer *dc = &dive.dcs[0];
|
||||||
double cns = 0.0;
|
double cns = 0.0;
|
||||||
double rate;
|
double rate;
|
||||||
/* Calculate the CNS for each sample in this dive and sum them */
|
/* Calculate the CNS for each sample in this dive and sum them */
|
||||||
for (auto [psample, sample]: pairwise_range(dc->samples)) {
|
for (auto [psample, sample]: pairwise_range(dc->samples)) {
|
||||||
int t = sample.time.seconds - psample.time.seconds;
|
int t = sample.time.seconds - psample.time.seconds;
|
||||||
int po2 = get_sample_o2(dive, dc, sample, psample);
|
int po2 = get_sample_o2(&dive, dc, sample, psample);
|
||||||
/* Don't increase CNS when po2 below 500 matm */
|
/* Don't increase CNS when po2 below 500 matm */
|
||||||
if (po2 <= 500)
|
if (po2 <= 500)
|
||||||
continue;
|
continue;
|
||||||
|
@ -204,7 +204,7 @@ static double calculate_cns_dive(const struct dive *dive)
|
||||||
/* this only gets called if dive->maxcns == 0 which means we know that
|
/* this only gets called if dive->maxcns == 0 which means we know that
|
||||||
* none of the divecomputers has tracked any CNS for us
|
* none of the divecomputers has tracked any CNS for us
|
||||||
* so we calculated it "by hand" */
|
* so we calculated it "by hand" */
|
||||||
static int calculate_cns(struct dive *dive)
|
int dive_table::calculate_cns(struct dive *dive) const
|
||||||
{
|
{
|
||||||
double cns = 0.0;
|
double cns = 0.0;
|
||||||
timestamp_t last_starttime, last_endtime = 0;
|
timestamp_t last_starttime, last_endtime = 0;
|
||||||
|
@ -213,27 +213,25 @@ static int calculate_cns(struct dive *dive)
|
||||||
if (dive->cns)
|
if (dive->cns)
|
||||||
return dive->cns;
|
return dive->cns;
|
||||||
|
|
||||||
size_t divenr = divelog.dives.get_idx(dive);
|
size_t divenr = get_idx(dive);
|
||||||
|
int nr_dives = static_cast<int>(size());
|
||||||
int i = divenr != std::string::npos ? static_cast<int>(divenr)
|
int i = divenr != std::string::npos ? static_cast<int>(divenr)
|
||||||
: static_cast<int>(divelog.dives.size());
|
: nr_dives;
|
||||||
int nr_dives = static_cast<int>(divelog.dives.size());
|
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
if (static_cast<size_t>(i) < divelog.table->size())
|
if (static_cast<size_t>(i) < size())
|
||||||
printf("\n\n*** CNS for dive #%d %d\n", i, (*divelog.table)[i]->number);
|
printf("\n\n*** CNS for dive #%d %d\n", i, ()[i]->number);
|
||||||
else
|
else
|
||||||
printf("\n\n*** CNS for dive #%d\n", i);
|
printf("\n\n*** CNS for dive #%d\n", i);
|
||||||
#endif
|
#endif
|
||||||
/* Look at next dive in dive list table and correct i when needed */
|
/* Look at next dive in dive list table and correct i when needed */
|
||||||
while (i < nr_dives - 1) {
|
while (i < nr_dives - 1) {
|
||||||
struct dive *pdive = get_dive(i);
|
if ((*this)[i]->when > dive->when)
|
||||||
if (!pdive || pdive->when > dive->when)
|
|
||||||
break;
|
break;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
/* Look at previous dive in dive list table and correct i when needed */
|
/* Look at previous dive in dive list table and correct i when needed */
|
||||||
while (i > 0) {
|
while (i > 0) {
|
||||||
struct dive *pdive = get_dive(i - 1);
|
if ((*this)[i - 1]->when < dive->when)
|
||||||
if (!pdive || pdive->when < dive->when)
|
|
||||||
break;
|
break;
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
|
@ -246,24 +244,24 @@ static int calculate_cns(struct dive *dive)
|
||||||
if (static_cast<size_t>(i) == divenr && i > 0)
|
if (static_cast<size_t>(i) == divenr && i > 0)
|
||||||
i--;
|
i--;
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Check if dive #%d %d has to be considered as prev dive: ", i, get_dive(i)->number);
|
printf("Check if dive #%d %d has to be considered as prev dive: ", i, (*this)[i]->number);
|
||||||
#endif
|
#endif
|
||||||
struct dive *pdive = get_dive(i);
|
const struct dive &pdive = *(*this)[i];
|
||||||
/* we don't want to mix dives from different trips as we keep looking
|
/* we don't want to mix dives from different trips as we keep looking
|
||||||
* for how far back we need to go */
|
* for how far back we need to go */
|
||||||
if (dive->divetrip && pdive->divetrip != dive->divetrip) {
|
if (dive->divetrip && pdive.divetrip != dive->divetrip) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - other dive trip\n");
|
printf("No - other dive trip\n");
|
||||||
#endif
|
#endif
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!pdive || pdive->when >= dive->when || pdive->endtime() + 12 * 60 * 60 < last_starttime) {
|
if (pdive.when >= dive->when || pdive.endtime() + 12 * 60 * 60 < last_starttime) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No\n");
|
printf("No\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
last_starttime = pdive->when;
|
last_starttime = pdive.when;
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Yes\n");
|
printf("Yes\n");
|
||||||
#endif
|
#endif
|
||||||
|
@ -271,18 +269,18 @@ static int calculate_cns(struct dive *dive)
|
||||||
/* Walk forward and add dives and surface intervals to CNS */
|
/* Walk forward and add dives and surface intervals to CNS */
|
||||||
while (++i < nr_dives) {
|
while (++i < nr_dives) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Check if dive #%d %d will be really added to CNS calc: ", i, get_dive(i)->number);
|
printf("Check if dive #%d %d will be really added to CNS calc: ", i, (*this)[i]->number);
|
||||||
#endif
|
#endif
|
||||||
struct dive *pdive = get_dive(i);
|
const struct dive &pdive = *(*this)[i];
|
||||||
/* again skip dives from different trips */
|
/* again skip dives from different trips */
|
||||||
if (dive->divetrip && dive->divetrip != pdive->divetrip) {
|
if (dive->divetrip && dive->divetrip != pdive.divetrip) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - other dive trip\n");
|
printf("No - other dive trip\n");
|
||||||
#endif
|
#endif
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
/* Don't add future dives */
|
/* Don't add future dives */
|
||||||
if (pdive->when >= dive->when) {
|
if (pdive.when >= dive->when) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - future or same dive\n");
|
printf("No - future or same dive\n");
|
||||||
#endif
|
#endif
|
||||||
|
@ -301,7 +299,7 @@ static int calculate_cns(struct dive *dive)
|
||||||
|
|
||||||
/* CNS reduced with 90min halftime during surface interval */
|
/* CNS reduced with 90min halftime during surface interval */
|
||||||
if (last_endtime)
|
if (last_endtime)
|
||||||
cns /= pow(2, (pdive->when - last_endtime) / (90.0 * 60.0));
|
cns /= pow(2, (pdive.when - last_endtime) / (90.0 * 60.0));
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("CNS after surface interval: %f\n", cns);
|
printf("CNS after surface interval: %f\n", cns);
|
||||||
#endif
|
#endif
|
||||||
|
@ -311,8 +309,8 @@ static int calculate_cns(struct dive *dive)
|
||||||
printf("CNS after previous dive: %f\n", cns);
|
printf("CNS after previous dive: %f\n", cns);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
last_starttime = pdive->when;
|
last_starttime = pdive.when;
|
||||||
last_endtime = pdive->endtime();
|
last_endtime = pdive.endtime();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* CNS reduced with 90min halftime during surface interval */
|
/* CNS reduced with 90min halftime during surface interval */
|
||||||
|
@ -322,7 +320,7 @@ static int calculate_cns(struct dive *dive)
|
||||||
printf("CNS after last surface interval: %f\n", cns);
|
printf("CNS after last surface interval: %f\n", cns);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cns += calculate_cns_dive(dive);
|
cns += calculate_cns_dive(*dive);
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("CNS after dive: %f\n", cns);
|
printf("CNS after dive: %f\n", cns);
|
||||||
#endif
|
#endif
|
||||||
|
@ -391,9 +389,9 @@ static int calculate_sac(const struct dive *dive)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* for now we do this based on the first divecomputer */
|
/* for now we do this based on the first divecomputer */
|
||||||
static void add_dive_to_deco(struct deco_state *ds, struct dive *dive, bool in_planner)
|
static void add_dive_to_deco(struct deco_state *ds, const struct dive *dive, bool in_planner)
|
||||||
{
|
{
|
||||||
struct divecomputer *dc = &dive->dcs[0];
|
const struct divecomputer *dc = &dive->dcs[0];
|
||||||
|
|
||||||
gasmix_loop loop(*dive, dive->dcs[0]);
|
gasmix_loop loop(*dive, dive->dcs[0]);
|
||||||
divemode_loop loop_d(dive->dcs[0]);
|
divemode_loop loop_d(dive->dcs[0]);
|
||||||
|
@ -417,7 +415,7 @@ static void add_dive_to_deco(struct deco_state *ds, struct dive *dive, bool in_p
|
||||||
/* return negative surface time if dives are overlapping */
|
/* return negative surface time if dives are overlapping */
|
||||||
/* The place you call this function is likely the place where you want
|
/* The place you call this function is likely the place where you want
|
||||||
* to create the deco_state */
|
* to create the deco_state */
|
||||||
int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_planner)
|
int dive_table::init_decompression(struct deco_state *ds, const struct dive *dive, bool in_planner) const
|
||||||
{
|
{
|
||||||
int surface_time = 48 * 60 * 60;
|
int surface_time = 48 * 60 * 60;
|
||||||
timestamp_t last_endtime = 0, last_starttime = 0;
|
timestamp_t last_endtime = 0, last_starttime = 0;
|
||||||
|
@ -427,27 +425,25 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
if (!dive)
|
if (!dive)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
int nr_dives = static_cast<int>(divelog.dives.size());
|
int nr_dives = static_cast<int>(size());
|
||||||
size_t divenr = divelog.dives.get_idx(dive);
|
size_t divenr = get_idx(dive);
|
||||||
int i = divenr != std::string::npos ? static_cast<int>(divenr)
|
int i = divenr != std::string::npos ? static_cast<int>(divenr)
|
||||||
: static_cast<int>(divelog.dives.size());
|
: nr_dives;
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
if (i < dive_table.nr)
|
if (i < dive_table.nr)
|
||||||
printf("\n\n*** Init deco for dive #%d %d\n", i, get_dive(i)->number);
|
printf("\n\n*** Init deco for dive #%d %d\n", i, (*this)[i]->number);
|
||||||
else
|
else
|
||||||
printf("\n\n*** Init deco for dive #%d\n", i);
|
printf("\n\n*** Init deco for dive #%d\n", i);
|
||||||
#endif
|
#endif
|
||||||
/* Look at next dive in dive list table and correct i when needed */
|
/* Look at next dive in dive list table and correct i when needed */
|
||||||
while (i + 1 < nr_dives) {
|
while (i + 1 < nr_dives) {
|
||||||
struct dive *pdive = get_dive(i);
|
if ((*this)[i]->when > dive->when)
|
||||||
if (!pdive || pdive->when > dive->when)
|
|
||||||
break;
|
break;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
/* Look at previous dive in dive list table and correct i when needed */
|
/* Look at previous dive in dive list table and correct i when needed */
|
||||||
while (i > 0) {
|
while (i > 0) {
|
||||||
struct dive *pdive = get_dive(i - 1);
|
if ((*this)[i - 1]->when < dive->when)
|
||||||
if (!pdive || pdive->when < dive->when)
|
|
||||||
break;
|
break;
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
|
@ -460,24 +456,24 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
if (static_cast<size_t>(i) == divenr && i > 0)
|
if (static_cast<size_t>(i) == divenr && i > 0)
|
||||||
i--;
|
i--;
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Check if dive #%d %d has to be considered as prev dive: ", i, get_dive(i)->number);
|
printf("Check if dive #%d %d has to be considered as prev dive: ", i, (*this)[i]->number);
|
||||||
#endif
|
#endif
|
||||||
struct dive *pdive = get_dive(i);
|
const struct dive &pdive = *(*this)[i];
|
||||||
/* we don't want to mix dives from different trips as we keep looking
|
/* we don't want to mix dives from different trips as we keep looking
|
||||||
* for how far back we need to go */
|
* for how far back we need to go */
|
||||||
if (dive->divetrip && pdive->divetrip != dive->divetrip) {
|
if (dive->divetrip && pdive.divetrip != dive->divetrip) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - other dive trip\n");
|
printf("No - other dive trip\n");
|
||||||
#endif
|
#endif
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!pdive || pdive->when >= dive->when || pdive->endtime() + 48 * 60 * 60 < last_starttime) {
|
if (pdive.when >= dive->when || pdive.endtime() + 48 * 60 * 60 < last_starttime) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No\n");
|
printf("No\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
last_starttime = pdive->when;
|
last_starttime = pdive.when;
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Yes\n");
|
printf("Yes\n");
|
||||||
#endif
|
#endif
|
||||||
|
@ -485,18 +481,18 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
/* Walk forward an add dives and surface intervals to deco */
|
/* Walk forward an add dives and surface intervals to deco */
|
||||||
while (++i < nr_dives) {
|
while (++i < nr_dives) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Check if dive #%d %d will be really added to deco calc: ", i, get_dive(i)->number);
|
printf("Check if dive #%d %d will be really added to deco calc: ", i, (*this)[i]->number);
|
||||||
#endif
|
#endif
|
||||||
struct dive *pdive = get_dive(i);
|
const struct dive &pdive = *(*this)[i];
|
||||||
/* again skip dives from different trips */
|
/* again skip dives from different trips */
|
||||||
if (dive->divetrip && dive->divetrip != pdive->divetrip) {
|
if (dive->divetrip && dive->divetrip != pdive.divetrip) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - other dive trip\n");
|
printf("No - other dive trip\n");
|
||||||
#endif
|
#endif
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
/* Don't add future dives */
|
/* Don't add future dives */
|
||||||
if (pdive->when >= dive->when) {
|
if (pdive.when >= dive->when) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("No - future or same dive\n");
|
printf("No - future or same dive\n");
|
||||||
#endif
|
#endif
|
||||||
|
@ -513,7 +509,7 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
printf("Yes\n");
|
printf("Yes\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
surface_pressure = get_surface_pressure_in_mbar(pdive, true) / 1000.0;
|
surface_pressure = get_surface_pressure_in_mbar(&pdive, true) / 1000.0;
|
||||||
/* Is it the first dive we add? */
|
/* Is it the first dive we add? */
|
||||||
if (!deco_init) {
|
if (!deco_init) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
|
@ -526,7 +522,7 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
dump_tissues(ds);
|
dump_tissues(ds);
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
surface_time = pdive->when - last_endtime;
|
surface_time = pdive.when - last_endtime;
|
||||||
if (surface_time < 0) {
|
if (surface_time < 0) {
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Exit because surface intervall is %d\n", surface_time);
|
printf("Exit because surface intervall is %d\n", surface_time);
|
||||||
|
@ -540,13 +536,13 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
add_dive_to_deco(ds, pdive, in_planner);
|
add_dive_to_deco(ds, &pdive, in_planner);
|
||||||
|
|
||||||
last_starttime = pdive->when;
|
last_starttime = pdive.when;
|
||||||
last_endtime = pdive->endtime();
|
last_endtime = pdive.endtime();
|
||||||
clear_vpmb_state(ds);
|
clear_vpmb_state(ds);
|
||||||
#if DECO_CALC_DEBUG & 2
|
#if DECO_CALC_DEBUG & 2
|
||||||
printf("Tissues after added dive #%d:\n", pdive->number);
|
printf("Tissues after added dive #%d:\n", pdive.number);
|
||||||
dump_tissues(ds);
|
dump_tissues(ds);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -582,7 +578,7 @@ int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_p
|
||||||
return surface_time;
|
return surface_time;
|
||||||
}
|
}
|
||||||
|
|
||||||
void update_cylinder_related_info(struct dive *dive)
|
void dive_table::update_cylinder_related_info(struct dive *dive) const
|
||||||
{
|
{
|
||||||
if (dive != NULL) {
|
if (dive != NULL) {
|
||||||
dive->sac = calculate_sac(dive);
|
dive->sac = calculate_sac(dive);
|
||||||
|
|
|
@ -22,16 +22,18 @@ struct dive_table : public sorted_owning_table<dive, &comp_dives> {
|
||||||
struct dive *register_dive(std::unique_ptr<dive> d);
|
struct dive *register_dive(std::unique_ptr<dive> d);
|
||||||
std::unique_ptr<dive> unregister_dive(int idx);
|
std::unique_ptr<dive> unregister_dive(int idx);
|
||||||
|
|
||||||
|
int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_planner) const;
|
||||||
|
void update_cylinder_related_info(struct dive *) const;
|
||||||
int get_dive_nr_at_idx(int idx) const;
|
int get_dive_nr_at_idx(int idx) const;
|
||||||
timestamp_t get_surface_interval(timestamp_t when) const;
|
timestamp_t get_surface_interval(timestamp_t when) const;
|
||||||
struct dive *find_next_visible_dive(timestamp_t when);
|
struct dive *find_next_visible_dive(timestamp_t when);
|
||||||
|
private:
|
||||||
|
int calculate_cns(struct dive *dive) const; // Note: writes into dive->cns
|
||||||
};
|
};
|
||||||
|
|
||||||
/* this is used for both git and xml format */
|
/* this is used for both git and xml format */
|
||||||
#define DATAFORMAT_VERSION 3
|
#define DATAFORMAT_VERSION 3
|
||||||
|
|
||||||
extern void update_cylinder_related_info(struct dive *);
|
|
||||||
extern int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_planner);
|
|
||||||
|
|
||||||
/* divelist core logic functions */
|
/* divelist core logic functions */
|
||||||
extern void process_loaded_dives();
|
extern void process_loaded_dives();
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "dive.h"
|
#include "dive.h"
|
||||||
#include "divelist.h" // for init_decompression()
|
#include "divelist.h" // for init_decompression()
|
||||||
|
#include "divelog.h"
|
||||||
#include "sample.h"
|
#include "sample.h"
|
||||||
#include "subsurface-string.h"
|
#include "subsurface-string.h"
|
||||||
#include "deco.h"
|
#include "deco.h"
|
||||||
|
@ -122,7 +123,7 @@ static int tissue_at_end(struct deco_state *ds, struct dive *dive, const struct
|
||||||
if (cache) {
|
if (cache) {
|
||||||
cache.restore(ds, true);
|
cache.restore(ds, true);
|
||||||
} else {
|
} else {
|
||||||
surface_interval = init_decompression(ds, dive, true);
|
surface_interval = divelog.dives.init_decompression(ds, dive, true);
|
||||||
cache.cache(ds);
|
cache.cache(ds);
|
||||||
}
|
}
|
||||||
if (dc->samples.empty())
|
if (dc->samples.empty())
|
||||||
|
|
|
@ -10,11 +10,12 @@
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include "dive.h"
|
|
||||||
#include "deco.h"
|
#include "deco.h"
|
||||||
|
#include "dive.h"
|
||||||
|
#include "divelist.h"
|
||||||
|
#include "divelog.h"
|
||||||
#include "event.h"
|
#include "event.h"
|
||||||
#include "units.h"
|
#include "units.h"
|
||||||
#include "divelist.h"
|
|
||||||
#include "planner.h"
|
#include "planner.h"
|
||||||
#include "range.h"
|
#include "range.h"
|
||||||
#include "gettext.h"
|
#include "gettext.h"
|
||||||
|
@ -409,7 +410,7 @@ void add_plan_to_notes(struct diveplan *diveplan, struct dive *dive, bool show_d
|
||||||
/* Print the CNS and OTU next.*/
|
/* Print the CNS and OTU next.*/
|
||||||
dive->cns = 0;
|
dive->cns = 0;
|
||||||
dive->maxcns = 0;
|
dive->maxcns = 0;
|
||||||
update_cylinder_related_info(dive);
|
divelog.dives.update_cylinder_related_info(dive);
|
||||||
buf += casprintf_loc("<div>\n%s: %i%%", translate("gettextFromC", "CNS"), dive->cns);
|
buf += casprintf_loc("<div>\n%s: %i%%", translate("gettextFromC", "CNS"), dive->cns);
|
||||||
buf += casprintf_loc("<br/>\n%s: %i<br/>\n</div>\n", translate("gettextFromC", "OTU"), dive->otu);
|
buf += casprintf_loc("<br/>\n%s: %i<br/>\n</div>\n", translate("gettextFromC", "OTU"), dive->otu);
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
|
|
||||||
#include "dive.h"
|
#include "dive.h"
|
||||||
#include "divelist.h"
|
#include "divelist.h"
|
||||||
|
#include "divelog.h"
|
||||||
#include "errorhelper.h"
|
#include "errorhelper.h"
|
||||||
#include "event.h"
|
#include "event.h"
|
||||||
#include "interpolate.h"
|
#include "interpolate.h"
|
||||||
|
@ -1252,7 +1253,7 @@ struct plot_info create_plot_info_new(const struct dive *dive, const struct dive
|
||||||
int o2, he, o2max;
|
int o2, he, o2max;
|
||||||
struct deco_state plot_deco_state;
|
struct deco_state plot_deco_state;
|
||||||
bool in_planner = planner_ds != NULL;
|
bool in_planner = planner_ds != NULL;
|
||||||
init_decompression(&plot_deco_state, dive, in_planner);
|
divelog.dives.init_decompression(&plot_deco_state, dive, in_planner);
|
||||||
plot_info pi;
|
plot_info pi;
|
||||||
calculate_max_limits_new(dive, dc, pi, in_planner);
|
calculate_max_limits_new(dive, dc, pi, in_planner);
|
||||||
get_dive_gas(dive, &o2, &he, &o2max);
|
get_dive_gas(dive, &o2, &he, &o2max);
|
||||||
|
|
|
@ -708,7 +708,7 @@ void DiveTripModelTree::populate()
|
||||||
uiNotification(QObject::tr("populate data model"));
|
uiNotification(QObject::tr("populate data model"));
|
||||||
uiNotification(QObject::tr("start processing"));
|
uiNotification(QObject::tr("start processing"));
|
||||||
for (auto &d: divelog.dives) {
|
for (auto &d: divelog.dives) {
|
||||||
update_cylinder_related_info(d.get());
|
divelog.dives.update_cylinder_related_info(d.get());
|
||||||
if (d->hidden_by_filter)
|
if (d->hidden_by_filter)
|
||||||
continue;
|
continue;
|
||||||
dive_trip *trip = d->divetrip;
|
dive_trip *trip = d->divetrip;
|
||||||
|
|
Loading…
Reference in a new issue