mirror of
https://github.com/h2zero/esp-nimble-cpp.git
synced 2025-01-22 09:20:51 +01:00
refactor(RemoteServ): Reduce nesting
* Adds parameter out to retrieveCharacteristics, default valuel works as the original method. * out: if not nullptr, will allow caller to obtain the characteristic * General cleanup
This commit is contained in:
parent
5ac7272f5d
commit
6116237d6b
2 changed files with 47 additions and 74 deletions
|
@ -76,46 +76,31 @@ NimBLERemoteCharacteristic* NimBLERemoteService::getCharacteristic(const char* u
|
||||||
*/
|
*/
|
||||||
NimBLERemoteCharacteristic* NimBLERemoteService::getCharacteristic(const NimBLEUUID& uuid) const {
|
NimBLERemoteCharacteristic* NimBLERemoteService::getCharacteristic(const NimBLEUUID& uuid) const {
|
||||||
NIMBLE_LOGD(LOG_TAG, ">> getCharacteristic: uuid: %s", uuid.toString().c_str());
|
NIMBLE_LOGD(LOG_TAG, ">> getCharacteristic: uuid: %s", uuid.toString().c_str());
|
||||||
NimBLERemoteCharacteristic* pChar = nullptr;
|
NimBLERemoteCharacteristic* pChar = nullptr;
|
||||||
size_t prev_size = m_vChars.size();
|
NimBLEUUID uuidTmp;
|
||||||
|
|
||||||
for (const auto& it : m_vChars) {
|
for (const auto& chr : m_vChars) {
|
||||||
if (it->getUUID() == uuid) {
|
if (chr->getUUID() == uuid) {
|
||||||
pChar = it;
|
pChar = chr;
|
||||||
goto Done;
|
goto Done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (retrieveCharacteristics(&uuid)) {
|
if (!retrieveCharacteristics(&uuid, pChar) || pChar) {
|
||||||
if (m_vChars.size() > prev_size) {
|
goto Done;
|
||||||
pChar = m_vChars.back();
|
}
|
||||||
goto Done;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the request was successful but 16/32 bit uuid not found
|
// Try again with 128 bit uuid if request succeeded with no uuid found.
|
||||||
// try again with the 128 bit uuid.
|
if (uuid.bitSize() == BLE_UUID_TYPE_16 || uuid.bitSize() == BLE_UUID_TYPE_32) {
|
||||||
if (uuid.bitSize() == BLE_UUID_TYPE_16 || uuid.bitSize() == BLE_UUID_TYPE_32) {
|
uuidTmp = NimBLEUUID(uuid).to128();
|
||||||
NimBLEUUID uuid128(uuid);
|
retrieveCharacteristics(&uuidTmp, pChar);
|
||||||
uuid128.to128();
|
goto Done;
|
||||||
if (retrieveCharacteristics(&uuid128)) {
|
}
|
||||||
if (m_vChars.size() > prev_size) {
|
// Try again with 16 bit uuid if request succeeded with no uuid found.
|
||||||
pChar = m_vChars.back();
|
// If the uuid was 128 bit but not of the BLE base type this check will fail.
|
||||||
}
|
uuidTmp = NimBLEUUID(uuid).to16();
|
||||||
}
|
if (uuidTmp.bitSize() == BLE_UUID_TYPE_16) {
|
||||||
} else {
|
retrieveCharacteristics(&uuidTmp, pChar);
|
||||||
// If the request was successful but the 128 bit uuid not found
|
|
||||||
// try again with the 16 bit uuid.
|
|
||||||
NimBLEUUID uuid16(uuid);
|
|
||||||
uuid16.to16();
|
|
||||||
// if the uuid was 128 bit but not of the BLE base type this check will fail
|
|
||||||
if (uuid16.bitSize() == BLE_UUID_TYPE_16) {
|
|
||||||
if (retrieveCharacteristics(&uuid16)) {
|
|
||||||
if (m_vChars.size() > prev_size) {
|
|
||||||
pChar = m_vChars.back();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Done:
|
Done:
|
||||||
|
@ -143,47 +128,37 @@ const std::vector<NimBLERemoteCharacteristic*>& NimBLERemoteService::getCharacte
|
||||||
* @brief Callback for Characteristic discovery.
|
* @brief Callback for Characteristic discovery.
|
||||||
* @return success == 0 or error code.
|
* @return success == 0 or error code.
|
||||||
*/
|
*/
|
||||||
int NimBLERemoteService::characteristicDiscCB(uint16_t conn_handle,
|
int NimBLERemoteService::characteristicDiscCB(uint16_t connHandle,
|
||||||
const ble_gatt_error* error,
|
const ble_gatt_error* error,
|
||||||
const ble_gatt_chr* chr,
|
const ble_gatt_chr* chr,
|
||||||
void* arg) {
|
void* arg) {
|
||||||
NIMBLE_LOGD(LOG_TAG,
|
const int rc = error->status;
|
||||||
"Characteristic Discovery >> status: %d handle: %d",
|
const bool ok = (rc == 0);
|
||||||
error->status,
|
|
||||||
(error->status == 0) ? chr->def_handle : -1);
|
|
||||||
auto pTaskData = (NimBLETaskData*)arg;
|
auto pTaskData = (NimBLETaskData*)arg;
|
||||||
const auto pSvc = (NimBLERemoteService*)pTaskData->m_pInstance;
|
const auto pSvc = (NimBLERemoteService*)pTaskData->m_pInstance;
|
||||||
|
NIMBLE_LOGD(LOG_TAG, "Characteristic Discovery >> status: %d handle: %d", rc, ok ? chr->def_handle : -1);
|
||||||
if (error->status == BLE_HS_ENOTCONN) {
|
|
||||||
NIMBLE_LOGE(LOG_TAG, "<< Characteristic Discovery; Not connected");
|
|
||||||
NimBLEUtils::taskRelease(*pTaskData, error->status);
|
|
||||||
return error->status;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Make sure the discovery is for this device
|
// Make sure the discovery is for this device
|
||||||
if (pSvc->getClient()->getConnHandle() != conn_handle) {
|
if (ok || pSvc->getClient()->getConnHandle() != connHandle) {
|
||||||
|
ok ? pSvc->m_vChars.push_back(new NimBLERemoteCharacteristic(pSvc, chr))
|
||||||
|
: (void)0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (error->status == 0) {
|
NimBLEUtils::taskRelease(*pTaskData, rc);
|
||||||
pSvc->m_vChars.push_back(new NimBLERemoteCharacteristic(pSvc, chr));
|
NIMBLE_LOGD(LOG_TAG, "<< Characteristic Discovery%s", (rc == BLE_HS_ENOTCONN) ? "; Not connected" : "");
|
||||||
return 0;
|
return rc;
|
||||||
}
|
|
||||||
|
|
||||||
NimBLEUtils::taskRelease(*pTaskData, error->status);
|
|
||||||
NIMBLE_LOGD(LOG_TAG, "<< Characteristic Discovery");
|
|
||||||
return error->status;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Retrieve all the characteristics for this service.
|
* @brief Retrieve all the characteristics for this service.
|
||||||
* This function will not return until we have all the characteristics.
|
* This function will not return until we have all the characteristics.
|
||||||
* @return True if successful.
|
* @return True if successfully retrieved, success = BLE_HS_EDONE.
|
||||||
*/
|
*/
|
||||||
bool NimBLERemoteService::retrieveCharacteristics(const NimBLEUUID* uuidFilter) const {
|
bool NimBLERemoteService::retrieveCharacteristics(const NimBLEUUID* uuidFilter, NimBLERemoteCharacteristic* out) const {
|
||||||
NIMBLE_LOGD(LOG_TAG, ">> retrieveCharacteristics()");
|
NIMBLE_LOGD(LOG_TAG, ">> retrieveCharacteristics()");
|
||||||
int rc = 0;
|
|
||||||
NimBLETaskData taskData(const_cast<NimBLERemoteService*>(this));
|
NimBLETaskData taskData(const_cast<NimBLERemoteService*>(this));
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
if (uuidFilter == nullptr) {
|
if (uuidFilter == nullptr) {
|
||||||
rc = ble_gattc_disc_all_chrs(m_pClient->getConnHandle(),
|
rc = ble_gattc_disc_all_chrs(m_pClient->getConnHandle(),
|
||||||
|
@ -207,12 +182,15 @@ bool NimBLERemoteService::retrieveCharacteristics(const NimBLEUUID* uuidFilter)
|
||||||
|
|
||||||
NimBLEUtils::taskWait(taskData, BLE_NPL_TIME_FOREVER);
|
NimBLEUtils::taskWait(taskData, BLE_NPL_TIME_FOREVER);
|
||||||
rc = taskData.m_flags;
|
rc = taskData.m_flags;
|
||||||
if (rc == 0 || rc == BLE_HS_EDONE) {
|
if (rc == BLE_HS_EDONE) {
|
||||||
NIMBLE_LOGD(LOG_TAG, "<< retrieveCharacteristics()");
|
NIMBLE_LOGD(LOG_TAG, "<< retrieveCharacteristics(): found %d characteristics.", m_vChars.size());
|
||||||
|
if (out) {
|
||||||
|
out = m_vChars.back();
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
NIMBLE_LOGE(LOG_TAG, "<< retrieveCharacteristics() rc=%d %s", rc, NimBLEUtils::returnCodeToString(rc));
|
NIMBLE_LOGE(LOG_TAG, "<< retrieveCharacteristics(): failed: rc=%d %s", rc, NimBLEUtils::returnCodeToString(rc));
|
||||||
return false;
|
return false;
|
||||||
} // retrieveCharacteristics
|
} // retrieveCharacteristics
|
||||||
|
|
||||||
|
@ -231,11 +209,8 @@ NimBLEClient* NimBLERemoteService::getClient() const {
|
||||||
*/
|
*/
|
||||||
NimBLEAttValue NimBLERemoteService::getValue(const NimBLEUUID& uuid) const {
|
NimBLEAttValue NimBLERemoteService::getValue(const NimBLEUUID& uuid) const {
|
||||||
const auto pChar = getCharacteristic(uuid);
|
const auto pChar = getCharacteristic(uuid);
|
||||||
if (pChar) {
|
return pChar ? pChar->readValue()
|
||||||
return pChar->readValue();
|
: NimBLEAttValue{};
|
||||||
}
|
|
||||||
|
|
||||||
return NimBLEAttValue{};
|
|
||||||
} // readValue
|
} // readValue
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -246,11 +221,8 @@ NimBLEAttValue NimBLERemoteService::getValue(const NimBLEUUID& uuid) const {
|
||||||
*/
|
*/
|
||||||
bool NimBLERemoteService::setValue(const NimBLEUUID& uuid, const NimBLEAttValue& value) const {
|
bool NimBLERemoteService::setValue(const NimBLEUUID& uuid, const NimBLEAttValue& value) const {
|
||||||
const auto pChar = getCharacteristic(uuid);
|
const auto pChar = getCharacteristic(uuid);
|
||||||
if (pChar) {
|
return pChar ? pChar->writeValue(value)
|
||||||
return pChar->writeValue(value);
|
: false;
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
} // setValue
|
} // setValue
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -260,8 +232,8 @@ bool NimBLERemoteService::setValue(const NimBLEUUID& uuid, const NimBLEAttValue&
|
||||||
* them. This method does just that.
|
* them. This method does just that.
|
||||||
*/
|
*/
|
||||||
void NimBLERemoteService::deleteCharacteristics() const {
|
void NimBLERemoteService::deleteCharacteristics() const {
|
||||||
for (const auto& it : m_vChars) {
|
for (const auto& chr : m_vChars) {
|
||||||
delete it;
|
delete chr;
|
||||||
}
|
}
|
||||||
std::vector<NimBLERemoteCharacteristic*>{}.swap(m_vChars);
|
std::vector<NimBLERemoteCharacteristic*>{}.swap(m_vChars);
|
||||||
} // deleteCharacteristics
|
} // deleteCharacteristics
|
||||||
|
|
|
@ -53,8 +53,9 @@ class NimBLERemoteService : public NimBLEAttribute {
|
||||||
|
|
||||||
NimBLERemoteService(NimBLEClient* pClient, const struct ble_gatt_svc* service);
|
NimBLERemoteService(NimBLEClient* pClient, const struct ble_gatt_svc* service);
|
||||||
~NimBLERemoteService();
|
~NimBLERemoteService();
|
||||||
bool retrieveCharacteristics(const NimBLEUUID* uuidFilter = nullptr) const;
|
bool retrieveCharacteristics(const NimBLEUUID* uuidFilter = nullptr,
|
||||||
static int characteristicDiscCB(uint16_t conn_handle,
|
NimBLERemoteCharacteristic* out = nullptr) const;
|
||||||
|
static int characteristicDiscCB(uint16_t connHandle,
|
||||||
const struct ble_gatt_error* error,
|
const struct ble_gatt_error* error,
|
||||||
const struct ble_gatt_chr* chr,
|
const struct ble_gatt_chr* chr,
|
||||||
void* arg);
|
void* arg);
|
||||||
|
|
Loading…
Add table
Reference in a new issue