Skip to content

Commit

Permalink
add parameter wait_for_response to all write functions
Browse files Browse the repository at this point in the history
  • Loading branch information
mtttz committed Apr 10, 2021
1 parent 6f7904d commit f98bffa
Showing 1 changed file with 39 additions and 10 deletions.
49 changes: 39 additions & 10 deletions trionesControl/trionesControl.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,21 +21,39 @@ def disconnect(device):
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("Device disconnected")
def powerOn(device):

def powerOn(device, wait_for_response=False):
"""
:param bool wait_for_response: wait for response after writing. A GATT "command"
is used when not waiting for a response. The remote host will not
acknowledge the write.
"""

try:
device.char_write(MAIN_CHARACTERISTIC_UUID, b'\xcc\x23\x33')
device.char_write(MAIN_CHARACTERISTIC_UUID, b'\xcc\x23\x33', wait_for_response=wait_for_response)
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("Device powered on")

def powerOff(device):
def powerOff(device, wait_for_response=False):
"""
:param bool wait_for_response: wait for response after writing. A GATT "command"
is used when not waiting for a response. The remote host will not
acknowledge the write.
"""

try:
device.char_write(MAIN_CHARACTERISTIC_UUID, b'\xcc\x24\x33')
device.char_write(MAIN_CHARACTERISTIC_UUID, b'\xcc\x24\x33', wait_for_response=wait_for_response)
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("Device powered off")

def setRGB(r: int, g: int, b: int, device):
def setRGB(r: int, g: int, b: int, device, wait_for_response=False):
"""
:param bool wait_for_response: wait for response after writing. A GATT "command"
is used when not waiting for a response. The remote host will not
acknowledge the write.
"""
# Values for color should be between 0 and 255
if r > 255: r = 255
if r < 0: r= 0
Expand All @@ -53,12 +71,17 @@ def setRGB(r: int, g: int, b: int, device):
payload.append(0xF0)
payload.append(0xAA)
try:
device.char_write(MAIN_CHARACTERISTIC_UUID, payload)
device.char_write(MAIN_CHARACTERISTIC_UUID, payload, wait_for_response=wait_for_response)
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("RGB set -- R: %d, G: %d, B: %d", r, g, b)

def setWhite(intensity: int, device):
def setWhite(intensity: int, device, wait_for_response=False):
"""
:param bool wait_for_response: wait for response after writing. A GATT "command"
is used when not waiting for a response. The remote host will not
acknowledge the write.
"""
# Intensity value shoud be between 0 and 255
if (intensity > 255): intensity = 255
if (intensity < 0): intensity = 0
Expand All @@ -71,12 +94,18 @@ def setWhite(intensity: int, device):
payload.append(0x0F)
payload.append(0xAA)
try:
device.char_write(MAIN_CHARACTERISTIC_UUID, payload)
device.char_write(MAIN_CHARACTERISTIC_UUID, payload, wait_for_response=wait_for_response)
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("White color set -- Intensity: %d", intensity)

def setBuiltIn(mode: int, speed: int, device):
def setBuiltIn(mode: int, speed: int, device, wait_for_response=False):
"""
:param bool wait_for_response: wait for response after writing. A GATT "command"
is used when not waiting for a response. The remote host will not
acknowledge the write.
"""

if mode<37 | mode > 56:
raise pygatt.exceptions.BLEError("Invalid Mode")
if speed<1: speed =1
Expand All @@ -87,7 +116,7 @@ def setBuiltIn(mode: int, speed: int, device):
payload.append(speed)
payload.append(0x44)
try:
device.char_write(MAIN_CHARACTERISTIC_UUID, payload)
device.char_write(MAIN_CHARACTERISTIC_UUID, payload, wait_for_response=wait_for_response)
except pygatt.exceptions.NotConnectedError:
raise pygatt.exceptions.NotConnectedError("Device nor connected!")
log.info("Default mode %d set -- Speed %d", mode, speed)
Expand Down

0 comments on commit f98bffa

Please sign in to comment.