diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2019-02-26 22:26:11 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-04-12 18:19:07 +0300 |
commit | f6e7bdc5ef99d5a5fe71ac4f32511900fa82e804 (patch) | |
tree | 398efefad3b84b33eb5e488bdfa5b2482f345cdd /core/divesite.h | |
parent | 36644dc9f7540886801bda6131dff36241d9e879 (diff) | |
download | subsurface-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.h | 36 |
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 } |