Dokit
Internal development documentation
Loading...
Searching...
No Matches
DeviceInfoService Class Reference

The DeviceInfoService class accesses the Device Info service of Pokit devices. More...

Inheritance diagram for DeviceInfoService:
[legend]
Collaboration diagram for DeviceInfoService:
[legend]

Classes

struct  CharacteristicUuids
 Characteristics available via the Device Info service. More...
 

Signals

void manufacturerRead (const QString &name)
 This signal is emitted when the Manufacturer Name characteristic has been read successfully.
 
void modelNumberRead (const QString &model)
 This signal is emitted when the Model Number characteristic has been read successfully.
 
void hardwareRevisionRead (const QString &revision)
 This signal is emitted when the Hardware Revision characteristic has been read successfully.
 
void firmwareRevisionRead (const QString &revision)
 This signal is emitted when the Firmware Revision characteristic has been read successfully.
 
void softwareRevisionRead (const QString &revision)
 This signal is emitted when the Software Revision characteristic has been read successfully.
 
void serialNumberRead (const QString &serialNumber)
 This signal is emitted when the Serial Number characteristic has been read successfully.
 
- Signals inherited from AbstractPokitService
void serviceDetailsDiscovered ()
 This signal is emitted when the Pokit service details have been discovered.
 
void serviceErrorOccurred (QLowEnergyService::ServiceError newError)
 This signal is emitted whenever an error occurs on the underlying QLowEnergyService.
 

Public Member Functions

 DeviceInfoService (QLowEnergyController *const pokitDevice, QObject *parent=nullptr)
 Constructs a new Pokit service with parent.
 
bool readCharacteristics () override
 Read all characteristics.
 
bool readFirmwareRevisionCharacteristic ()
 Read the Device Info service's Firmware Revision characteristic.
 
bool readHardwareRevisionCharacteristic ()
 Read the Device Info service's Hardware Revision characteristic.
 
bool readManufacturerCharacteristics ()
 Read the Device Info service's Manufacturer Name characteristic.
 
bool readModelNumberCharacteristic ()
 Read the Device Info service's Model Number characteristic.
 
bool readSoftwareRevisionCharacteristic ()
 Read the Device Info service's Software Revision characteristic.
 
bool readSerialNumberCharacteristic ()
 Read the Device Info service's (undocumented) Serial Number characteristic.
 
QString manufacturer () const
 Returns the most recent value of the Device Info service's Manufacturer Name characteristic.
 
QString modelNumber () const
 Returns the most recent value of the Device Info service's Model Number characteristic.
 
QString hardwareRevision () const
 Returns the most recent value of the Device Info service's Hardware Revision characteristic.
 
QString firmwareRevision () const
 Returns the most recent value of the Device Info service's Firmware Revision characteristic.
 
QString softwareRevision () const
 Returns the most recent value of the Device Info service's Software Revision characteristic.
 
QString serialNumber () const
 Returns the most recent value of the Device Info service's (undocumented) Serial Number characteristic.
 
- Public Member Functions inherited from AbstractPokitService
virtual ~AbstractPokitService ()
 Destroys this AbstractPokitService object.
 
bool autoDiscover () const
 Returns true if autodiscovery of services and service details is enabled, false otherwise.
 
void setAutoDiscover (const bool discover=true)
 If discover is true, autodiscovery will be attempted.
 
std::optional< PokitProductpokitProduct () const
 Returns the Pokit product this service is attached to.
 
void setPokitProduct (const PokitProduct product)
 Sets the current Pokit product.
 
QLowEnergyServiceservice ()
 Returns a non-const pointer to the internal service object, if any.
 
const QLowEnergyServiceservice () const
 Returns a const pointer to the internal service object, if any.
 
- Public Member Functions inherited from QObject
virtual const QMetaObjectmetaObject () const const
 
 QObject (QObject *parent)
 
virtual bool event (QEvent *e)
 
virtual bool eventFilter (QObject *watched, QEvent *event)
 
QString objectName () const const
 
void setObjectName (const QString &name)
 
bool isWidgetType () const const
 
bool isWindowType () const const
 
bool signalsBlocked () const const
 
bool blockSignals (bool block)
 
QThreadthread () const const
 
void moveToThread (QThread *targetThread)
 
int startTimer (int interval, Qt::TimerType timerType)
 
int startTimer (std::chrono::milliseconds time, Qt::TimerType timerType)
 
void killTimer (int id)
 
findChild (const QString &name, Qt::FindChildOptions options) const const
 
QList< T > findChildren (const QString &name, Qt::FindChildOptions options) const const
 
QList< T > findChildren (const QRegExp &regExp, Qt::FindChildOptions options) const const
 
