aboutsummaryrefslogtreecommitdiff
path: root/BluetoothImpl.h
diff options
context:
space:
mode:
authorTrygve Laugstøl <trygvis@inamo.no>2015-02-20 20:45:43 +0100
committerTrygve Laugstøl <trygvis@inamo.no>2015-02-20 20:45:43 +0100
commitb6f080193d71334e8afea95ae26afbc03c27fac3 (patch)
treea5abdbb564bc817165ee3803570590520f548170 /BluetoothImpl.h
parent71167b3c8fb1ce47feb72b9376b899e40ffd3907 (diff)
downloadble-toys-b6f080193d71334e8afea95ae26afbc03c27fac3.tar.gz
ble-toys-b6f080193d71334e8afea95ae26afbc03c27fac3.tar.bz2
ble-toys-b6f080193d71334e8afea95ae26afbc03c27fac3.tar.xz
ble-toys-b6f080193d71334e8afea95ae26afbc03c27fac3.zip
o Decoding GATT characteristics.
Diffstat (limited to 'BluetoothImpl.h')
-rw-r--r--BluetoothImpl.h88
1 files changed, 67 insertions, 21 deletions
diff --git a/BluetoothImpl.h b/BluetoothImpl.h
index 0263da5..3fad164 100644
--- a/BluetoothImpl.h
+++ b/BluetoothImpl.h
@@ -20,52 +20,75 @@ typedef boost::uuids::uuid uuid_t;
class DefaultBluetoothGattCharacteristic : public BluetoothGattCharacteristic {
public:
- DefaultBluetoothGattCharacteristic(BluetoothGattService& service, uuid_t uuid) : service(service), uuid(uuid) {
+ DefaultBluetoothGattCharacteristic(BluetoothGattService &service, uint16_t handle, uuid_t uuid, uint8_t properties, uint16_t valueHandle)
+ : service(service), handle(handle), uuid(uuid), properties(properties), valueHandle(valueHandle) {
}
virtual ~DefaultBluetoothGattCharacteristic() {
}
+ BluetoothGattService &getService() const {
+ return service;
+ }
+
+ uint16_t getHandle() const {
+ return handle;
+ }
+
const uuid_t getUuid() const {
return uuid;
- };
+ }
- BluetoothGattService& getService() const {
- return service;
- };
+ uint8_t getProperties() const {
+ return properties;
+ }
+
+ uint16_t getValueHandle() const {
+ return valueHandle;
+ }
protected:
- BluetoothGattService& service;
+ BluetoothGattService &service;
+ uint16_t handle;
uuid_t uuid;
+ uint8_t properties;
+ uint16_t valueHandle;
};
class DefaultBluetoothGattService : public BluetoothGattService {
public:
- DefaultBluetoothGattService(BluetoothDevice& device, const uuid_t uuid, const uint16_t handle, const uint16_t endGroupHandle) :
- device(device), uuid(uuid), handle(handle), endGroupHandle(endGroupHandle) {
+ DefaultBluetoothGattService(BluetoothDevice &device, const uuid_t uuid, const uint16_t handle, const uint16_t endGroupHandle)
+ : device(device), uuid(uuid), handle(handle), endGroupHandle(endGroupHandle) {
+ DF;
}
virtual ~DefaultBluetoothGattService() {
+ DF;
+ removeCharacteristics();
}
- BluetoothDevice& getDevice() const {
+ virtual BluetoothDevice &getDevice() const {
return device;
}
- uuid_t getUuid() const {
+ virtual uuid_t getUuid() const {
return uuid;
}
- uint16_t getHandle() const {
- return handle;
+ virtual uint16_t getHandle() const {
+ return handle;
}
- uint16_t getEndGroupHandle() const {
- return endGroupHandle;
- }
+ virtual uint16_t getEndGroupHandle() const {
+ return endGroupHandle;
+ }
+
+ virtual const vector<BluetoothGattCharacteristic *> getCharacteristics() const {
+ return characteristics;
+ }
- vector<BluetoothGattCharacteristic* >::const_iterator getCharacteristics() const {
- return characteristics.begin();
+ virtual void addCharacteristic(BluetoothGattCharacteristic *characteristic) {
+ characteristics.push_back(characteristic);
}
protected:
@@ -73,22 +96,45 @@ protected:
const uuid_t uuid;
const uint16_t handle;
const uint16_t endGroupHandle;
- const vector<BluetoothGattCharacteristic*> characteristics;
+ vector<BluetoothGattCharacteristic *> characteristics;
+
+ void removeCharacteristics() {
+ DF;
+ for (auto &c: characteristics) {
+ delete c;
+ }
+ characteristics.clear();
+ }
};
class DefaultBluetoothDevice : public BluetoothDevice {
public:
- virtual vector<BluetoothGattService*>::const_iterator getServices() const {
- return services.begin();
+ virtual const vector<BluetoothGattService *> getServices() const {
+ return services;
};
+ virtual void addService(BluetoothGattService *service) {
+ services.push_back(service);
+ }
+
protected:
+ DefaultBluetoothDevice() {
+ DF;
+ }
+
virtual ~DefaultBluetoothDevice() {
+ DF;
+ removeServices();
+ }
+
+ void removeServices() {
for (auto s: services) {
delete s;
}
+ services.clear();
}
- vector<BluetoothGattService*> services;
+
+ vector<BluetoothGattService *> services;
};
BluetoothAdapter &getAdapterImpl(int hciDevice);