High level Bluetooth Low Energy API and radio abstraction layer
Fork of BLE_API by
ble/GattAttribute.h@1020:c8664d12bf10, 2015-12-10 (annotated)
- Committer:
- rgrover1
- Date:
- Thu Dec 10 09:15:02 2015 +0000
- Revision:
- 1020:c8664d12bf10
- Parent:
- 1019:575852ad31a2
- Child:
- 1028:9dc2ab644517
Synchronized with git rev 35adda98
Author: Rohit Grover
Release 2.1.6
=============
Minor update around GattCharacteristics having variable length.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
rgrover1 | 710:b2e1a2660ec2 | 1 | /* mbed Microcontroller Library |
rgrover1 | 710:b2e1a2660ec2 | 2 | * Copyright (c) 2006-2013 ARM Limited |
rgrover1 | 710:b2e1a2660ec2 | 3 | * |
rgrover1 | 710:b2e1a2660ec2 | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
rgrover1 | 710:b2e1a2660ec2 | 5 | * you may not use this file except in compliance with the License. |
rgrover1 | 710:b2e1a2660ec2 | 6 | * You may obtain a copy of the License at |
rgrover1 | 710:b2e1a2660ec2 | 7 | * |
rgrover1 | 710:b2e1a2660ec2 | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
rgrover1 | 710:b2e1a2660ec2 | 9 | * |
rgrover1 | 710:b2e1a2660ec2 | 10 | * Unless required by applicable law or agreed to in writing, software |
rgrover1 | 710:b2e1a2660ec2 | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
rgrover1 | 710:b2e1a2660ec2 | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
rgrover1 | 710:b2e1a2660ec2 | 13 | * See the License for the specific language governing permissions and |
rgrover1 | 710:b2e1a2660ec2 | 14 | * limitations under the License. |
rgrover1 | 710:b2e1a2660ec2 | 15 | */ |
rgrover1 | 710:b2e1a2660ec2 | 16 | |
rgrover1 | 710:b2e1a2660ec2 | 17 | #ifndef __GATT_ATTRIBUTE_H__ |
rgrover1 | 710:b2e1a2660ec2 | 18 | #define __GATT_ATTRIBUTE_H__ |
rgrover1 | 710:b2e1a2660ec2 | 19 | |
rgrover1 | 710:b2e1a2660ec2 | 20 | #include "UUID.h" |
rgrover1 | 710:b2e1a2660ec2 | 21 | |
rgrover1 | 710:b2e1a2660ec2 | 22 | class GattAttribute { |
rgrover1 | 710:b2e1a2660ec2 | 23 | public: |
rgrover1 | 710:b2e1a2660ec2 | 24 | typedef uint16_t Handle_t; |
rgrover1 | 710:b2e1a2660ec2 | 25 | static const Handle_t INVALID_HANDLE = 0x0000; |
rgrover1 | 710:b2e1a2660ec2 | 26 | |
rgrover1 | 710:b2e1a2660ec2 | 27 | public: |
rgrover1 | 710:b2e1a2660ec2 | 28 | /** |
rgrover1 | 710:b2e1a2660ec2 | 29 | * @brief Creates a new GattAttribute using the specified |
rgrover1 | 993:4d62b7967c11 | 30 | * UUID, value length, and inital value. |
rgrover1 | 710:b2e1a2660ec2 | 31 | * |
rgrover1 | 710:b2e1a2660ec2 | 32 | * @param[in] uuid |
rgrover1 | 993:4d62b7967c11 | 33 | * The UUID to use for this attribute. |
rgrover1 | 710:b2e1a2660ec2 | 34 | * @param[in] valuePtr |
rgrover1 | 710:b2e1a2660ec2 | 35 | * The memory holding the initial value. |
rgrover1 | 1019:575852ad31a2 | 36 | * @param[in] len |
rgrover1 | 1019:575852ad31a2 | 37 | * The length in bytes of this attribute's value. |
rgrover1 | 710:b2e1a2660ec2 | 38 | * @param[in] maxLen |
rgrover1 | 993:4d62b7967c11 | 39 | * The max length in bytes of this attribute's value. |
rgrover1 | 1020:c8664d12bf10 | 40 | * @param[in] hasVariableLen |
rgrover1 | 1020:c8664d12bf10 | 41 | * Whether the attribute's value length changes overtime. |
rgrover1 | 710:b2e1a2660ec2 | 42 | * |
rgrover1 | 710:b2e1a2660ec2 | 43 | * @section EXAMPLE |
rgrover1 | 710:b2e1a2660ec2 | 44 | * |
rgrover1 | 710:b2e1a2660ec2 | 45 | * @code |
rgrover1 | 710:b2e1a2660ec2 | 46 | * |
rgrover1 | 710:b2e1a2660ec2 | 47 | * // UUID = 0x2A19, Min length 2, Max len = 2 |
rgrover1 | 710:b2e1a2660ec2 | 48 | * GattAttribute attr = GattAttribute(0x2A19, &someValue, 2, 2); |
rgrover1 | 710:b2e1a2660ec2 | 49 | * |
rgrover1 | 710:b2e1a2660ec2 | 50 | * @endcode |
rgrover1 | 710:b2e1a2660ec2 | 51 | */ |
rgrover1 | 1020:c8664d12bf10 | 52 | GattAttribute(const UUID &uuid, uint8_t *valuePtr = NULL, uint16_t len = 0, uint16_t maxLen = 0, bool hasVariableLen = true) : |
rgrover1 | 1020:c8664d12bf10 | 53 | _uuid(uuid), _valuePtr(valuePtr), _lenMax(maxLen), _len(len), _hasVariableLen(hasVariableLen), _handle() { |
rgrover1 | 993:4d62b7967c11 | 54 | /* Empty */ |
rgrover1 | 710:b2e1a2660ec2 | 55 | } |
rgrover1 | 710:b2e1a2660ec2 | 56 | |
rgrover1 | 710:b2e1a2660ec2 | 57 | public: |
rgrover1 | 1020:c8664d12bf10 | 58 | Handle_t getHandle(void) const {return _handle; } |
rgrover1 | 1020:c8664d12bf10 | 59 | const UUID &getUUID(void) const {return _uuid; } |
rgrover1 | 1020:c8664d12bf10 | 60 | uint16_t getLength(void) const {return _len; } |
rgrover1 | 1020:c8664d12bf10 | 61 | uint16_t getMaxLength(void) const {return _lenMax; } |
rgrover1 | 1020:c8664d12bf10 | 62 | uint16_t *getLengthPtr(void) {return &_len; } |
rgrover1 | 1020:c8664d12bf10 | 63 | void setHandle(Handle_t id) {_handle = id; } |
rgrover1 | 1020:c8664d12bf10 | 64 | uint8_t *getValuePtr(void) {return _valuePtr; } |
rgrover1 | 1020:c8664d12bf10 | 65 | bool hasVariableLength(void) const {return _hasVariableLen;} |
rgrover1 | 710:b2e1a2660ec2 | 66 | |
rgrover1 | 710:b2e1a2660ec2 | 67 | private: |
rgrover1 | 1020:c8664d12bf10 | 68 | UUID _uuid; /* Characteristic UUID. */ |
rgrover1 | 710:b2e1a2660ec2 | 69 | uint8_t *_valuePtr; |
rgrover1 | 1020:c8664d12bf10 | 70 | uint16_t _lenMax; /* Maximum length of the value. */ |
rgrover1 | 1020:c8664d12bf10 | 71 | uint16_t _len; /* Current length of the value. */ |
rgrover1 | 1020:c8664d12bf10 | 72 | bool _hasVariableLen; |
rgrover1 | 710:b2e1a2660ec2 | 73 | Handle_t _handle; |
rgrover1 | 710:b2e1a2660ec2 | 74 | |
rgrover1 | 710:b2e1a2660ec2 | 75 | private: |
rgrover1 | 993:4d62b7967c11 | 76 | /* Disallow copy and assignment. */ |
rgrover1 | 710:b2e1a2660ec2 | 77 | GattAttribute(const GattAttribute &); |
rgrover1 | 710:b2e1a2660ec2 | 78 | GattAttribute& operator=(const GattAttribute &); |
rgrover1 | 710:b2e1a2660ec2 | 79 | }; |
rgrover1 | 710:b2e1a2660ec2 | 80 | |
rgrover1 | 710:b2e1a2660ec2 | 81 | #endif // ifndef __GATT_ATTRIBUTE_H__ |