def process_bytes(self, bytes): ownership = packets.portal_ownership(bytes) if ownership == None: return my_id = craw.get_player_id() if my_id == None: self.debug_print('Unable to retrieve my ID') return player_id, portal_id = ownership if player_id != my_id: self.debug_print('IDs do not match: %08x vs. %08x (%s, %s)' % (my_id, player_id, str(type(my_id)), str(type(player_id)))) return if self.tp_handler != None: self.tp_handler(portal_id) self.tp_handler = None
def process_bytes(self, bytes): if packets.entering_game(bytes): self.initialise() message = packets.parse_message(bytes) if message != None: name, message = message my_name = utility.get_my_name() self.my_name = my_name if name not in configuration.follow_leaders: return if name != my_name and self.command_match(message, configuration.leave_command): print '%s ordered us to leave the game' % name craw.leave_game() if my_name != None and my_name in configuration.followers: self.process_command(name, message) move = packets.parse_move(bytes) if move != None: player_id, x, y = move if self.following and player_id == self.leader_id: #print 'Following %s to (%d, %d)' % (self.leader, x, y) craw.move_click(x, y) assignment = packets.town_portal_assignment(bytes) if assignment != None: object_id, x, y = assignment self.current_portal = town_portal_entry(object_id, x, y) #print 'Portal assignment: %08x (%d, %d)' % (object_id, x, y) portal_ownership = packets.portal_ownership(bytes) if portal_ownership != None: player_id, portal_id = portal_ownership if self.current_portal == None: print 'Received portal ownership information without a previous object assignment' else: self.town_portal_map[player_id] = self.current_portal x, y = self.current_portal.location #print 'Portal ownership detected: Portal %08x (%d, %d) belongs to player %08x' % (portal_id, x, y, player_id) object_removal = packets.object_removal(bytes) if object_removal != None: type, id = object_removal for player_id in self.town_portal_map: if self.town_portal_map[player_id].id == id: del self.town_portal_map[player_id] #print 'Removed portal %08x by player %08x' % (id, player_id) break try: if type == 1: del self.monsters[id] #print 'Removed unit %08x' % id except KeyError: pass add_unit = packets.parse_add_unit(bytes) if add_unit != None: unit_type, unit_id = add_unit if unit_type == 1: try: location = self.assignments[unit_id] self.monsters[unit_id] = location #print 'Added unit %08x: %s' % (unit_id, repr(location)) except KeyError: #print 'Unit was added without prior assignment: %08x' % unit_id pass npc_move = packets.parse_npc_move(bytes) if npc_move != None: unit_id, running, x, y = npc_move if unit_id in self.monsters: target = (x, y) if unit_id in self.monsters: self.monsters[unit_id] = target #print 'Monster %08x is moving to %s' % (unit_id, repr(target)) npc_assignment = packets.parse_npc_assignment(bytes) if npc_assignment != None: unit_id, unit_code, x, y, life = npc_assignment if unit_code in npc.npcs: #print 'Detected an NPC: %08x' % unit_id pass else: location = (x, y) self.assignments[unit_id] = location