diff options
| author | Jean-François Milants <jf@codingfield.com> | 2021-10-17 06:23:01 (GMT) |
|---|---|---|
| committer | Jean-François Milants <jf@codingfield.com> | 2021-10-17 06:23:01 (GMT) |
| commit | d1f50157c7e0c471ae0e260fdca82fc472635079 (patch) | |
| tree | 5ff50524ec689b5472d04405fd54a983161ff04d /src/components/ble/HeartRateService.h | |
| parent | bf83493c8db1ef8afab34a10d0253c0208304484 (diff) | |
MotionService : fix typo and characteristic array size + send notification only if the host subscribed to them.
Diffstat (limited to 'src/components/ble/HeartRateService.h')
| -rw-r--r-- | src/components/ble/HeartRateService.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/components/ble/HeartRateService.h b/src/components/ble/HeartRateService.h index 0b16703..4e4a5a4 100644 --- a/src/components/ble/HeartRateService.h +++ b/src/components/ble/HeartRateService.h @@ -2,6 +2,7 @@ #define min // workaround: nimble's min/max macros conflict with libstdc++ #define max #include <host/ble_gap.h> +#include <atomic> #undef max #undef min @@ -18,6 +19,9 @@ namespace Pinetime { int OnHeartRateRequested(uint16_t connectionHandle, uint16_t attributeHandle, ble_gatt_access_ctxt* context); void OnNewHeartRateValue(uint8_t hearRateValue); + void SubscribeNotification(uint16_t connectionHandle, uint16_t attributeHandle); + void UnsubscribeNotification(uint16_t connectionHandle, uint16_t attributeHandle); + private: Pinetime::System::SystemTask& system; Controllers::HeartRateController& heartRateController; @@ -28,10 +32,11 @@ namespace Pinetime { static constexpr ble_uuid16_t heartRateMeasurementUuid {.u {.type = BLE_UUID_TYPE_16}, .value = heartRateMeasurementId}; - struct ble_gatt_chr_def characteristicDefinition[3]; + struct ble_gatt_chr_def characteristicDefinition[2]; struct ble_gatt_svc_def serviceDefinition[2]; uint16_t heartRateMeasurementHandle; + std::atomic_bool heartRateMeasurementNotificationEnable {false}; }; } } |
