forked from test/mau_mau_bot
66 lines
1.7 KiB
Python
66 lines
1.7 KiB
Python
import logging
|
|
|
|
from deck import Deck
|
|
from card import Card
|
|
import card as c
|
|
from player import Player
|
|
|
|
|
|
class Game(object):
|
|
""" This class represents a game of mau mau
|
|
|
|
:type current_player: Player
|
|
"""
|
|
current_player = None
|
|
reversed = False
|
|
draw_counter = 0
|
|
choosing_color = False
|
|
|
|
def __init__(self):
|
|
self.deck = Deck()
|
|
self.last_card = self.deck.draw()
|
|
self.logger = logging.getLogger(__name__)
|
|
|
|
def reverse(self):
|
|
self.reversed = not self.reversed
|
|
|
|
def turn(self):
|
|
self.logger.debug("Next Player")
|
|
self.current_player = self.current_player.next
|
|
self.current_player.drew = False
|
|
|
|
def play_card(self, card):
|
|
"""
|
|
|
|
:param card:
|
|
:type card: Card
|
|
:return:
|
|
"""
|
|
self.deck.dismiss(self.last_card)
|
|
self.last_card = card
|
|
|
|
self.logger.info("Playing card " + repr(card))
|
|
if card.value == c.SKIP:
|
|
self.turn()
|
|
elif card.special == c.DRAW_FOUR:
|
|
self.draw_counter += 4
|
|
self.logger.debug("Draw counter increased by 4")
|
|
elif card.value == c.DRAW_TWO:
|
|
self.draw_counter += 2
|
|
self.logger.debug("Draw counter increased by 2")
|
|
elif card.value == c.REVERSE:
|
|
if self.current_player is self.current_player.next.next:
|
|
self.turn()
|
|
else:
|
|
self.reverse()
|
|
|
|
if card.special not in (c.CHOOSE, c.DRAW_FOUR):
|
|
self.turn()
|
|
else:
|
|
self.logger.debug("Choosing Color...")
|
|
self.choosing_color = True
|
|
|
|
def choose_color(self, color):
|
|
self.last_card.color = color
|
|
self.turn()
|
|
self.choosing_color = False
|