2020-03-30 01:44:20 +02:00
|
|
|
/*
|
|
|
|
* NimBLEDescriptorMap.cpp
|
|
|
|
*
|
|
|
|
* Created: on March 10, 2020
|
|
|
|
* Author H2zero
|
2020-05-14 06:03:56 +02:00
|
|
|
*
|
2020-03-30 01:44:20 +02:00
|
|
|
* Originally:
|
|
|
|
*
|
|
|
|
* BLEDescriptorMap.cpp
|
|
|
|
*
|
|
|
|
* Created on: Jun 22, 2017
|
|
|
|
* Author: kolban
|
|
|
|
*/
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
#if defined(CONFIG_BT_ENABLED)
|
2020-05-14 06:03:56 +02:00
|
|
|
|
|
|
|
#include "nimconfig.h"
|
|
|
|
#if defined(CONFIG_BT_NIMBLE_ROLE_PERIPHERAL)
|
|
|
|
|
2020-03-30 01:44:20 +02:00
|
|
|
#include "NimBLECharacteristic.h"
|
|
|
|
#include "NimBLEDescriptor.h"
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the descriptor by UUID.
|
|
|
|
* @param [in] UUID The UUID to look up the descriptor.
|
|
|
|
* @return The descriptor. If not present, then nullptr is returned.
|
|
|
|
*/
|
|
|
|
NimBLEDescriptor* NimBLEDescriptorMap::getByUUID(const char* uuid) {
|
2020-05-14 06:03:56 +02:00
|
|
|
return getByUUID(NimBLEUUID(uuid));
|
2020-03-30 01:44:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the descriptor by UUID.
|
|
|
|
* @param [in] UUID The UUID to look up the descriptor.
|
|
|
|
* @return The descriptor. If not present, then nullptr is returned.
|
|
|
|
*/
|
2020-05-10 15:21:46 +02:00
|
|
|
NimBLEDescriptor* NimBLEDescriptorMap::getByUUID(const NimBLEUUID &uuid) {
|
2020-05-14 06:03:56 +02:00
|
|
|
for (auto &myPair : m_uuidMap) {
|
|
|
|
if (myPair.first->getUUID().equals(uuid)) {
|
|
|
|
return myPair.first;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nullptr;
|
2020-03-30 01:44:20 +02:00
|
|
|
} // getByUUID
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return the descriptor by handle.
|
|
|
|
* @param [in] handle The handle to look up the descriptor.
|
|
|
|
* @return The descriptor.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
NimBLEDescriptor* NimBLEDescriptorMap::getByHandle(uint16_t handle) {
|
2020-05-14 06:03:56 +02:00
|
|
|
return m_handleMap.at(handle);
|
2020-03-30 01:44:20 +02:00
|
|
|
} // getByHandle
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the descriptor by UUID.
|
|
|
|
* @param [in] uuid The uuid of the descriptor.
|
|
|
|
* @param [in] characteristic The descriptor to cache.
|
|
|
|
* @return N/A.
|
|
|
|
*/
|
|
|
|
void NimBLEDescriptorMap::setByUUID(const char* uuid, NimBLEDescriptor* pDescriptor){
|
2020-05-14 06:03:56 +02:00
|
|
|
m_uuidMap.insert(std::pair<NimBLEDescriptor*, std::string>(pDescriptor, uuid));
|
2020-03-30 01:44:20 +02:00
|
|
|
} // setByUUID
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the descriptor by UUID.
|
|
|
|
* @param [in] uuid The uuid of the descriptor.
|
|
|
|
* @param [in] characteristic The descriptor to cache.
|
|
|
|
* @return N/A.
|
|
|
|
*/
|
2020-05-10 15:21:46 +02:00
|
|
|
void NimBLEDescriptorMap::setByUUID(const NimBLEUUID &uuid, NimBLEDescriptor* pDescriptor) {
|
2020-05-14 06:03:56 +02:00
|
|
|
m_uuidMap.insert(std::pair<NimBLEDescriptor*, std::string>(pDescriptor, uuid.toString()));
|
2020-03-30 01:44:20 +02:00
|
|
|
} // setByUUID
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the descriptor by handle.
|
|
|
|
* @param [in] handle The handle of the descriptor.
|
|
|
|
* @param [in] descriptor The descriptor to cache.
|
|
|
|
* @return N/A.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
void NimBLEDescriptorMap::setByHandle(uint16_t handle, NimBLEDescriptor* pDescriptor) {
|
2020-05-14 06:03:56 +02:00
|
|
|
m_handleMap.insert(std::pair<uint16_t, NimBLEDescriptor*>(handle, pDescriptor));
|
2020-03-30 01:44:20 +02:00
|
|
|
} // setByHandle
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the number of descriptors in the map.
|
|
|
|
*/
|
|
|
|
uint8_t NimBLEDescriptorMap::getSize() {
|
2020-05-14 06:03:56 +02:00
|
|
|
return (uint8_t)m_uuidMap.size();
|
2020-03-30 01:44:20 +02:00
|
|
|
} // getSize
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return a string representation of the descriptor map.
|
|
|
|
* @return A string representation of the descriptor map.
|
|
|
|
*/
|
|
|
|
std::string NimBLEDescriptorMap::toString() {
|
2020-05-14 06:03:56 +02:00
|
|
|
std::string res;
|
|
|
|
char hex[5];
|
|
|
|
int count = 0;
|
|
|
|
for (auto &myPair : m_uuidMap) {
|
|
|
|
if (count > 0) {res += "\n";}
|
|
|
|
snprintf(hex, sizeof(hex), "%04x", myPair.first->getHandle());
|
|
|
|
count++;
|
|
|
|
res += "handle: 0x";
|
|
|
|
res += hex;
|
|
|
|
res += ", uuid: " + myPair.first->getUUID().toString();
|
|
|
|
}
|
|
|
|
return res;
|
2020-03-30 01:44:20 +02:00
|
|
|
} // toString
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the first descriptor in the map.
|
|
|
|
* @return The first descriptor in the map.
|
|
|
|
*/
|
|
|
|
NimBLEDescriptor* NimBLEDescriptorMap::getFirst() {
|
2020-05-14 06:03:56 +02:00
|
|
|
m_iterator = m_uuidMap.begin();
|
|
|
|
if (m_iterator == m_uuidMap.end()) return nullptr;
|
|
|
|
NimBLEDescriptor* pRet = m_iterator->first;
|
|
|
|
m_iterator++;
|
|
|
|
return pRet;
|
2020-03-30 01:44:20 +02:00
|
|
|
} // getFirst
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the next descriptor in the map.
|
|
|
|
* @return The next descriptor in the map.
|
|
|
|
*/
|
|
|
|
NimBLEDescriptor* NimBLEDescriptorMap::getNext() {
|
2020-05-14 06:03:56 +02:00
|
|
|
if (m_iterator == m_uuidMap.end()) return nullptr;
|
|
|
|
NimBLEDescriptor* pRet = m_iterator->first;
|
|
|
|
m_iterator++;
|
|
|
|
return pRet;
|
2020-03-30 01:44:20 +02:00
|
|
|
} // getNext
|
2020-05-14 06:03:56 +02:00
|
|
|
|
|
|
|
#endif // #if defined(CONFIG_BT_NIMBLE_ROLE_PERIPHERAL)
|
2020-05-10 15:21:46 +02:00
|
|
|
#endif /* CONFIG_BT_ENABLED */
|