QList< T > findChildren (const QRegularExpression &re, Qt::FindChildOptions options) const const
 
const QObjectListchildren () const const
 
void setParent (QObject *parent)
 
void installEventFilter (QObject *filterObj)
 
void removeEventFilter (QObject *obj)
 
QMetaObject::Connection connect (const QObject *sender, const char *signal, const char *method, Qt::ConnectionType type) const const
 
bool disconnect (const char *signal, const QObject *receiver, const char *method) const const
 
bool disconnect (const QObject *receiver, const char *method) const const
 
void dumpObjectTree ()
 
void dumpObjectInfo ()
 
void dumpObjectTree () const const
 
void dumpObjectInfo () const const
 
bool setProperty (const char *name, const QVariant &value)
 
QVariant property (const char *name) const const
 
QList< QByteArraydynamicPropertyNames () const const
 
void destroyed (QObject *obj)
 
void objectNameChanged (const QString &objectName)
 
QObjectparent () const const
 
bool inherits (const char *className) const const
 
void deleteLater ()
 
 Q_DISABLE_COPY (Class)
 
 Q_DISABLE_MOVE (Class)
 
 Q_DISABLE_COPY_MOVE (Class)
 
qobject_cast (QObject *object)
 
qobject_cast (const QObject *object)
 
qFindChild (const QObject *obj, const QString &name)
 
QList< T > qFindChildren (const QObject *obj, const QString &name)
 
QList< T > qFindChildren (const QObject *obj, const QRegExp &regExp)
 
 Q_CLASSINFO (Name, Value)
 
 Q_INTERFACES (...)
 
 Q_PROPERTY (...)
 
 Q_ENUMS (...)
 
 Q_FLAGS (...)
 
 Q_ENUM (...)
 
 Q_FLAG (...)
 
 Q_ENUM_NS (...)
 
 Q_FLAG_NS (...)
 
 Q_OBJECT Q_OBJECT
 
 Q_GADGET Q_GADGET
 
 Q_NAMESPACE Q_NAMESPACE
 
 Q_NAMESPACE_EXPORT (EXPORT_MACRO)
 
 Q_SIGNALS Q_SIGNALS
 
 Q_SIGNAL Q_SIGNAL
 
 Q_SLOTS Q_SLOTS
 
 Q_SLOT Q_SLOT
 
 Q_EMIT Q_EMIT
 
 Q_INVOKABLE Q_INVOKABLE
 
 Q_REVISION Q_REVISION
 
 Q_SET_OBJECT_NAME (Object)
 
 QT_NO_NARROWING_CONVERSIONS_IN_CONNECT QT_NO_NARROWING_CONVERSIONS_IN_CONNECT
 

Static Public Attributes

static const QBluetoothUuid serviceUuid { QBluetoothUuid::ServiceClassUuid::DeviceInformation }
 UUID of the "Device Info" service.
 

Protected Member Functions

 DeviceInfoService (DeviceInfoServicePrivate *const d, QObject *const parent)
 Constructs a new Pokit service with parent, and private implementation d.
 
- Protected Member Functions inherited from AbstractPokitService
 AbstractPokitService (AbstractPokitServicePrivate *const d, QObject *const parent)
 Constructs a new Pokit service with parent, and private implementation d.
 
- Protected Member Functions inherited from QObject
QObjectsender () const const
 
int senderSignalIndex () const const
 
int receivers (const char *signal) const const
 
bool isSignalConnected (const QMetaMethod &signal) const const
 
virtual void timerEvent (QTimerEvent *event)
 
virtual void childEvent (QChildEvent *event)
 
virtual void customEvent (QEvent *event)
 
virtual void connectNotify (const QMetaMethod &signal)
 
virtual void disconnectNotify (const QMetaMethod &signal)
 

Additional Inherited Members

- Static Public Member Functions inherited from QObject
QString tr (const char *sourceText, const char *disambiguation, int n)
 
QString trUtf8 (const char *sourceText, const char *disambiguation, int n)
 
QMetaObject::Connection connect (const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, Functor functor)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *context, Functor functor, Qt::ConnectionType type)
 
bool disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *method)
 
bool disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method)
 
bool disconnect (const QMetaObject::Connection &connection)
 
bool disconnect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method)
 
- Public Attributes inherited from QObject
typedef QObjectList
 
- Protected Attributes inherited from AbstractPokitService
AbstractPokitServicePrivated_ptr
 Internal d-pointer.
 
- Properties inherited from QObject
 objectName
 

Detailed Description

The DeviceInfoService class accesses the Device Info service of Pokit devices.

