summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/divelist.c1
-rw-r--r--core/divelist.h1
-rw-r--r--core/divesite.c1
-rw-r--r--core/divesite.h1
-rw-r--r--core/table.h11
5 files changed, 15 insertions, 0 deletions
diff --git a/core/divelist.c b/core/divelist.c
index 227528e18..c15ca8d3c 100644
--- a/core/divelist.c
+++ b/core/divelist.c
@@ -753,6 +753,7 @@ static MAKE_GET_IDX(dive_table, struct dive *, dives)
MAKE_SORT(dive_table, struct dive *, dives, comp_dives)
MAKE_REMOVE(dive_table, struct dive *, dive)
MAKE_CLEAR_TABLE(dive_table, dives, dive)
+MAKE_MOVE_TABLE(dive_table, dives)
void insert_dive(struct dive_table *table, struct dive *d)
{
diff --git a/core/divelist.h b/core/divelist.h
index 3c09d5400..dc3ab1302 100644
--- a/core/divelist.h
+++ b/core/divelist.h
@@ -60,6 +60,7 @@ void report_datafile_version(int version);
int get_dive_id_closest_to(timestamp_t when);
void clear_dive_file_data();
void clear_dive_table(struct dive_table *table);
+void move_dive_table(struct dive_table *src, struct dive_table *dst);
#ifdef DEBUG_TRIP
extern void dump_selection(void);
diff --git a/core/divesite.c b/core/divesite.c
index 68ac6e98a..0ed4eb2ca 100644
--- a/core/divesite.c
+++ b/core/divesite.c
@@ -131,6 +131,7 @@ static MAKE_GET_IDX(dive_site_table, struct dive_site *, dive_sites)
MAKE_SORT(dive_site_table, struct dive_site *, dive_sites, compare_sites)
static MAKE_REMOVE(dive_site_table, struct dive_site *, dive_site)
MAKE_CLEAR_TABLE(dive_site_table, dive_sites, dive_site)
+MAKE_MOVE_TABLE(dive_site_table, dive_sites)
int add_dive_site_to_table(struct dive_site *ds, struct dive_site_table *ds_table)
{
diff --git a/core/divesite.h b/core/divesite.h
index 2dc64f81e..e5ef4d1b4 100644
--- a/core/divesite.h
+++ b/core/divesite.h
@@ -71,6 +71,7 @@ unsigned int get_distance(const location_t *loc1, const location_t *loc2);
struct dive_site *find_or_create_dive_site_with_name(const char *name, struct dive_site_table *ds_table);
void purge_empty_dive_sites(struct dive_site_table *ds_table);
void clear_dive_site_table(struct dive_site_table *ds_table);
+void move_dive_site_table(struct dive_site_table *src, struct dive_site_table *dst);
void add_dive_to_dive_site(struct dive *d, struct dive_site *ds);
struct dive_site *unregister_dive_from_dive_site(struct dive *d);
diff --git a/core/table.h b/core/table.h
index cf0be3bae..0f168f4bc 100644
--- a/core/table.h
+++ b/core/table.h
@@ -99,4 +99,15 @@
table->nr = 0; \
}
+/* Move data of one table to the other - source table is empty after call. */
+#define MAKE_MOVE_TABLE(table_type, array_name) \
+ void move_##table_type(struct table_type *src, struct table_type *dst) \
+ { \
+ clear_##table_type(dst); \
+ free(dst->array_name); \
+ *dst = *src; \
+ src->nr = src->allocated = 0; \
+ src->array_name = NULL; \
+ }
+
#endif