+ self.net_state = "ADDRESS"
+ elif (self.net_state == "ADDRESS"):
+ # family code (1B) + serial number (6B) + CRC (1B)
+ if (self.collect_data((1+6+1)*8)):
+ self.net_address = self.net_data & 0xffffffffffffffff
+ self.net_state = "CONTROL COMMAND"
+ elif (self.net_state == "SEARCH"):
+ # family code (1B) + serial number (6B) + CRC (1B)
+ if (self.collect_search((1+6+1)*8)):
+ self.net_address = self.net_data & 0xffffffffffffffff
+ self.net_state = "CONTROL COMMAND"
+ elif (self.net_state == "CONTROL COMMAND"):
+ if (self.collect_data(8)):
+# self.put(self.lnk_fall, self.samplenum,
+# self.out_proto, ['LNK: COMMAND', self.net_data])
+ self.put(self.lnk_fall, self.samplenum, self.out_ann,
+ [ANN_DEC, ['NET: FUNCTION COMMAND: 0x' + hex(self.net_data)]])
+ print ("DEBUG: FUNCTION_COMMAND=0x%02x t0=%d t+=%d" % (self.net_data, self.lnk_fall, self.samplenum))
+ if (self.net_data == 0x48):
+ # COPY SCRATCHPAD
+ self.net_state = "TODO"
+ elif (self.net_data == 0x4e):
+ # WRITE SCRATCHPAD
+ self.net_state = "TODO"
+ elif (self.net_data == 0xbe):
+ # READ SCRATCHPAD
+ self.net_state = "TODO"
+ elif (self.net_data == 0xb8):
+ # RECALL E2
+ self.net_state = "TODO"
+ elif (self.net_data == 0xb4):
+ # READ POWER SUPPLY
+ self.net_state = "TODO"
+ else:
+ # unsupported commands
+ self.net_state = "UNDEFINED"
+ elif (self.net_state == "UNDEFINED"):
+ pass