Browse Source

Well thats slightly cleaner.

pyserial_fix
Scott Petersen 11 years ago
parent
commit
793adb66cf
1 changed files with 12 additions and 13 deletions
  1. +12
    -13
      pyad2usb/ad2usb.py

+ 12
- 13
pyad2usb/ad2usb.py View File

@@ -183,6 +183,7 @@ class AD2USB(object):
F4 = unichr(4) + unichr(4) + unichr(4) F4 = unichr(4) + unichr(4) + unichr(4)


BATTERY_TIMEOUT = 30 BATTERY_TIMEOUT = 30
FIRE_TIMEOUT = 30


def __init__(self, device): def __init__(self, device):
""" """
@@ -196,9 +197,7 @@ class AD2USB(object):
self._bypass_status = None self._bypass_status = None
self._armed_status = None self._armed_status = None
self._fire_status = (False, 0) self._fire_status = (False, 0)
self._previous_fire_status = (None, 0)
self._battery_status = (False, 0) self._battery_status = (False, 0)
self._previous_battery_status = (None, 0)
self._panic_status = None self._panic_status = None


self.address = 18 self.address = 18
@@ -428,19 +427,19 @@ class AD2USB(object):
if self._battery_status[0] == self._previous_battery_status[0]: if self._battery_status[0] == self._previous_battery_status[0]:
self._battery_status = (self._battery_status[0], time.time()) self._battery_status = (self._battery_status[0], time.time())


# Fire alarm status toggle. This is kinda ugly.. may be a better way to do it.
if message.fire_alarm != self._fire_status[0]:
if time.time() > self._fire_status[1] + AD2USB.BATTERY_TIMEOUT:
self._fire_status, self._previous_fire_status = (message.fire_alarm, time.time()), self._fire_status

self.on_fire(self._fire_status)

else:
self._previous_fire_status = self._fire_status
if message.battery_low == self._battery_status[0]:
self._battery_status = (self._battery_status[0], time.time())
else:
if message.battery_low == True or time.time() > self._battery_status[1] + AD2USB.BATTERY_TIMEOUT:
self._battery_status = (message.battery_low, time.time())
self.on_fire(self._battery_status)


if message.fire_alarm == self._fire_status[0]:
self._fire_status = (self._fire_status[0], time.time())
else: else:
if self._fire_status[0] == self._previous_fire_status[0]:
self._fire_status = (self._fire_status[0], time.time())
if message.fire_alarm == True or time.time() > self._fire_status[1] + AD2USB.FIRE_TIMEOUT:
self._fire_status = (message.fire_alarm, time.time())
self.on_fire(self._fire_status)


self._update_zone_tracker(message) self._update_zone_tracker(message)




Loading…
Cancel
Save