summaryrefslogtreecommitdiffstats
path: root/core/divesite.h
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2019-02-26 22:26:11 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-04-12 18:19:07 +0300
commitf6e7bdc5ef99d5a5fe71ac4f32511900fa82e804 (patch)
tree398efefad3b84b33eb5e488bdfa5b2482f345cdd /core/divesite.h
parent36644dc9f7540886801bda6131dff36241d9e879 (diff)
downloadsubsurface-f6e7bdc5ef99d5a5fe71ac4f32511900fa82e804.tar.gz
Dive site: add dive site table parameter to dive site functions
To enable undo of dive site functions, it is crucial to work with different dive site tables. Therefore add a dive site table parameter to dive site functions. For now, always pass the global dive site table. Thus, this commit shouldn't alter any functionality. After this change, a simple search for dive_site_table reveals all places where the global dive site table is accessed. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core/divesite.h')
-rw-r--r--core/divesite.h36
1 files changed, 18 insertions, 18 deletions
diff --git a/core/divesite.h b/core/divesite.h
index b3ae0657c..aca00f9b0 100644
--- a/core/divesite.h
+++ b/core/divesite.h
@@ -31,39 +31,39 @@ struct dive_site_table {
extern struct dive_site_table dive_site_table;
-static inline struct dive_site *get_dive_site(int nr)
+static inline struct dive_site *get_dive_site(int nr, struct dive_site_table *ds_table)
{
- if (nr >= dive_site_table.nr || nr < 0)
+ if (nr >= ds_table->nr || nr < 0)
return NULL;
- return dive_site_table.dive_sites[nr];
+ return ds_table->dive_sites[nr];
}
/* iterate over each dive site */
-#define for_each_dive_site(_i, _x) \
- for ((_i) = 0; ((_x) = get_dive_site(_i)) != NULL; (_i)++)
+#define for_each_dive_site(_i, _x, _ds_table) \
+ for ((_i) = 0; ((_x) = get_dive_site(_i, _ds_table)) != NULL; (_i)++)
-int get_divesite_idx(const struct dive_site *ds);
-struct dive_site *get_dive_site_by_uuid(uint32_t uuid);
-void dive_site_table_sort();
-struct dive_site *alloc_or_get_dive_site(uint32_t uuid);
+int get_divesite_idx(const struct dive_site *ds, struct dive_site_table *ds_table);
+struct dive_site *get_dive_site_by_uuid(uint32_t uuid, struct dive_site_table *ds_table);
+void dive_site_table_sort(struct dive_site_table *ds_table);
+struct dive_site *alloc_or_get_dive_site(uint32_t uuid, struct dive_site_table *ds_table);
int nr_of_dives_at_dive_site(struct dive_site *ds, bool select_only);
bool is_dive_site_used(struct dive_site *ds, bool select_only);
void free_dive_site(struct dive_site *ds);
-void delete_dive_site(struct dive_site *ds);
-struct dive_site *create_dive_site(const char *name, timestamp_t divetime);
-struct dive_site *create_dive_site_with_gps(const char *name, const location_t *, timestamp_t divetime);
-struct dive_site *get_dive_site_by_name(const char *name);
-struct dive_site *get_dive_site_by_gps(const location_t *);
-struct dive_site *get_dive_site_by_gps_and_name(char *name, const location_t *);
-struct dive_site *get_dive_site_by_gps_proximity(const location_t *, int distance);
+void delete_dive_site(struct dive_site *ds, struct dive_site_table *ds_table);
+struct dive_site *create_dive_site(const char *name, timestamp_t divetime, struct dive_site_table *ds_table);
+struct dive_site *create_dive_site_with_gps(const char *name, const location_t *, timestamp_t divetime, struct dive_site_table *ds_table);
+struct dive_site *get_dive_site_by_name(const char *name, struct dive_site_table *ds_table);
+struct dive_site *get_dive_site_by_gps(const location_t *, struct dive_site_table *ds_table);
+struct dive_site *get_dive_site_by_gps_and_name(char *name, const location_t *, struct dive_site_table *ds_table);
+struct dive_site *get_dive_site_by_gps_proximity(const location_t *, int distance, struct dive_site_table *ds_table);
bool dive_site_is_empty(struct dive_site *ds);
void copy_dive_site_taxonomy(struct dive_site *orig, struct dive_site *copy);
void copy_dive_site(struct dive_site *orig, struct dive_site *copy);
void merge_dive_site(struct dive_site *a, struct dive_site *b);
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, timestamp_t divetime);
+struct dive_site *find_or_create_dive_site_with_name(const char *name, timestamp_t divetime, struct dive_site_table *ds_table);
void merge_dive_sites(struct dive_site *ref, struct dive_site *dive_sites[], int count);
-void purge_empty_dive_sites();
+void purge_empty_dive_sites(struct dive_site_table *ds_table);
#ifdef __cplusplus
}