vban-cmd-python/examples/observer/__main__.py

39 lines
906 B
Python
Raw Normal View History

import logging
import vban_cmd
class Observer:
def __init__(self, vban):
self.vban = vban
# register your app as event observer
self.vban.subject.add(self)
# enable level updates, since they are disabled by default.
self.vban.event.ldirty = True
# define an 'on_update' callback function to receive event updates
def on_update(self, subject):
if subject == "pdirty":
print("pdirty!")
elif subject == "ldirty":
for bus in self.vban.bus:
if bus.levels.isdirty:
print(bus, bus.levels.all)
def main():
kind_id = "potato"
with vban_cmd.api(kind_id) as vban:
Observer(vban)
while cmd := input("Press <Enter> to exit\n"):
if not cmd:
break
if __name__ == "__main__":
logging.basicConfig(level=logging.INFO)
main()