X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Fplayer.py;h=58cb8245e6c5f0f3b466f25bf2d007dba2e544ef;hb=a33a2ebeb63a239810d3afd54827be45cfa823d2;hp=d4ff73211a54db98354f18c55c02fa5557e9a918;hpb=8f1005d3b07d61d44d5a8a0302099126f7f2e6a9;p=naja.git diff --git a/naja/player.py b/naja/player.py index d4ff732..58cb824 100644 --- a/naja/player.py +++ b/naja/player.py @@ -57,22 +57,25 @@ class PlayerBits(object): wrap = self.bits << (8 - shift) & 0xff self.bits = (self.bits >> shift | wrap) + class Player(object): """ A representation of the player. """ - def __init__(self, bits, position, movement_mode=None): + def __init__(self, bits, position, movement_mode=None, gameboard=None): self.bits = PlayerBits(bits) self.position = position self.movement_mode = movement_mode if movement_mode else MOVES.ADJACENT + self.gameboard = gameboard @classmethod - def import_player(cls, definition): + def import_player(cls, definition, gameboard=None): return cls( definition['bits'], tuple(definition['position']), - definition['movement_mode']) + definition['movement_mode'], + gameboard=gameboard) def export(self): return { @@ -148,6 +151,19 @@ class Player(object): return True return False + def set_gameboard(self, gameboard): + self.gameboard = gameboard + + def pos_has_action(self, pos): + card = self.gameboard.board_locations[pos] + for action in card.actions: + if self.bits.check_bits(action.required_bits): + return True + return False + + def filter_moves_with_no_actions(self, positions): + return [pos for pos in positions if self.pos_has_action(pos)] + def legal_moves(self): POSITION_FUNCTION = { MOVES.ADJACENT: self.get_adjacent_positions, @@ -155,7 +171,8 @@ class Player(object): MOVES.BISHOP: self.get_bishop_positions, MOVES.CASTLE: self.get_castle_positions, } - return POSITION_FUNCTION[self.movement_mode]() + positions = POSITION_FUNCTION[self.movement_mode]() + return self.filter_moves_with_no_actions(positions) def allow_chess_move(self, chesspiece): self.movement_mode = chesspiece