diff options
author | Sven Gothel <[email protected]> | 2021-10-13 05:16:03 +0200 |
---|---|---|
committer | Sven Gothel <[email protected]> | 2021-10-13 05:16:03 +0200 |
commit | 12ebc1fb88f206a2b65f12d5b0e9574d1e24aba2 (patch) | |
tree | 35ee446e1579121b8e23237fabe002f92c20eed7 | |
parent | d92f55f93d710dfe25059f6df9330fc388f0fc0d (diff) |
Fix AttFindInfoRsp: setElementSize() set format-code, not TypeSize; setElementHandle() is at +0 (not +2)
-rw-r--r-- | api/direct_bt/ATTPDUTypes.hpp | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/api/direct_bt/ATTPDUTypes.hpp b/api/direct_bt/ATTPDUTypes.hpp index 80247848..dc787346 100644 --- a/api/direct_bt/ATTPDUTypes.hpp +++ b/api/direct_bt/ATTPDUTypes.hpp @@ -1610,6 +1610,14 @@ namespace direct_bt { } throw AttValueException("AttFindInfoRsp: Invalid format "+std::to_string(format)+", not UUID16 (1) or UUID128 (2)", E_FILE_LINE); } + static uint8_t toFormatCode(const jau::uuid_t::TypeSize tsz) { + switch( tsz ) { + case jau::uuid_t::TypeSize::UUID16_SZ: return 0x01; + case jau::uuid_t::TypeSize::UUID128_SZ: return 0x02; + default: break; + } + throw AttValueException("AttFindInfoRsp: Invalid TypeSize "+jau::uuid_t::getTypeSizeString(tsz)+", not UUID16_SZ (1) or UUID128_SZ (2)", E_FILE_LINE); + } static jau::nsize_t getElementSize2(jau::uuid_t::TypeSize tsz) { return 2 /* handle */ + jau::uuid_t::number( tsz ); } @@ -1684,15 +1692,15 @@ namespace direct_bt { * @param element_length * @param count */ - void setElementSize(const jau::uuid_t::TypeSize format, const jau::nsize_t count) { - const jau::nsize_t element_length = getElementSize2( format ); + void setElementSize(const jau::uuid_t::TypeSize tsz, const jau::nsize_t count) { + const jau::nsize_t element_length = getElementSize2( tsz ); const jau::nsize_t new_size = getPDUValueOffset() + element_length * count; if( pdu.size() < new_size ) { throw jau::IllegalArgumentException("AttFindInfoRsp: "+std::to_string(getPDUValueOffset())+ " + element[len "+std::to_string(element_length)+ " * count "+std::to_string(count)+" > pdu "+std::to_string(pdu.size()), E_FILE_LINE); } - pdu.put_uint8_nc(1, element_length); + pdu.put_uint8_nc(1, toFormatCode(tsz)); pdu.resize( new_size ); if( getPDUValueSize() % getElementSize() != 0 ) { throw AttValueException("AttFindInfoRsp: Invalid packet size: pdu-value-size "+std::to_string(getPDUValueSize())+ @@ -1708,7 +1716,7 @@ namespace direct_bt { return pdu.get_uint16( getElementPDUOffset(elementIdx) ); } void setElementHandle(const jau::nsize_t elementIdx, const uint16_t h) { - pdu.put_uint16_nc( getElementPDUOffset(elementIdx) + 2, h ); + pdu.put_uint16_nc( getElementPDUOffset(elementIdx), h ); } std::unique_ptr<const jau::uuid_t> getElementValue(const jau::nsize_t elementIdx) const { |