Definition at line 22 of file deviceinfoservice.h.

Constructor & Destructor Documentation

◆ DeviceInfoService() [1/2]

DeviceInfoService::DeviceInfoService ( QLowEnergyController *const pokitDevice,
QObject * parent = nullptr )

Constructs a new Pokit service with parent.

Definition at line 23 of file deviceinfoservice.cpp.

24 : AbstractPokitService(new DeviceInfoServicePrivate(controller, this), parent)
25{
26
27}
QObject * parent() const const

References QObject::parent(), and QObject::QObject().

Referenced by firmwareRevision(), hardwareRevision(), manufacturer(), modelNumber(), readFirmwareRevisionCharacteristic(), readHardwareRevisionCharacteristic(), readManufacturerCharacteristics(), readModelNumberCharacteristic(), readSerialNumberCharacteristic(), readSoftwareRevisionCharacteristic(), serialNumber(), serialNumberRead(), and softwareRevision().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ DeviceInfoService() [2/2]

DeviceInfoService::DeviceInfoService ( DeviceInfoServicePrivate *const d,
QObject *const parent )
protected

Constructs a new Pokit service with parent, and private implementation d.

Definition at line 33 of file deviceinfoservice.cpp.

35 : AbstractPokitService(d, parent)
36{
37
38}

References QObject::parent(), and QObject::QObject().

Here is the call graph for this function:

Member Function Documentation

◆ firmwareRevision()

QString DeviceInfoService::firmwareRevision ( ) const

Returns the most recent value of the Device Info service's Firmware Revision characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Definition at line 195 of file deviceinfoservice.cpp.

196{
197 Q_D(const DeviceInfoService);
198 const QLowEnergyCharacteristic characteristic =
199 d->getCharacteristic(CharacteristicUuids::firmwareRevision);
200 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()) : QString();
201}
DeviceInfoService(QLowEnergyController *const pokitDevice, QObject *parent=nullptr)
Constructs a new Pokit service with parent.
bool isValid() const const
QByteArray value() const const
QString fromUtf8(const char *str, int size)
static const QBluetoothUuid firmwareRevision
UUID of the Device Info service's Firmware Revision String characterstic.

References DeviceInfoService(), DeviceInfoService::CharacteristicUuids::firmwareRevision, QString::fromUtf8(), QLowEnergyCharacteristic::isValid(), and QLowEnergyCharacteristic::value().

Here is the call graph for this function:

◆ firmwareRevisionRead

void DeviceInfoService::firmwareRevisionRead ( const QString & revision)
signal

This signal is emitted when the Firmware Revision characteristic has been read successfully.

See also
readFirmwareRevisionCharacteristic
firmwareRevision

◆ hardwareRevision()

QString DeviceInfoService::hardwareRevision ( ) const

Returns the most recent value of the Device Info service's Hardware Revision characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Definition at line 180 of file deviceinfoservice.cpp.

181{
182 Q_D(const DeviceInfoService);
183 const QLowEnergyCharacteristic characteristic =
184 d->getCharacteristic(CharacteristicUuids::hardwareRevision);
185 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()) : QString();
186}
static const QBluetoothUuid hardwareRevision
UUID of the Device Info service's Hardware Revision String characterstic.

References DeviceInfoService(), QString::fromUtf8(), DeviceInfoService::CharacteristicUuids::hardwareRevision, QLowEnergyCharacteristic::isValid(), and QLowEnergyCharacteristic::value().

Here is the call graph for this function:

◆ hardwareRevisionRead

void DeviceInfoService::hardwareRevisionRead ( const QString & revision)
signal

This signal is emitted when the Hardware Revision characteristic has been read successfully.

See also
readHardwareRevisionCharacteristic
hardwareRevision

◆ manufacturer()

QString DeviceInfoService::manufacturer ( ) const

Returns the most recent value of the Device Info service's Manufacturer Name characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Definition at line 150 of file deviceinfoservice.cpp.

151{
152 Q_D(const DeviceInfoService);
153 const QLowEnergyCharacteristic characteristic =
154 d->getCharacteristic(CharacteristicUuids::manufacturerName);
155 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()) : QString();
156}
static const QBluetoothUuid manufacturerName
UUID of the Device Info service's Manufacturer Name String characterstic.

References DeviceInfoService(), QString::fromUtf8(), QLowEnergyCharacteristic::isValid(), DeviceInfoService::CharacteristicUuids::manufacturerName, and QLowEnergyCharacteristic::value().

Here is the call graph for this function:

◆ manufacturerRead

void DeviceInfoService::manufacturerRead ( const QString & name)
signal

This signal is emitted when the Manufacturer Name characteristic has been read successfully.

