mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-24 20:53:48 +01:00 
			
		
		
		
	Merge branch 'integration' into memory_api
This commit is contained in:
		| @@ -13,16 +13,17 @@ namespace bluetooth_proxy { | |||||||
|  |  | ||||||
| static const char *const TAG = "bluetooth_proxy.connection"; | static const char *const TAG = "bluetooth_proxy.connection"; | ||||||
|  |  | ||||||
| static std::vector<uint64_t> get_128bit_uuid_vec(esp_bt_uuid_t uuid_source) { | static void set_128bit_uuid_vec(std::vector<uint64_t> &out, esp_bt_uuid_t uuid_source) { | ||||||
|   esp_bt_uuid_t uuid = espbt::ESPBTUUID::from_uuid(uuid_source).as_128bit().get_uuid(); |   esp_bt_uuid_t uuid = espbt::ESPBTUUID::from_uuid(uuid_source).as_128bit().get_uuid(); | ||||||
|   return std::vector<uint64_t>{((uint64_t) uuid.uuid.uuid128[15] << 56) | ((uint64_t) uuid.uuid.uuid128[14] << 48) | |   out.reserve(2); | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[13] << 40) | ((uint64_t) uuid.uuid.uuid128[12] << 32) | |   out.emplace_back(((uint64_t) uuid.uuid.uuid128[15] << 56) | ((uint64_t) uuid.uuid.uuid128[14] << 48) | | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[11] << 24) | ((uint64_t) uuid.uuid.uuid128[10] << 16) | |                    ((uint64_t) uuid.uuid.uuid128[13] << 40) | ((uint64_t) uuid.uuid.uuid128[12] << 32) | | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[9] << 8) | ((uint64_t) uuid.uuid.uuid128[8]), |                    ((uint64_t) uuid.uuid.uuid128[11] << 24) | ((uint64_t) uuid.uuid.uuid128[10] << 16) | | ||||||
|                                ((uint64_t) uuid.uuid.uuid128[7] << 56) | ((uint64_t) uuid.uuid.uuid128[6] << 48) | |                    ((uint64_t) uuid.uuid.uuid128[9] << 8) | ((uint64_t) uuid.uuid.uuid128[8])); | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[5] << 40) | ((uint64_t) uuid.uuid.uuid128[4] << 32) | |   out.emplace_back(((uint64_t) uuid.uuid.uuid128[7] << 56) | ((uint64_t) uuid.uuid.uuid128[6] << 48) | | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[3] << 24) | ((uint64_t) uuid.uuid.uuid128[2] << 16) | |                    ((uint64_t) uuid.uuid.uuid128[5] << 40) | ((uint64_t) uuid.uuid.uuid128[4] << 32) | | ||||||
|                                    ((uint64_t) uuid.uuid.uuid128[1] << 8) | ((uint64_t) uuid.uuid.uuid128[0])}; |                    ((uint64_t) uuid.uuid.uuid128[3] << 24) | ((uint64_t) uuid.uuid.uuid128[2] << 16) | | ||||||
|  |                    ((uint64_t) uuid.uuid.uuid128[1] << 8) | ((uint64_t) uuid.uuid.uuid128[0])); | ||||||
| } | } | ||||||
|  |  | ||||||
| void BluetoothConnection::dump_config() { | void BluetoothConnection::dump_config() { | ||||||
| @@ -97,7 +98,7 @@ void BluetoothConnection::send_service_for_discovery_() { | |||||||
|   resp.address = this->address_; |   resp.address = this->address_; | ||||||
|   resp.services.emplace_back(); |   resp.services.emplace_back(); | ||||||
|   auto &service_resp = resp.services.back(); |   auto &service_resp = resp.services.back(); | ||||||
|   service_resp.uuid = get_128bit_uuid_vec(service_result.uuid); |   set_128bit_uuid_vec(service_resp.uuid, service_result.uuid); | ||||||
|   service_resp.handle = service_result.start_handle; |   service_resp.handle = service_result.start_handle; | ||||||
|  |  | ||||||
|   // Get the number of characteristics directly with one call |   // Get the number of characteristics directly with one call | ||||||
| @@ -136,7 +137,7 @@ void BluetoothConnection::send_service_for_discovery_() { | |||||||
|  |  | ||||||
|     service_resp.characteristics.emplace_back(); |     service_resp.characteristics.emplace_back(); | ||||||
|     auto &characteristic_resp = service_resp.characteristics.back(); |     auto &characteristic_resp = service_resp.characteristics.back(); | ||||||
|     characteristic_resp.uuid = get_128bit_uuid_vec(char_result.uuid); |     set_128bit_uuid_vec(characteristic_resp.uuid, char_result.uuid); | ||||||
|     characteristic_resp.handle = char_result.char_handle; |     characteristic_resp.handle = char_result.char_handle; | ||||||
|     characteristic_resp.properties = char_result.properties; |     characteristic_resp.properties = char_result.properties; | ||||||
|     char_offset++; |     char_offset++; | ||||||
| @@ -176,7 +177,7 @@ void BluetoothConnection::send_service_for_discovery_() { | |||||||
|  |  | ||||||
|       characteristic_resp.descriptors.emplace_back(); |       characteristic_resp.descriptors.emplace_back(); | ||||||
|       auto &descriptor_resp = characteristic_resp.descriptors.back(); |       auto &descriptor_resp = characteristic_resp.descriptors.back(); | ||||||
|       descriptor_resp.uuid = get_128bit_uuid_vec(desc_result.uuid); |       set_128bit_uuid_vec(descriptor_resp.uuid, desc_result.uuid); | ||||||
|       descriptor_resp.handle = desc_result.handle; |       descriptor_resp.handle = desc_result.handle; | ||||||
|       desc_offset++; |       desc_offset++; | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user