diff options
Diffstat (limited to 'core/dive.c')
-rw-r--r-- | core/dive.c | 49 |
1 files changed, 10 insertions, 39 deletions
diff --git a/core/dive.c b/core/dive.c index f296a8486..ac34be7f4 100644 --- a/core/dive.c +++ b/core/dive.c @@ -241,59 +241,29 @@ void add_extra_data(struct divecomputer *dc, const char *key, const char *value) } } -struct event *get_next_divemodechange(struct event **evd) +struct event *get_next_divemodechange(struct event **evd, bool update_pointer) { /* Starting at the event pointed to by evd, find the next divemode change event and initialise its * type and divemode. Requires an external pointer (evd) to a divemode change event, usually - * a copy of dc->events. This function is self-tracking and the value of evd needs no - * setting or manipulation outside of this function. */ + * a copy of dc->events. This function is self-tracking if update_pointer is TRUE and the value + * of evd needs no manipulation outside of this function. If update_pointer is FALSE, pointer evd + * is NOT updated with the address of the last examined event in the while() loop. */ struct event *ev = *evd; while (ev) { // Step through the events. for (int i=0; i<3; i++) { // For each event name search for one of the above strings if (!strcmp(ev->name,divemode_text[i])) { // if the event name is one of the divemode names ev->divemode = i; // set the event type to the dive mode - *evd = ev->next; + if (update_pointer) + *evd = ev->next; return (ev); } } ev = ev->next; } - *evd = NULL; + if (update_pointer) + *evd = NULL; return (NULL); } -struct event *peek_next_divemodechange(struct event *evd) -{ // Starting at event evd, return the subsequent divemode change event, remembering its divemode. - struct event *ev = evd; - while (ev) { // Step through the events. - for (int i=0; i<3; i++) { // For each event name search for one of the above strings - if (!strcmp(ev->name,divemode_text[i])) { // if the event name is one of the divemode names - ev->divemode = i; - return (ev); // ... then return the event. - } - } - ev = ev->next; - } - return (NULL); -} - -/* -enum dive_comp_type get_divemode_at_time(struct divecomputer *dc, int divetime, struct event **ev_dmc) -{ // The dummy version of this function, call parameters compatible with self-tracking version. - return dc->divemode; -} - -enum dive_comp_type get_divemode_at_time(struct divecomputer *dc, int divetime, struct event **ev_dmc) -{ // The non-self-tracking version of this function, call parameters compatible with self-tracking version. - struct event *ev, *ev_ndc = dc->events; - enum dive_comp_type mode = dc->divemode; - ev = get_next_divemodechange(&ev_ndc); - while (ev && (divetime >= ev->time.seconds)) { - mode = ev->divemode; - ev = get_next_divemodechange(&ev_ndc); - } - return mode; -} */ - enum dive_comp_type get_divemode_at_time(struct divecomputer *dc, int dtime, struct event **ev_dmc) { /* For a particular dive computer and its linked list of events, find the divemode dtime seconds * into the dive. Requires an external pointer (ev_dmc) to a divemode change event, usually @@ -304,7 +274,8 @@ enum dive_comp_type get_divemode_at_time(struct divecomputer *dc, int dtime, str while (ev && (dtime >= ev->time.seconds)) { // If dtime is AFTER this event time, store divemode mode = ev->divemode; ev_last = ev; - ev = peek_next_divemodechange(ev->next); // peek at the time of the following divemode change event +// ev = peek_next_divemodechange(ev->next); // peek at the time of the following divemode change event + ev = get_next_divemodechange(&ev->next, FALSE); } *ev_dmc = ev_last; return (mode); |