blob: 9340e4918ee826ddb923816ecdc1b5817efb26c4 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
# -*- coding: utf-8 -*-
#
# SPDX-License-Identifier: MIT
"""Common utility functions for LifeScan meters."""
from glucometerutils import exceptions
class MissingChecksum(exceptions.InvalidResponse):
"""The response misses the expected 4-digits checksum."""
def __init__(self, response):
super(MissingChecksum, self).__init__(
"Response is missing checksum: %s" % response
)
class InvalidSerialNumber(exceptions.Error):
"""The serial number is not as expected."""
def __init__(self, serial_number):
super(InvalidSerialNumber, self).__init__(
"Serial number %s is invalid." % serial_number
)
class MalformedCommand(exceptions.InvalidResponse):
def __init__(self, message):
super(MalformedCommand, self).__init__("Malformed command: %s" % message)
def crc_ccitt(data):
# type: (bytes) -> int
"""Calculate the CRC-16-CCITT with LifeScan's common seed.
Args:
data: (bytes) the data to calculate the checksum of
Returns:
(int) The 16-bit integer value of the CRC-CCITT calculated.
This function uses the non-default 0xFFFF seed as used by multiple
LifeScan meters.
"""
crc = 0xFFFF
for byte in data:
crc = (crc >> 8) & 0xFFFF | (crc << 8) & 0xFFFF
crc ^= byte
crc ^= (crc & 0xFF) >> 4
crc ^= (((crc << 8) & 0xFFFF) << 4) & 0xFFFF
crc ^= (crc & 0xFF) << 5
return crc & 0xFFFF
|