See also
readManufacturerCharacteristic
manufacturer

◆ modelNumber()

QString DeviceInfoService::modelNumber ( ) const

Returns the most recent value of the Device Info service's Model Number characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Definition at line 165 of file deviceinfoservice.cpp.

166{
167 Q_D(const DeviceInfoService);
168 const QLowEnergyCharacteristic characteristic =
169 d->getCharacteristic(CharacteristicUuids::modelNumber);
170 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()) : QString();
171}
static const QBluetoothUuid modelNumber
UUID of the Device Info service's Model Number String characterstic.

References DeviceInfoService(), QString::fromUtf8(), QLowEnergyCharacteristic::isValid(), DeviceInfoService::CharacteristicUuids::modelNumber, and QLowEnergyCharacteristic::value().

Here is the call graph for this function:

◆ modelNumberRead

void DeviceInfoService::modelNumberRead ( const QString & model)
signal

This signal is emitted when the Model Number characteristic has been read successfully.

See also
readModelNumberCharacteristic
modelNumber

◆ readCharacteristics()

bool DeviceInfoService::readCharacteristics ( )
overridevirtual

Read all characteristics.

This convenience function will queue refresh requests of all characteristics supported by this service.

Relevant *Service::*Read signals will be emitted by derived class objects as each characteristic is successfully read.

Implements AbstractPokitService.

Definition at line 41 of file deviceinfoservice.cpp.

42{
43 const bool r1 = readFirmwareRevisionCharacteristic();
44 const bool r2 = readHardwareRevisionCharacteristic();
45 const bool r3 = readSoftwareRevisionCharacteristic();
46 const bool r4 = readManufacturerCharacteristics();
47 const bool r5 = readModelNumberCharacteristic();
48 const bool r6 = ((service() != nullptr) && (service()->characteristic(CharacteristicUuids::serialNumber).isValid()))
50 return (r1 && r2 && r3 && r4 && r5 && r6);
51}
QLowEnergyService * service()
Returns a non-const pointer to the internal service object, if any.
bool readSerialNumberCharacteristic()
Read the Device Info service's (undocumented) Serial Number characteristic.
bool readHardwareRevisionCharacteristic()
Read the Device Info service's Hardware Revision characteristic.
bool readSoftwareRevisionCharacteristic()
Read the Device Info service's Software Revision characteristic.
bool readFirmwareRevisionCharacteristic()
Read the Device Info service's Firmware Revision characteristic.
bool readManufacturerCharacteristics()
Read the Device Info service's Manufacturer Name characteristic.
bool readModelNumberCharacteristic()
Read the Device Info service's Model Number characteristic.
QLowEnergyCharacteristic characteristic(const QBluetoothUuid &uuid) const const
static const QBluetoothUuid serialNumber
UUID of the Device Info service's Serial Number String characterstic.

References QLowEnergyService::characteristic(), QLowEnergyCharacteristic::isValid(), readFirmwareRevisionCharacteristic(), readHardwareRevisionCharacteristic(), readManufacturerCharacteristics(), readModelNumberCharacteristic(), readSerialNumberCharacteristic(), readSoftwareRevisionCharacteristic(), DeviceInfoService::CharacteristicUuids::serialNumber, and AbstractPokitService::service().

Here is the call graph for this function:

◆ readFirmwareRevisionCharacteristic()

bool DeviceInfoService::readFirmwareRevisionCharacteristic ( )

Read the Device Info service's Firmware Revision characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits firmwareRevisionRead() if/when the characteristic has been read successfully.

Definition at line 62 of file deviceinfoservice.cpp.

63{
65 return d->readCharacteristic(CharacteristicUuids::firmwareRevision);
66}

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::firmwareRevision.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ readHardwareRevisionCharacteristic()

bool DeviceInfoService::readHardwareRevisionCharacteristic ( )

Read the Device Info service's Hardware Revision characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits hardwareRevisionRead() if/when the characteristic has been read successfully.

Definition at line 77 of file deviceinfoservice.cpp.

78{
80 return d->readCharacteristic(CharacteristicUuids::hardwareRevision);
81}

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::hardwareRevision.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ readManufacturerCharacteristics()

bool DeviceInfoService::readManufacturerCharacteristics ( )

Read the Device Info service's Manufacturer Name characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits manufacturerNameRead() if/when the characteristic has been read successfully.

Definition at line 92 of file deviceinfoservice.cpp.

93{
95 return d->readCharacteristic(CharacteristicUuids::manufacturerName);
96}

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::manufacturerName.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ readModelNumberCharacteristic()

bool DeviceInfoService::readModelNumberCharacteristic ( )

