mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-01 04:03:24 +00:00
Polish up on classes
This patch polishes up on all classes added for dive computer configuration to give a clean workflow. The classes can now write and read data from the OSTC 3. Signed-off-by: Joseph W. Joshua <joejoshw@gmail.com> Signed-off-by: Thiago Macieira <thiago@macieira.org>
This commit is contained in:
parent
4fc16b1674
commit
20eb62a98a
7 changed files with 150 additions and 60 deletions
|
@ -4,31 +4,42 @@
|
||||||
ConfigureDiveComputer::ConfigureDiveComputer(QObject *parent) :
|
ConfigureDiveComputer::ConfigureDiveComputer(QObject *parent) :
|
||||||
QObject(parent),
|
QObject(parent),
|
||||||
readThread(0),
|
readThread(0),
|
||||||
writeThread(0),
|
writeThread(0)
|
||||||
m_deviceDetails(0)
|
|
||||||
{
|
{
|
||||||
setState(INITIAL);
|
setState(INITIAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputer::readSettings(DeviceDetails *deviceDetails, device_data_t *data)
|
void ConfigureDiveComputer::readSettings(device_data_t *data)
|
||||||
{
|
{
|
||||||
setState(READING);
|
setState(READING);
|
||||||
m_deviceDetails = deviceDetails;
|
|
||||||
|
|
||||||
if (readThread)
|
if (readThread)
|
||||||
readThread->deleteLater();
|
readThread->deleteLater();
|
||||||
|
|
||||||
readThread = new ReadSettingsThread(this, deviceDetails, data);
|
readThread = new ReadSettingsThread(this, data);
|
||||||
connect (readThread, SIGNAL(finished()),
|
connect (readThread, SIGNAL(finished()),
|
||||||
this, SLOT(readThreadFinished()), Qt::QueuedConnection);
|
this, SLOT(readThreadFinished()), Qt::QueuedConnection);
|
||||||
connect (readThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
|
connect (readThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
|
||||||
|
connect (readThread, SIGNAL(devicedetails(DeviceDetails*)), this,
|
||||||
|
SIGNAL(deviceDetailsChanged(DeviceDetails*)));
|
||||||
|
|
||||||
readThread->start();
|
readThread->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputer::saveDeviceDetails()
|
void ConfigureDiveComputer::saveDeviceDetails(DeviceDetails *details, device_data_t *data)
|
||||||
{
|
{
|
||||||
|
setState(WRITING);
|
||||||
|
|
||||||
|
if (writeThread)
|
||||||
|
writeThread->deleteLater();
|
||||||
|
|
||||||
|
writeThread = new WriteSettingsThread(this, data);
|
||||||
|
connect (writeThread, SIGNAL(finished()),
|
||||||
|
this, SLOT(writeThreadFinished()), Qt::QueuedConnection);
|
||||||
|
connect (writeThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
|
||||||
|
|
||||||
|
writeThread->setDeviceDetails(details);
|
||||||
|
writeThread->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputer::setState(ConfigureDiveComputer::states newState)
|
void ConfigureDiveComputer::setState(ConfigureDiveComputer::states newState)
|
||||||
|
|
|
@ -13,7 +13,7 @@ class ConfigureDiveComputer : public QObject
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit ConfigureDiveComputer(QObject *parent = 0);
|
explicit ConfigureDiveComputer(QObject *parent = 0);
|
||||||
void readSettings(DeviceDetails *deviceDetails, device_data_t *data);
|
void readSettings(device_data_t *data);
|
||||||
|
|
||||||
enum states {
|
enum states {
|
||||||
INITIAL,
|
INITIAL,
|
||||||
|
@ -27,9 +27,8 @@ public:
|
||||||
|
|
||||||
QString lastError;
|
QString lastError;
|
||||||
states currentState;
|
states currentState;
|
||||||
DeviceDetails *m_deviceDetails;
|
|
||||||
device_data_t *m_data;
|
device_data_t *m_data;
|
||||||
void saveDeviceDetails();
|
void saveDeviceDetails(DeviceDetails *details, device_data_t *data);
|
||||||
void fetchDeviceDetails();
|
void fetchDeviceDetails();
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
|
@ -38,6 +37,7 @@ signals:
|
||||||
void readFinished();
|
void readFinished();
|
||||||
void writeFinished();
|
void writeFinished();
|
||||||
void stateChanged(states newState);
|
void stateChanged(states newState);
|
||||||
|
void deviceDetailsChanged(DeviceDetails *newDetails);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ReadSettingsThread *readThread;
|
ReadSettingsThread *readThread;
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "../divelist.h"
|
#include "../divelist.h"
|
||||||
#include "configuredivecomputer.h"
|
#include "configuredivecomputer.h"
|
||||||
#include <QInputDialog>
|
#include <QInputDialog>
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
struct product {
|
struct product {
|
||||||
const char *product;
|
const char *product;
|
||||||
|
@ -43,6 +44,8 @@ ConfigureDiveComputerDialog::ConfigureDiveComputerDialog(QWidget *parent) :
|
||||||
connect (config, SIGNAL(error(QString)), this, SLOT(configError(QString)));
|
connect (config, SIGNAL(error(QString)), this, SLOT(configError(QString)));
|
||||||
connect (config, SIGNAL(message(QString)), this, SLOT(configMessage(QString)));
|
connect (config, SIGNAL(message(QString)), this, SLOT(configMessage(QString)));
|
||||||
connect (config, SIGNAL(readFinished()), this, SLOT(deviceReadFinished()));
|
connect (config, SIGNAL(readFinished()), this, SLOT(deviceReadFinished()));
|
||||||
|
connect (config, SIGNAL(deviceDetailsChanged(DeviceDetails*)),
|
||||||
|
this, SLOT(deviceDetailsReceived(DeviceDetails*)));
|
||||||
|
|
||||||
fill_computer_list();
|
fill_computer_list();
|
||||||
|
|
||||||
|
@ -159,7 +162,7 @@ void ConfigureDiveComputerDialog::readSettings()
|
||||||
ui->errorLabel->clear();
|
ui->errorLabel->clear();
|
||||||
|
|
||||||
getDeviceData();
|
getDeviceData();
|
||||||
config->readSettings(deviceDetails, &device_data);
|
config->readSettings(&device_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputerDialog::configMessage(QString msg)
|
void ConfigureDiveComputerDialog::configMessage(QString msg)
|
||||||
|
@ -183,8 +186,6 @@ void ConfigureDiveComputerDialog::getDeviceData()
|
||||||
|
|
||||||
set_default_dive_computer(device_data.vendor, device_data.product);
|
set_default_dive_computer(device_data.vendor, device_data.product);
|
||||||
set_default_dive_computer_device(device_data.devname);
|
set_default_dive_computer_device(device_data.devname);
|
||||||
|
|
||||||
//deviceDetails->setData(&device_data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputerDialog::on_cancel_clicked()
|
void ConfigureDiveComputerDialog::on_cancel_clicked()
|
||||||
|
@ -194,11 +195,32 @@ void ConfigureDiveComputerDialog::on_cancel_clicked()
|
||||||
|
|
||||||
void ConfigureDiveComputerDialog::deviceReadFinished()
|
void ConfigureDiveComputerDialog::deviceReadFinished()
|
||||||
{
|
{
|
||||||
ui->brightnessComboBox->setCurrentIndex(config->m_deviceDetails->brightness());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureDiveComputerDialog::on_saveSettingsPushButton_clicked()
|
void ConfigureDiveComputerDialog::on_saveSettingsPushButton_clicked()
|
||||||
{
|
{
|
||||||
config->saveDeviceDetails();
|
deviceDetails->setBrightness(ui->brightnessComboBox->currentIndex());
|
||||||
|
deviceDetails->setLanguage(ui->languageComboBox->currentIndex());
|
||||||
|
deviceDetails->setDateFormat(ui->dateFormatComboBox->currentIndex());
|
||||||
|
deviceDetails->setCustomText(ui->customTextLlineEdit->text());
|
||||||
|
getDeviceData();
|
||||||
|
config->saveDeviceDetails(deviceDetails, &device_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigureDiveComputerDialog::deviceDetailsReceived(DeviceDetails *newDeviceDetails)
|
||||||
|
{
|
||||||
|
deviceDetails = newDeviceDetails;
|
||||||
|
reloadValues();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigureDiveComputerDialog::reloadValues()
|
||||||
|
{
|
||||||
|
ui->serialNoLineEdit->setText(deviceDetails->serialNo());
|
||||||
|
ui->firmwareVersionLineEdit->setText(deviceDetails->firmwareVersion());
|
||||||
|
ui->customTextLlineEdit->setText(deviceDetails->customText());
|
||||||
|
ui->brightnessComboBox->setCurrentIndex(deviceDetails->brightness());
|
||||||
|
ui->languageComboBox->setCurrentIndex(deviceDetails->language());
|
||||||
|
ui->dateFormatComboBox->setCurrentIndex(deviceDetails->dateFormat());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,8 @@ private slots:
|
||||||
void on_cancel_clicked();
|
void on_cancel_clicked();
|
||||||
void deviceReadFinished();
|
void deviceReadFinished();
|
||||||
void on_saveSettingsPushButton_clicked();
|
void on_saveSettingsPushButton_clicked();
|
||||||
|
void deviceDetailsReceived(DeviceDetails *newDeviceDetails);
|
||||||
|
void reloadValues();
|
||||||
private:
|
private:
|
||||||
Ui::ConfigureDiveComputerDialog *ui;
|
Ui::ConfigureDiveComputerDialog *ui;
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>343</width>
|
<width>343</width>
|
||||||
<height>365</height>
|
<height>390</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
|
@ -93,12 +93,8 @@
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QGridLayout" name="gridLayout_2">
|
<layout class="QGridLayout" name="gridLayout_2">
|
||||||
<item row="3" column="0">
|
<item row="2" column="1">
|
||||||
<widget class="QLabel" name="label_4">
|
<widget class="QLineEdit" name="customTextLlineEdit"/>
|
||||||
<property name="text">
|
|
||||||
<string>Brightness:</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
</item>
|
||||||
<item row="3" column="1">
|
<item row="3" column="1">
|
||||||
<widget class="QComboBox" name="brightnessComboBox">
|
<widget class="QComboBox" name="brightnessComboBox">
|
||||||
|
@ -119,10 +115,10 @@
|
||||||
</item>
|
</item>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="1">
|
<item row="1" column="0">
|
||||||
<widget class="QLineEdit" name="serialNoLineEdit">
|
<widget class="QLabel" name="label_8">
|
||||||
<property name="readOnly">
|
<property name="text">
|
||||||
<bool>true</bool>
|
<string>Firmware Version:</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -150,20 +146,17 @@
|
||||||
</item>
|
</item>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="2" column="1">
|
<item row="3" column="0">
|
||||||
<widget class="QLineEdit" name="customTextLlineEdit"/>
|
<widget class="QLabel" name="label_4">
|
||||||
</item>
|
|
||||||
<item row="4" column="0">
|
|
||||||
<widget class="QLabel" name="label_6">
|
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Language:</string>
|
<string>Brightness:</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="0">
|
<item row="0" column="1">
|
||||||
<widget class="QLabel" name="label_7">
|
<widget class="QLineEdit" name="serialNoLineEdit">
|
||||||
<property name="text">
|
<property name="readOnly">
|
||||||
<string>Serial No.</string>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -174,10 +167,17 @@
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
<item row="0" column="0">
|
||||||
<widget class="QLabel" name="label_8">
|
<widget class="QLabel" name="label_7">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Firmware Version:</string>
|
<string>Serial No.</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="4" column="0">
|
||||||
|
<widget class="QLabel" name="label_6">
|
||||||
|
<property name="text">
|
||||||
|
<string>Language:</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -188,6 +188,32 @@
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="5" column="0">
|
||||||
|
<widget class="QLabel" name="label_9">
|
||||||
|
<property name="text">
|
||||||
|
<string>Date Format:</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="5" column="1">
|
||||||
|
<widget class="QComboBox" name="dateFormatComboBox">
|
||||||
|
<item>
|
||||||
|
<property name="text">
|
||||||
|
<string>MMDDYY</string>
|
||||||
|
</property>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<property name="text">
|
||||||
|
<string>DDMMYY</string>
|
||||||
|
</property>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<property name="text">
|
||||||
|
<string>YYMMDD</string>
|
||||||
|
</property>
|
||||||
|
</item>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
|
|
|
@ -2,8 +2,8 @@
|
||||||
#include "libdivecomputer/hw.h"
|
#include "libdivecomputer/hw.h"
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
ReadSettingsThread::ReadSettingsThread(QObject *parent, DeviceDetails *deviceDetails, device_data_t *data)
|
ReadSettingsThread::ReadSettingsThread(QObject *parent, device_data_t *data)
|
||||||
: QThread(parent), m_deviceDetails(deviceDetails), m_data(data)
|
: QThread(parent), m_data(data)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ void ReadSettingsThread::run()
|
||||||
dc_status_t rc;
|
dc_status_t rc;
|
||||||
rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
|
rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
|
||||||
if (rc == DC_STATUS_SUCCESS) {
|
if (rc == DC_STATUS_SUCCESS) {
|
||||||
|
DeviceDetails *m_deviceDetails = new DeviceDetails(0);
|
||||||
switch (dc_device_get_type(m_data->device)) {
|
switch (dc_device_get_type(m_data->device)) {
|
||||||
case DC_FAMILY_HW_OSTC3:
|
case DC_FAMILY_HW_OSTC3:
|
||||||
supported = true;
|
supported = true;
|
||||||
|
@ -25,7 +26,8 @@ void ReadSettingsThread::run()
|
||||||
m_deviceDetails->setLanguage(0);
|
m_deviceDetails->setLanguage(0);
|
||||||
m_deviceDetails->setLastDeco(0);
|
m_deviceDetails->setLastDeco(0);
|
||||||
m_deviceDetails->setSerialNo("");
|
m_deviceDetails->setSerialNo("");
|
||||||
unsigned char uData[1];
|
//Read general settings
|
||||||
|
unsigned char uData[1] = {0};
|
||||||
rc = hw_ostc3_device_config_read(m_data->device, 0x2D, uData, sizeof(uData));
|
rc = hw_ostc3_device_config_read(m_data->device, 0x2D, uData, sizeof(uData));
|
||||||
if (rc == DC_STATUS_SUCCESS)
|
if (rc == DC_STATUS_SUCCESS)
|
||||||
m_deviceDetails->setBrightness(uData[0]);
|
m_deviceDetails->setBrightness(uData[0]);
|
||||||
|
@ -35,6 +37,20 @@ void ReadSettingsThread::run()
|
||||||
rc = hw_ostc3_device_config_read(m_data->device, 0x33, uData, sizeof(uData));
|
rc = hw_ostc3_device_config_read(m_data->device, 0x33, uData, sizeof(uData));
|
||||||
if (rc == DC_STATUS_SUCCESS)
|
if (rc == DC_STATUS_SUCCESS)
|
||||||
m_deviceDetails->setDateFormat(uData[0]);
|
m_deviceDetails->setDateFormat(uData[0]);
|
||||||
|
|
||||||
|
//read firmware settings
|
||||||
|
unsigned char fData[64] = {0};
|
||||||
|
rc = hw_ostc3_device_version (m_data->device, fData, sizeof (fData));
|
||||||
|
if (rc == DC_STATUS_SUCCESS) {
|
||||||
|
int serial = fData[0] + (fData[1] << 8);
|
||||||
|
m_deviceDetails->setSerialNo(QString::number(serial));
|
||||||
|
int fw = (fData[2] << 8) + fData[3];
|
||||||
|
m_deviceDetails->setFirmwareVersion(QString::number(fw));
|
||||||
|
QByteArray ar((char *)fData + 4, 60);
|
||||||
|
m_deviceDetails->setCustomText(ar.trimmed());
|
||||||
|
}
|
||||||
|
|
||||||
|
emit devicedetails(m_deviceDetails);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -51,31 +67,46 @@ void ReadSettingsThread::run()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteSettingsThread::WriteSettingsThread(QObject *parent, DeviceDetails *deviceDetails, QString settingName, QVariant settingValue)
|
WriteSettingsThread::WriteSettingsThread(QObject *parent, device_data_t *data)
|
||||||
: QThread(parent), m_deviceDetails(deviceDetails), m_settingName(settingName), m_settingValue(settingValue)
|
: QThread(parent), m_data(data) {
|
||||||
{
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WriteSettingsThread::setDeviceDetails(DeviceDetails *details)
|
||||||
|
{
|
||||||
|
m_deviceDetails = details;
|
||||||
|
}
|
||||||
|
|
||||||
void WriteSettingsThread::run()
|
void WriteSettingsThread::run()
|
||||||
{
|
{
|
||||||
bool supported = false;
|
bool supported = false;
|
||||||
dc_status_t rc;
|
dc_status_t rc;
|
||||||
|
rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
|
||||||
switch (dc_device_get_type(data->device)) {
|
|
||||||
case DC_FAMILY_HW_OSTC3:
|
|
||||||
rc = dc_device_open(&data->device, data->context, data->descriptor, data->devname);
|
|
||||||
if (rc == DC_STATUS_SUCCESS) {
|
if (rc == DC_STATUS_SUCCESS) {
|
||||||
|
switch (dc_device_get_type(m_data->device)) {
|
||||||
} else {
|
case DC_FAMILY_HW_OSTC3:
|
||||||
lastError = tr("Could not a establish connection to the dive computer.");
|
supported = true;
|
||||||
emit error(lastError);
|
//write general settings
|
||||||
}
|
hw_ostc3_device_customtext(m_data->device, m_deviceDetails->customText().toUtf8().data());
|
||||||
|
unsigned char data[1] = {0};
|
||||||
|
data[0] = m_deviceDetails->brightness();
|
||||||
|
hw_ostc3_device_config_write(m_data->device, 0x2D, data, sizeof(data));
|
||||||
|
data[0] = m_deviceDetails->language();
|
||||||
|
hw_ostc3_device_config_write(m_data->device, 0x32, data, sizeof(data));
|
||||||
|
data[0] = m_deviceDetails->dateFormat();
|
||||||
|
hw_ostc3_device_config_write(m_data->device, 0x33, data, sizeof(data));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
dc_device_close(m_data->device);
|
||||||
|
|
||||||
if (!supported) {
|
if (!supported) {
|
||||||
lastError = tr("This feature is not yet available for the selected dive computer.");
|
lastError = tr("This feature is not yet available for the selected dive computer.");
|
||||||
emit error(lastError);
|
emit error(lastError);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
lastError = tr("Could not a establish connection to the dive computer.");
|
||||||
|
emit error(lastError);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,31 +11,29 @@
|
||||||
class ReadSettingsThread : public QThread {
|
class ReadSettingsThread : public QThread {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
ReadSettingsThread(QObject *parent, DeviceDetails *deviceDetails, device_data_t *data);
|
ReadSettingsThread(QObject *parent, device_data_t *data);
|
||||||
virtual void run();
|
virtual void run();
|
||||||
QString result;
|
QString result;
|
||||||
QString lastError;
|
QString lastError;
|
||||||
signals:
|
signals:
|
||||||
void error(QString err);
|
void error(QString err);
|
||||||
|
void devicedetails(DeviceDetails *newDeviceDetails);
|
||||||
private:
|
private:
|
||||||
DeviceDetails *m_deviceDetails;
|
|
||||||
device_data_t *m_data;
|
device_data_t *m_data;
|
||||||
};
|
};
|
||||||
|
|
||||||
class WriteSettingsThread : public QThread {
|
class WriteSettingsThread : public QThread {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
WriteSettingsThread(QObject *parent, DeviceDetails *deviceDetails, QString settingName, QVariant settingValue);
|
WriteSettingsThread(QObject *parent, device_data_t *data);
|
||||||
|
void setDeviceDetails(DeviceDetails *details);
|
||||||
virtual void run();
|
virtual void run();
|
||||||
QString result;
|
QString result;
|
||||||
QString lastError;
|
QString lastError;
|
||||||
signals:
|
signals:
|
||||||
void error(QString err);
|
void error(QString err);
|
||||||
private:
|
private:
|
||||||
device_data_t *data;
|
device_data_t *m_data;
|
||||||
QString m_settingName;
|
|
||||||
QVariant m_settingValue;
|
|
||||||
|
|
||||||
DeviceDetails *m_deviceDetails;
|
DeviceDetails *m_deviceDetails;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue