mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 06:15:26 +00:00
Create a 'remove_event' function that removes an event.
The logic of removing the event was in the UI, and this makes the code harder to test because we need to take into account also the events that the interface is receiving, instead of only relying on the algorithm to test. so, now it lives in dive.h/.c and a unittest is easyer to make. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
3750d55665
commit
ef4705070f
3 changed files with 13 additions and 7 deletions
11
dive.c
11
dive.c
|
@ -65,6 +65,17 @@ void add_event(struct divecomputer *dc, int time, int type, int flags, int value
|
|||
remember_event(name);
|
||||
}
|
||||
|
||||
void remove_event(struct event* event)
|
||||
{
|
||||
struct event **ep = ¤t_dc->events;
|
||||
while (ep && *ep != event)
|
||||
ep = &(*ep)->next;
|
||||
if (ep) {
|
||||
*ep = event->next;
|
||||
free(event);
|
||||
}
|
||||
}
|
||||
|
||||
int get_pressure_units(unsigned int mb, const char **units)
|
||||
{
|
||||
int pressure;
|
||||
|
|
1
dive.h
1
dive.h
|
@ -562,6 +562,7 @@ extern void copy_samples(struct dive *s, struct dive *d);
|
|||
extern void fill_default_cylinder(cylinder_t *cyl);
|
||||
extern void add_gas_switch_event(struct dive *dive, struct divecomputer *dc, int time, int idx);
|
||||
extern void add_event(struct divecomputer *dc, int time, int type, int flags, int value, const char *name);
|
||||
extern void remove_event(struct event* event);
|
||||
extern void per_cylinder_mean_depth(struct dive *dive, struct divecomputer *dc, int *mean, int *duration);
|
||||
extern int get_cylinder_index(struct dive *dive, struct event *ev);
|
||||
extern int nr_cylinders(struct dive *dive);
|
||||
|
|
|
@ -830,13 +830,7 @@ void ProfileWidget2::removeEvent()
|
|||
tr("Remove the selected event?"),
|
||||
tr("%1 @ %2:%3").arg(event->name).arg(event->time.seconds / 60).arg(event->time.seconds % 60, 2, 10, QChar('0'))),
|
||||
QMessageBox::Ok | QMessageBox::Cancel) == QMessageBox::Ok) {
|
||||
struct event **ep = ¤t_dc->events;
|
||||
while (ep && *ep != event)
|
||||
ep = &(*ep)->next;
|
||||
if (ep) {
|
||||
*ep = event->next;
|
||||
free(event);
|
||||
}
|
||||
remove_event(event);
|
||||
mark_divelist_changed(true);
|
||||
replot();
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue