panda/tests/can_printer.py

40 lines
995 B
Python
Raw Normal View History

2019-09-24 18:50:53 -06:00
#!/usr/bin/env python3
2019-09-24 23:33:46 -06:00
2017-05-27 13:31:29 -06:00
import os
import sys
2017-05-27 13:31:29 -06:00
import time
from collections import defaultdict
2018-03-04 12:52:53 -07:00
import binascii
sys.path.append(os.path.join(os.path.dirname(os.path.realpath(__file__)), ".."))
from panda import Panda # noqa: E402
2017-05-27 13:31:29 -06:00
# fake
def sec_since_boot():
return time.time()
def can_printer():
p = Panda()
p.set_safety_mode(Panda.SAFETY_ALLOUTPUT)
2017-05-27 13:31:29 -06:00
start = sec_since_boot()
lp = sec_since_boot()
msgs = defaultdict(list)
canbus = int(os.getenv("CAN", 0))
while True:
2017-05-27 13:31:29 -06:00
can_recv = p.can_recv()
for address, _, dat, src in can_recv:
2017-05-27 13:31:29 -06:00
if src == canbus:
msgs[address].append(dat)
if sec_since_boot() - lp > 0.1:
dd = chr(27) + "[2J"
dd += "%5.2f\n" % (sec_since_boot() - start)
for k, v in sorted(zip(list(msgs.keys()), [binascii.hexlify(x[-1]) for x in list(msgs.values())])):
dd += "%s(%6d) %s\n" % ("%04X(%4d)" % (k, k), len(msgs[k]), v)
print(dd)
2017-05-27 13:31:29 -06:00
lp = sec_since_boot()
if __name__ == "__main__":
can_printer()