2017-04-27 20:18:03 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2011-09-05 21:12:58 +02:00
|
|
|
#ifndef DIVELIST_H
|
|
|
|
#define DIVELIST_H
|
|
|
|
|
2024-06-07 10:25:09 +02:00
|
|
|
#include "triptable.h"
|
|
|
|
#include "divesitetable.h"
|
2020-05-01 13:43:52 +02:00
|
|
|
#include "units.h"
|
2024-06-04 13:52:48 +02:00
|
|
|
#include <memory>
|
2019-03-04 23:20:29 +01:00
|
|
|
|
2020-05-01 13:43:52 +02:00
|
|
|
struct dive;
|
core: introduce divelog structure
The parser API was very annoying, as a number of tables
to-be-filled were passed in as pointers. The goal of this
commit is to collect all these tables in a single struct.
This should make it (more or less) clear what is actually
written into the divelog files.
Moreover, it should now be rather easy to search for
instances, where the global logfile is accessed (and it
turns out that there are many!).
The divelog struct does not contain the tables as substructs,
but only collects pointers. The idea is that the "divelog.h"
file can be included without all the other files describing
the numerous tables.
To make it easier to use from C++ parts of the code, the
struct implements a constructor and a destructor. Sadly,
we can't use smart pointers, since the pointers are accessed
from C code. Therfore the constructor and destructor are
quite complex.
The whole commit is large, but was mostly an automatic
conversion.
One oddity of note: the divelog structure also contains
the "autogroup" flag, since that is saved in the divelog.
This actually fixes a bug: Before, when importing dives
from a different log, the autogroup flag was overwritten.
This was probably not intended and does not happen anymore.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
2022-11-08 21:31:08 +01:00
|
|
|
struct divelog;
|
2024-05-31 07:08:54 +02:00
|
|
|
struct device;
|
2019-08-05 20:43:06 +02:00
|
|
|
struct deco_state;
|
|
|
|
|
2024-06-07 10:25:09 +02:00
|
|
|
int comp_dives(const struct dive &a, const struct dive &b);
|
|
|
|
int comp_dives_ptr(const struct dive *a, const struct dive *b);
|
|
|
|
|
2024-06-24 20:47:02 +02:00
|
|
|
struct merge_result {
|
|
|
|
std::unique_ptr<struct dive> dive;
|
|
|
|
dive_trip *trip;
|
|
|
|
dive_site *site;
|
|
|
|
};
|
|
|
|
|
2024-06-07 10:25:09 +02:00
|
|
|
struct dive_table : public sorted_owning_table<dive, &comp_dives> {
|
|
|
|
dive *get_by_uniq_id(int id) const;
|
|
|
|
void record_dive(std::unique_ptr<dive> d); // call fixup_dive() before adding dive to table.
|
2024-06-18 21:19:14 +02:00
|
|
|
struct dive *register_dive(std::unique_ptr<dive> d);
|
2024-06-07 10:25:09 +02:00
|
|
|
std::unique_ptr<dive> unregister_dive(int idx);
|
2024-06-23 14:20:59 +02:00
|
|
|
std::unique_ptr<dive> default_dive(); // generate a sensible looking defaultdive 1h from now.
|
2024-06-18 20:57:10 +02:00
|
|
|
|
2024-06-23 14:20:59 +02:00
|
|
|
// Some of these functions act on dives, but need data from adjacent dives,
|
|
|
|
// notably to calculate CNS, surface interval, etc. Therefore, they are called
|
|
|
|
// on the dive_table and not on the dive.
|
|
|
|
void fixup_dive(struct dive &dive) const;
|
|
|
|
void force_fixup_dive(struct dive &d) const;
|
2024-06-18 22:23:57 +02:00
|
|
|
int init_decompression(struct deco_state *ds, const struct dive *dive, bool in_planner) const;
|
2024-06-23 14:20:59 +02:00
|
|
|
void update_cylinder_related_info(struct dive &dive) const;
|
2024-06-18 21:07:58 +02:00
|
|
|
int get_dive_nr_at_idx(int idx) const;
|
2024-06-18 21:01:16 +02:00
|
|
|
timestamp_t get_surface_interval(timestamp_t when) const;
|
2024-06-18 20:57:10 +02:00
|
|
|
struct dive *find_next_visible_dive(timestamp_t when);
|
2024-06-24 19:17:43 +02:00
|
|
|
std::array<std::unique_ptr<dive>, 2> split_divecomputer(const struct dive &src, int num) const;
|
|
|
|
std::array<std::unique_ptr<dive>, 2> split_dive(const struct dive &dive) const;
|
|
|
|
std::array<std::unique_ptr<dive>, 2> split_dive_at_time(const struct dive &dive, duration_t time) const;
|
2024-06-24 20:47:02 +02:00
|
|
|
merge_result merge_dives(const struct dive &a_in, const struct dive &b_in, int offset, bool prefer_downloaded) const;
|
|
|
|
std::unique_ptr<dive> try_to_merge(const struct dive &a, const struct dive &b, bool prefer_downloaded) const;
|
2024-06-25 14:40:51 +02:00
|
|
|
bool has_dive(unsigned int deviceid, unsigned int diveid) const;
|
2024-06-25 14:45:33 +02:00
|
|
|
std::unique_ptr<dive> clone_delete_divecomputer(const struct dive &d, int dc_number);
|
2024-06-18 22:23:57 +02:00
|
|
|
private:
|
2024-06-23 14:20:59 +02:00
|
|
|
int calculate_cns(struct dive &dive) const; // Note: writes into dive->cns
|
2024-06-24 19:17:43 +02:00
|
|
|
std::array<std::unique_ptr<dive>, 2> split_dive_at(const struct dive &dive, int a, int b) const;
|
2020-05-01 13:43:52 +02:00
|
|
|
};
|
|
|
|
|
2015-07-24 13:18:30 -07:00
|
|
|
void clear_dive_file_data();
|
2015-06-20 06:45:12 -07:00
|
|
|
|
2014-02-11 19:14:46 +01:00
|
|
|
#endif // DIVELIST_H
|