Previous version which works for my stm32f401 Nucleo board
Fork of X_NUCLEO_IDB0XA1 by
Diff: BlueNRGGattServer.h
- Revision:
- 52:94638d2461c1
- Parent:
- 51:963982e7c17c
- Child:
- 53:8c10d592ca49
--- a/BlueNRGGattServer.h Wed Sep 17 06:34:57 2014 +0000 +++ b/BlueNRGGattServer.h Thu Sep 25 08:21:49 2014 +0000 @@ -22,9 +22,13 @@ #include "btle.h" #include "GattService.h" #include "public/GattServer.h" +#include <vector> +#include <map> #define BLE_TOTAL_CHARACTERISTICS 10 +using namespace std; + class BlueNRGGattServer : public GattServer { public: @@ -32,8 +36,8 @@ static BlueNRGGattServer m_instance; return m_instance; } - - /* Functions that must be implemented from GattServer */ + + /* Functions that must be implemented from GattServer */ virtual ble_error_t addService(GattService &); virtual ble_error_t readValue(uint16_t handle, uint8_t buffer[], uint16_t *const lengthP); virtual ble_error_t updateValue(uint16_t, uint8_t[], uint16_t, bool localOnly = false); @@ -49,21 +53,22 @@ GattCharacteristic* getCharacteristicFromHandle(tHalUint16 charHandle); private: - + static const int MAX_SERVICE_COUNT = 10; uint8_t serviceCount; uint8_t characteristicCount; tHalUint16 servHandle, charHandle; - + + std::map<tHalUint16, tHalUint16> bleCharHanldeMap; // 1st argument is characteristic, 2nd argument is service GattCharacteristic *p_characteristics[BLE_TOTAL_CHARACTERISTICS]; tHalUint16 bleCharacteristicHandles[BLE_TOTAL_CHARACTERISTICS]; - + uint8_t *DeviceName; uint8_t deviceAppearance[2]; BlueNRGGattServer() { serviceCount = 0; characteristicCount = 0; - DeviceName = NULL; + DeviceName = NULL; }; BlueNRGGattServer(BlueNRGGattServer const &);