mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-25 05:03:52 +01:00 
			
		
		
		
	Merge branch 'zero_copy' into integration
This commit is contained in:
		| @@ -609,6 +609,9 @@ class BytesType(TypeInfo): | ||||
|         super().__init__(field) | ||||
|         self.needs_decode = needs_decode | ||||
|         self.needs_encode = needs_encode | ||||
|         # Only set decode_length if we need decoding | ||||
|         if needs_decode: | ||||
|             self.decode_length = "value.as_string()" | ||||
|  | ||||
|     @property | ||||
|     def public_content(self) -> list[str]: | ||||
| @@ -640,18 +643,6 @@ class BytesType(TypeInfo): | ||||
|  | ||||
|         return content | ||||
|  | ||||
|     @property | ||||
|     def decode_length_content(self) -> str: | ||||
|         if not self.needs_decode: | ||||
|             return ""  # No decode needed for SOURCE_SERVER messages | ||||
|  | ||||
|         # Decode into storage only - pointer/length are only needed for encoding | ||||
|         return ( | ||||
|             f"case {self.number}:\n" | ||||
|             f"  this->{self.field_name} = value.as_string();\n" | ||||
|             f"  break;" | ||||
|         ) | ||||
|  | ||||
|     @property | ||||
|     def encode_content(self) -> str: | ||||
|         return f"buffer.encode_bytes({self.number}, this->{self.field_name}_ptr_, this->{self.field_name}_len_);" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user