From 29f8074fcb844cf9668a5bf071e9cffa47299c99 Mon Sep 17 00:00:00 2001 From: JF Date: Thu, 29 Oct 2020 16:06:01 +0100 Subject: Refactoring of BLE service discovery : it is now implemented into the classes of the services. --- src/components/ble/CurrentTimeClient.h | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) (limited to 'src/components/ble/CurrentTimeClient.h') diff --git a/src/components/ble/CurrentTimeClient.h b/src/components/ble/CurrentTimeClient.h index fcc124c2..93139399 100644 --- a/src/components/ble/CurrentTimeClient.h +++ b/src/components/ble/CurrentTimeClient.h @@ -3,12 +3,13 @@ #include #include "components/datetime/DateTimeController.h" +#include "BleClient.h" #include namespace Pinetime { namespace Controllers { - class CurrentTimeClient { + class CurrentTimeClient : public BleClient { public: explicit CurrentTimeClient(DateTime& dateTimeController); void Init(); @@ -17,14 +18,11 @@ namespace Pinetime { int OnCharacteristicDiscoveryEvent(uint16_t conn_handle, const ble_gatt_error *error, const ble_gatt_chr *characteristic); int OnCurrentTimeReadResult(uint16_t conn_handle, const ble_gatt_error *error, const ble_gatt_attr *attribute); - bool IsDiscovered() const; - bool IsCharacteristicDiscovered() const; - uint16_t StartHandle() const; - uint16_t EndHandle() const; - uint16_t CurrentTimeHandle() const; static constexpr const ble_uuid16_t* Uuid() { return &CurrentTimeClient::ctsServiceUuid; } static constexpr const ble_uuid16_t* CurrentTimeCharacteristicUuid() { return &CurrentTimeClient::currentTimeCharacteristicUuid; } - private: + void Discover(uint16_t connectionHandle, std::function lambda) override; + + private: typedef struct __attribute__((packed)) { uint16_t year; uint8_t month; @@ -55,7 +53,7 @@ namespace Pinetime { bool isCharacteristicDiscovered = false; uint16_t currentTimeHandle; - + std::function onServiceDiscovered; }; } } \ No newline at end of file -- cgit v1.2.3-70-g09d2