summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2020-10-17 14:01:52 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-10-24 09:51:37 -0700
commit53118be1f9915584c33aba6e70b31d1720b1a451 (patch)
tree9ad039c544bf0dc9c84e619a8fbc0958c2f6e94f /core
parenta2614665942959b95eef8453730cd3ac66ac42a3 (diff)
downloadsubsurface-53118be1f9915584c33aba6e70b31d1720b1a451.tar.gz
devices: add functions to add / remove / check for devices
To include the device code in the undo system, we need functions to check for the existence of devices and to add or remove them. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core')
-rw-r--r--core/device.cpp22
-rw-r--r--core/device.h3
2 files changed, 24 insertions, 1 deletions
diff --git a/core/device.cpp b/core/device.cpp
index 48d66244f..512d17d57 100644
--- a/core/device.cpp
+++ b/core/device.cpp
@@ -218,7 +218,7 @@ bool device::operator<(const device &a) const
return strcoll(model.c_str(), a.model.c_str()) < 0;
}
-const struct device *get_device_for_dc(const struct device_table *table, const struct divecomputer *dc)
+extern "C" const struct device *get_device_for_dc(const struct device_table *table, const struct divecomputer *dc)
{
const std::vector<device> &dcs = table->devices;
device dev { dc->model, dc->deviceid, {}, {}, {} };
@@ -226,6 +226,12 @@ const struct device *get_device_for_dc(const struct device_table *table, const s
return it != dcs.end() && same_device(*it, dev) ? &*it : NULL;
}
+extern "C" bool device_exists(const struct device_table *device_table, const struct device *dev)
+{
+ auto it = std::lower_bound(device_table->devices.begin(), device_table->devices.end(), *dev);
+ return it != device_table->devices.end() && same_device(*it, *dev);
+}
+
/*
* When setting the device ID, we also fill in the
* serial number and firmware version data
@@ -292,6 +298,20 @@ extern "C" void create_device_node(struct device_table *device_table, const char
addDC(device_table->devices, model ?: "", deviceid, nickname ?: "", serial ?: "", firmware ?: "");
}
+/* Does not check for duplicates! */
+extern "C" void add_to_device_table(struct device_table *device_table, const struct device *dev)
+{
+ auto it = std::lower_bound(device_table->devices.begin(), device_table->devices.end(), *dev);
+ device_table->devices.insert(it, *dev);
+}
+
+extern "C" void remove_device(struct device_table *device_table, const struct device *dev)
+{
+ auto it = std::lower_bound(device_table->devices.begin(), device_table->devices.end(), *dev);
+ if (it != device_table->devices.end() && same_device(*it, *dev))
+ device_table->devices.erase(it);
+}
+
extern "C" void clear_device_table(struct device_table *device_table)
{
device_table->devices.clear();
diff --git a/core/device.h b/core/device.h
index f3bb1e097..9c7fff31c 100644
--- a/core/device.h
+++ b/core/device.h
@@ -28,6 +28,9 @@ const char *get_dc_nickname(const struct divecomputer *dc);
extern bool device_used_by_selected_dive(const struct device *dev);
extern const struct device *get_device_for_dc(const struct device_table *table, const struct divecomputer *dc);
+extern bool device_exists(const struct device_table *table, const struct device *dev);
+extern void add_to_device_table(struct device_table *table, const struct device *dev);
+extern void remove_device(struct device_table *table, const struct device *dev);
// struct device accessors for C-code. The returned strings are not stable!
const char *device_get_model(const struct device *dev);