summaryrefslogtreecommitdiffstats
path: root/glucometerutils/drivers
diff options
context:
space:
mode:
authorDiego Elio Pettenò <flameeyes@flameeyes.eu>2017-04-17 17:28:26 +0200
committerDiego Elio Pettenò <flameeyes@flameeyes.eu>2017-04-17 17:31:07 +0200
commit2a825fb889735fa881566d1764cc48d2814447d2 (patch)
tree26411f143d49dcb9354e6643e9d51ab5f8e29edd /glucometerutils/drivers
parentRemove unused constants. (diff)
downloadglucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar.gz
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar.bz2
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar.lz
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar.xz
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.tar.zst
glucometerutils-2a825fb889735fa881566d1764cc48d2814447d2.zip
Diffstat (limited to 'glucometerutils/drivers')
-rw-r--r--glucometerutils/drivers/fsoptium.py16
-rw-r--r--glucometerutils/drivers/otultra2.py16
-rw-r--r--glucometerutils/drivers/otultraeasy.py17
-rw-r--r--glucometerutils/drivers/sdcodefree.py19
4 files changed, 19 insertions, 49 deletions
diff --git a/glucometerutils/drivers/fsoptium.py b/glucometerutils/drivers/fsoptium.py
index a380c96..d1b5f24 100644
--- a/glucometerutils/drivers/fsoptium.py
+++ b/glucometerutils/drivers/fsoptium.py
@@ -15,10 +15,9 @@ import datetime
import logging
import re
-import serial
-
from glucometerutils import common
from glucometerutils import exceptions
+from glucomterutils.support import serial
_CLOCK_RE = re.compile(
@@ -77,16 +76,9 @@ def _parse_clock(datestr):
return datetime.datetime(year, month, day, hour, minute, second)
-class Device(object):
- def __init__(self, device):
- if not device:
- logging.info('No --device parameter provided, looking for default cable.')
- device = 'hwgrep://1a61:3420'
-
- self.serial_ = serial.serial_for_url(
- device, baudrate=19200, bytesize=serial.EIGHTBITS,
- parity=serial.PARITY_NONE, stopbits=serial.STOPBITS_ONE,
- timeout=1, xonxoff=True, rtscts=False, dsrdtr=False, writeTimeout=None)
+class Device(serial.SerialDevice):
+ BAUDRATE = 19200
+ DEFAULT_CABLE_ID = '1a61:3420'
def _send_command(self, command):
cmd_bytes = bytes('$%s\r\n' % command, 'ascii')
diff --git a/glucometerutils/drivers/otultra2.py b/glucometerutils/drivers/otultra2.py
index 28a4771..8e33ea5 100644
--- a/glucometerutils/drivers/otultra2.py
+++ b/glucometerutils/drivers/otultra2.py
@@ -10,11 +10,10 @@ import datetime
import logging
import re
-import serial
-
from glucometerutils import common
from glucometerutils import exceptions
from glucometerutils.support import lifescan
+from glucometerutils.support import serial
# The following two hashes are taken directly from LifeScan's documentation
_MEAL_CODES = {
@@ -123,16 +122,9 @@ def _parse_datetime(response):
return datetime.datetime(2000 + year, month, day, hour, minute, second)
-class Device(object):
- def __init__(self, device):
- if not device:
- logging.info('No --device parameter provided, looking for default cable.')
- device = 'hwgrep://067b:2303'
-
- self.serial_ = serial.serial_for_url(
- device, baudrate=9600, bytesize=serial.EIGHTBITS,
- parity=serial.PARITY_NONE, stopbits=serial.STOPBITS_ONE,
- timeout=1, xonxoff=False, rtscts=False, dsrdtr=False, writeTimeout=None)
+class Device(serial.SerialDevice):
+ BAUDRATE = 9600
+ DEFAULT_CABLE_ID = '067b:2303' # Generic PL2303 cable.
def connect(self):
return
diff --git a/glucometerutils/drivers/otultraeasy.py b/glucometerutils/drivers/otultraeasy.py
index 2976b9e..31b719f 100644
--- a/glucometerutils/drivers/otultraeasy.py
+++ b/glucometerutils/drivers/otultraeasy.py
@@ -13,11 +13,10 @@ import re
import struct
import time
-import serial
-
from glucometerutils import common
from glucometerutils import exceptions
from glucometerutils.support import lifescan
+from glucometerutils.support import serial
_STX = 0x02
_ETX = 0x03
@@ -176,16 +175,12 @@ class _Packet(object):
return self.cmd[_IDX_DATA:_IDX_ETX]
-class Device(object):
+class Device(serial.SerialDevice):
+ BAUDRATE = 9600
+ DEFAULT_CABLE_ID = '067b:2303' # Generic PL2303 cable.
+
def __init__(self, device):
- if not device:
- logging.info('No --device parameter provided, looking for default cable.')
- device = 'hwgrep://067b:2303'
-
- self.serial_ = serial.serial_for_url(
- device, baudrate=9600, bytesize=serial.EIGHTBITS,
- parity=serial.PARITY_NONE, stopbits=serial.STOPBITS_ONE,
- timeout=1, xonxoff=False, rtscts=False, dsrdtr=False, writeTimeout=None)
+ super(Device, self).__init__(device)
self.sent_counter_ = False
self.expect_receive_ = False
diff --git a/glucometerutils/drivers/sdcodefree.py b/glucometerutils/drivers/sdcodefree.py
index 0cd0b28..9aeb653 100644
--- a/glucometerutils/drivers/sdcodefree.py
+++ b/glucometerutils/drivers/sdcodefree.py
@@ -15,10 +15,9 @@ import operator
import struct
import time
-import serial
-
from glucometerutils import common
from glucometerutils import exceptions
+from glucometerutils.support import serial
_STX = 0x53 # Not really 'STX'
_ETX = 0xAA # Not really 'ETX'
@@ -64,18 +63,10 @@ def parse_reading(msgdata):
def xor_checksum(msg):
return functools.reduce(operator.xor, msg)
-class Device(object):
- def __init__(self, device):
- if not device:
- logging.info(
- 'No --device parameter provided, looking for default cable.')
- device = 'hwgrep://10c4:ea60'
-
- self.serial_ = serial.serial_for_url(
- device, baudrate=38400, bytesize=serial.EIGHTBITS,
- parity=serial.PARITY_NONE, stopbits=serial.STOPBITS_ONE,
- timeout=300, xonxoff=False, rtscts=False, dsrdtr=False,
- writeTimeout=None)
+class Device(serial.SerialDevice):
+ BAUDRATE = 38400
+ DEFAULT_CABLE_ID = '10c4:ea60' # Generic cable.
+ TIMEOUT = 300 # We need to wait for data from the device.
def read_packet(self):
preamble = self.serial_.read(3)