diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-10-21 15:25:18 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-10-24 09:51:37 -0700 |
commit | fadea413cdb4644b821369b27fad6e5f019d32c2 (patch) | |
tree | 4f027306ccb84277cd142d80c3a9e9c684c1521d /core/device.cpp | |
parent | 53118be1f9915584c33aba6e70b31d1720b1a451 (diff) | |
download | subsurface-fadea413cdb4644b821369b27fad6e5f019d32c2.tar.gz |
devices: return index from function adding / removing devices
This will be used to keep the model representing the device-list
up to date.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core/device.cpp')
-rw-r--r-- | core/device.cpp | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/core/device.cpp b/core/device.cpp index 512d17d57..764531414 100644 --- a/core/device.cpp +++ b/core/device.cpp @@ -299,17 +299,24 @@ extern "C" void create_device_node(struct device_table *device_table, const char } /* Does not check for duplicates! */ -extern "C" void add_to_device_table(struct device_table *device_table, const struct device *dev) +extern "C" int 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); + int idx = it - device_table->devices.begin(); device_table->devices.insert(it, *dev); + return idx; } -extern "C" void remove_device(struct device_table *device_table, const struct device *dev) +extern "C" int 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)) + if (it != device_table->devices.end() && same_device(*it, *dev)) { + int idx = it - device_table->devices.begin(); device_table->devices.erase(it); + return idx; + } else { + return -1; + } } extern "C" void clear_device_table(struct device_table *device_table) |