Read the Device Info service's Model Number characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits modelNumberRead() if/when the characteristic has been read successfully.

Definition at line 107 of file deviceinfoservice.cpp.

108{
110 return d->readCharacteristic(CharacteristicUuids::modelNumber);
111}

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::modelNumber.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ readSerialNumberCharacteristic()

bool DeviceInfoService::readSerialNumberCharacteristic ( )

Read the Device Info service's (undocumented) Serial Number characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits serialNumberRead() if/when the characteristic has been read successfully.

Definition at line 137 of file deviceinfoservice.cpp.

138{
140 return d->readCharacteristic(CharacteristicUuids::serialNumber);
141}

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::serialNumber.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ readSoftwareRevisionCharacteristic()

bool DeviceInfoService::readSoftwareRevisionCharacteristic ( )

Read the Device Info service's Software Revision characteristic.

Returns true is the read request is succesfully queued, false otherwise (ie if the underlying controller it not yet connected to the Pokit device, or the device's services have not yet been discovered).

Emits softwareRevisionRead() if/when the characteristic has been read successfully.

Definition at line 122 of file deviceinfoservice.cpp.

123{
125 return d->readCharacteristic(CharacteristicUuids::softwareRevision);
126}
static const QBluetoothUuid softwareRevision
UUID of the Device Info service's Software Revision String characterstic.

References DeviceInfoService(), and DeviceInfoService::CharacteristicUuids::softwareRevision.

Referenced by readCharacteristics().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ serialNumber()

QString DeviceInfoService::serialNumber ( ) const

Returns the most recent value of the Device Info service's (undocumented) Serial Number characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Pokit Bluetooth API errata
Unlike other string characteristics, Pokit (Pro) devices always appear to add a trailing null byte to serial number strings. So here we strip any that are present.

Definition at line 226 of file deviceinfoservice.cpp.

227{
228 Q_D(const DeviceInfoService);
229 const QLowEnergyCharacteristic characteristic =
230 d->getCharacteristic(CharacteristicUuids::serialNumber);
231 /*!
232 * \cond internal
233 * \pokitApi Unlike other string characteristics, Pokit (Pro) devices always appear to add a trailing
234 * `null` byte to serial number strings. So here we strip any that are present.
235 * \endcond
236 */
237 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()).remove(QLatin1Char('\0')) : QString();
238}
QString & remove(int position, int n)

References DeviceInfoService(), QString::fromUtf8(), QLowEnergyCharacteristic::isValid(), QString::remove(), DeviceInfoService::CharacteristicUuids::serialNumber, and QLowEnergyCharacteristic::value().

Referenced by serialNumberRead().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ serialNumberRead

void DeviceInfoService::serialNumberRead ( const QString & serialNumber)
signal

This signal is emitted when the Serial Number characteristic has been read successfully.

See also
readSerialNumberCharacteristic
serialNumber

References DeviceInfoService(), QObject::parent(), QObject::QObject(), and serialNumber().

Here is the call graph for this function:

◆ softwareRevision()

QString DeviceInfoService::softwareRevision ( ) const

Returns the most recent value of the Device Info service's Software Revision characteristic.

The returned value, if any, is from the underlying Bluetooth stack's cache. If no such value is currently available (ie the serviceDetailsDiscovered signal has not been emitted yet), then a null QString is returned.

Definition at line 210 of file deviceinfoservice.cpp.

211{
212 Q_D(const DeviceInfoService);
213 const QLowEnergyCharacteristic characteristic =
214 d->getCharacteristic(CharacteristicUuids::softwareRevision);
215 return (characteristic.isValid()) ? QString::fromUtf8(characteristic.value()) : QString();
216}

References DeviceInfoService(), QString::fromUtf8(), QLowEnergyCharacteristic::isValid(), DeviceInfoService::CharacteristicUuids::softwareRevision, and QLowEnergyCharacteristic::value().

Here is the call graph for this function:

◆ softwareRevisionRead

void DeviceInfoService::softwareRevisionRead ( const QString & revision)
signal

This signal is emitted when the Software Revision characteristic has been read successfully.

See also
readSoftwareRevisionCharacteristic
softwareRevision

Member Data Documentation

◆ serviceUuid

const QBluetoothUuid DeviceInfoService::serviceUuid { QBluetoothUuid::ServiceClassUuid::DeviceInformation }
inlinestatic

UUID of the "Device Info" service.

Definition at line 28 of file deviceinfoservice.h.

29{ QBluetoothUuid::ServiceClassUuid::DeviceInformation }; // 0x180a

Referenced by PokitDevice::serviceToString().


The documentation for this class was generated from the following files: