summaryrefslogtreecommitdiffstats
path: root/core/device.h
diff options
context:
space:
mode:
Diffstat (limited to 'core/device.h')
-rw-r--r--core/device.h17
1 files changed, 15 insertions, 2 deletions
diff --git a/core/device.h b/core/device.h
index 28ad696bb..a976a7e64 100644
--- a/core/device.h
+++ b/core/device.h
@@ -9,15 +9,30 @@ extern "C" {
#endif
struct divecomputer;
+struct device;
+struct device_table;
+
+// global device table
+extern struct device_table device_table;
+
extern void fake_dc(struct divecomputer *dc);
extern void set_dc_deviceid(struct divecomputer *dc, unsigned int deviceid);
extern void set_dc_nickname(struct dive *dive);
extern void create_device_node(const char *model, uint32_t deviceid, const char *serial, const char *firmware, const char *nickname);
+extern int nr_devices(const struct device_table *table);
+extern const struct device *get_device(const struct device_table *table, int i);
extern void call_for_each_dc(void *f, void (*callback)(void *, const char *, uint32_t,
const char *, const char *, const char *), bool select_only);
extern void clear_device_nodes();
const char *get_dc_nickname(const struct divecomputer *dc);
+// struct device accessors for C-code. The returned strings are not stable!
+const char *device_get_model(const struct device *dev);
+const uint32_t device_get_id(const struct device *dev);
+const char *device_get_serial(const struct device *dev);
+const char *device_get_firmware(const struct device *dev);
+const char *device_get_nickname(const struct device *dev);
+
#ifdef __cplusplus
}
#endif
@@ -44,8 +59,6 @@ struct device_table {
std::vector<device> devices;
};
-extern struct device_table device_table;
-
#endif
#endif // DEVICE_H