Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: microbit-dal microbit-dal microbit-ble-open microbit-dal ... more
Fork of BLE_API by
Diff: public/GattServer.h
- Revision:
- 116:ca826083980e
- Parent:
- 114:f1ede142a78f
- Child:
- 118:620d28e7a1ba
--- a/public/GattServer.h Fri Aug 29 10:41:06 2014 +0200
+++ b/public/GattServer.h Tue Sep 02 15:09:46 2014 +0100
@@ -21,6 +21,7 @@
#include "blecommon.h"
#include "GattService.h"
#include "GattServerEvents.h"
+#include "GattCharacteristicWriteCBParams.h"
/**************************************************************************/
/*!
@@ -36,10 +37,6 @@
virtual ble_error_t addService(GattService &) = 0;
virtual ble_error_t readValue(uint16_t handle, uint8_t buffer[], uint16_t *const lengthP) = 0;
virtual ble_error_t updateValue(uint16_t, uint8_t[], uint16_t, bool localOnly = false) = 0;
- virtual ble_error_t setDeviceName(const uint8_t *deviceName) = 0;
- virtual ble_error_t getDeviceName(uint8_t *deviceName, unsigned *lengthP) = 0;
- virtual ble_error_t setAppearance(uint16_t appearance) = 0;
- virtual ble_error_t getAppearance(uint16_t *appearanceP) = 0;
// ToDo: For updateValue, check the CCCD to see if the value we are
// updating has the notify or indicate bits sent, and if BOTH are set
@@ -48,11 +45,13 @@
/* Event callback handlers. */
typedef void (*EventCallback_t)(uint16_t attributeHandle);
- typedef void (*ServerEventCallback_t)(void); /* independent of any particular attribute */
- void setOnDataSent(ServerEventCallback_t callback) {
+ typedef void (*WriteEventCallback_t)(uint16_t attributeHandle, const GattCharacteristicWriteCBParams *eventDataP);
+ typedef void (*ServerEventCallback_t)(void); /**< independent of any particular attribute */
+ typedef void (*ServerEventCallbackWithCount_t)(unsigned count); /**< independent of any particular attribute */
+ void setOnDataSent(ServerEventCallbackWithCount_t callback) {
onDataSent = callback;
}
- void setOnDataWritten(EventCallback_t callback) {
+ void setOnDataWritten(WriteEventCallback_t callback) {
onDataWritten = callback;
}
void setOnUpdatesEnabled(EventCallback_t callback) {
@@ -65,13 +64,14 @@
onConfirmationReceived = callback;
}
+ void handleDataWrittenEvent(uint16_t charHandle, const GattCharacteristicWriteCBParams *params) {
+ if (onDataWritten) {
+ onDataWritten(charHandle, params);
+ }
+ }
+
void handleEvent(GattServerEvents::gattEvent_e type, uint16_t charHandle) {
switch (type) {
- case GattServerEvents::GATT_EVENT_DATA_WRITTEN:
- if (onDataWritten) {
- onDataWritten(charHandle);
- }
- break;
case GattServerEvents::GATT_EVENT_UPDATES_ENABLED:
if (onUpdatesEnabled) {
onUpdatesEnabled(charHandle);
@@ -90,15 +90,9 @@
}
}
- void handleEvent(GattServerEvents::gattEvent_e type) {
- switch (type) {
- case GattServerEvents::GATT_EVENT_DATA_SENT:
- if (onDataSent) {
- onDataSent();
- }
- break;
- default:
- break;
+ void handleDataSentEvent(unsigned count) {
+ if (onDataSent) {
+ onDataSent(count);
}
}
@@ -113,11 +107,11 @@
uint8_t descriptorCount;
private:
- ServerEventCallback_t onDataSent;
- EventCallback_t onDataWritten;
- EventCallback_t onUpdatesEnabled;
- EventCallback_t onUpdatesDisabled;
- EventCallback_t onConfirmationReceived;
+ ServerEventCallbackWithCount_t onDataSent;
+ WriteEventCallback_t onDataWritten;
+ EventCallback_t onUpdatesEnabled;
+ EventCallback_t onUpdatesDisabled;
+ EventCallback_t onConfirmationReceived;
};
#endif // ifndef __GATT_SERVER_H__
