Coverage for src / bluetooth_sig / gatt / descriptors / manufacturer_limits.py: 68%
25 statements
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-18 11:17 +0000
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-18 11:17 +0000
1"""Manufacturer Limits Descriptor implementation."""
3from __future__ import annotations
5import msgspec
7from ..characteristics.utils import DataParser
8from .base import BaseDescriptor
11class ManufacturerLimitsData(msgspec.Struct, frozen=True, kw_only=True):
12 """Manufacturer Limits descriptor data."""
14 min_limit: int | float
15 max_limit: int | float
18class ManufacturerLimitsDescriptor(BaseDescriptor):
19 """Manufacturer Limits Descriptor (0x2913).
21 Defines manufacturer-specified limits for characteristic values.
22 Contains minimum and maximum limits set by the manufacturer.
23 """
25 def _has_structured_data(self) -> bool:
26 return True
28 def _get_data_format(self) -> str:
29 return "struct"
31 def _parse_descriptor_value(self, data: bytes) -> ManufacturerLimitsData:
32 """Parse Manufacturer Limits descriptor value.
34 The format depends on the characteristic's value type.
35 For simplicity, this implementation assumes uint16 min/max values.
37 Args:
38 data: Raw bytes containing min and max limit values
40 Returns:
41 ManufacturerLimitsData with manufacturer limits
43 Raises:
44 ValueError: If data length is incorrect
45 """
46 # Manufacturer Limits format: min_limit + max_limit
47 # For now, assume 4 bytes total (2 bytes each for uint16)
49 min_limit = DataParser.parse_int16(data, offset=0, endian="little")
50 max_limit = DataParser.parse_int16(data, offset=2, endian="little")
52 return ManufacturerLimitsData(
53 min_limit=min_limit,
54 max_limit=max_limit,
55 )
57 def get_min_limit(self, data: bytes) -> int | float:
58 """Get the minimum manufacturer limit."""
59 parsed = self._parse_descriptor_value(data)
60 return parsed.min_limit
62 def get_max_limit(self, data: bytes) -> int | float:
63 """Get the maximum manufacturer limit."""
64 parsed = self._parse_descriptor_value(data)
65 return parsed.max_limit
67 def is_value_within_limits(self, data: bytes, value: float) -> bool:
68 """Check if a value is within manufacturer limits."""
69 parsed = self._parse_descriptor_value(data)
70 return parsed.min_limit <= value <= parsed.max_limit