summaryrefslogtreecommitdiffstats
path: root/libdivecomputer.c
diff options
context:
space:
mode:
authorGravatar Claudiu Olteanu <olteanu.claudiu@ymail.com>2015-07-06 17:07:34 +0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-07-06 08:37:42 -0700
commit198cc419596dbd17f65124d0495e98fb7acf81c2 (patch)
treea0bb99131eb82932f6f0894c95b85310a25e6ac5 /libdivecomputer.c
parentdff4e5f33eee0ba112ddd2265410a5e858d6c98f (diff)
downloadsubsurface-198cc419596dbd17f65124d0495e98fb7acf81c2.tar.gz
Implement the custom Bluetooth serial communication and use it
Create a custom Bluetooth serial communication using the QTBluetooth API and use it when the Bluetooth download mode is enabled. First try to connect on RFCOMM channel 1 because this is the default RFCOMM channel of SPP service for most devices. If this doesn't work try again on RFCOMM channel number 5 because it could be a Petrel2 device. Add a fake open function for the custom implementation. This is used when the selected device is HW OSTC 2N and the Bluetooth mode is activated, then fake the open call of the serial device. Signed-off-by: Claudiu Olteanu <olteanu.claudiu@ymail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'libdivecomputer.c')
-rw-r--r--libdivecomputer.c22
1 files changed, 19 insertions, 3 deletions
diff --git a/libdivecomputer.c b/libdivecomputer.c
index 24f4d0ff5..e308c132d 100644
--- a/libdivecomputer.c
+++ b/libdivecomputer.c
@@ -923,14 +923,30 @@ const char *do_libdivecomputer_import(device_data_t *data)
}
err = translate("gettextFromC", "Unable to open %s %s (%s)");
- rc = dc_device_open(&data->device, data->context, data->descriptor, data->devname);
+
+ if (data->bluetooth_mode) {
+ dc_serial_t *serial_device;
+
+ rc = dc_serial_qt_open(&serial_device, data->context, data->devname);
+ if (rc == DC_STATUS_SUCCESS) {
+ rc = dc_device_custom_open(&data->device, data->context, data->descriptor, serial_device);
+ } else {
+ report_error(errmsg(rc));
+ }
+
+ } else {
+ rc = dc_device_open(&data->device, data->context, data->descriptor, data->devname);
+
+ if (rc != DC_STATUS_SUCCESS && subsurface_access(data->devname, R_OK | W_OK) != 0)
+ err = translate("gettextFromC", "Insufficient privileges to open the device %s %s (%s)");
+ }
+
if (rc == DC_STATUS_SUCCESS) {
err = do_device_import(data);
/* TODO: Show the logfile to the user on error. */
dc_device_close(data->device);
data->device = NULL;
- } else if (subsurface_access(data->devname, R_OK | W_OK) != 0)
- err = translate("gettextFromC", "Insufficient privileges to open the device %s %s (%s)");
+ }
dc_context_free(data->context);
data->context = NULL;