2017-12-30 12:15:51 -06:00
|
|
|
from table.trash import Trash
|
|
|
|
|
from table.pile import Pile
|
2017-12-24 13:00:51 -06:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class Table:
|
|
|
|
|
def __init__(self):
|
|
|
|
|
self.__player = list()
|
|
|
|
|
self.__pile = list()
|
|
|
|
|
self.__trash = Trash()
|
|
|
|
|
self.__winner = None
|
|
|
|
|
self.__winning_score = 0
|
|
|
|
|
|
|
|
|
|
def add_player(self, p):
|
|
|
|
|
self.__player.append(p)
|
|
|
|
|
|
|
|
|
|
def get_player(self, n):
|
|
|
|
|
return self.__player[n]
|
|
|
|
|
|
2017-12-26 15:33:05 -06:00
|
|
|
def get_players(self):
|
|
|
|
|
return self.__player
|
|
|
|
|
|
2017-12-28 18:24:07 -06:00
|
|
|
def get_trash(self):
|
|
|
|
|
return self.__trash
|
|
|
|
|
|
2018-01-04 01:50:34 -06:00
|
|
|
def create_pile(self, card):
|
|
|
|
|
p = Pile(card)
|
2017-12-31 17:02:27 -06:00
|
|
|
p.add_card(card)
|
|
|
|
|
card.setup()
|
2017-12-24 13:00:51 -06:00
|
|
|
self.__pile.append(p)
|
|
|
|
|
|
|
|
|
|
def get_piles(self):
|
|
|
|
|
return self.__pile
|
|
|
|
|
|
|
|
|
|
def get_pile(self, n):
|
|
|
|
|
return self.__pile[n]
|
|
|
|
|
|
2017-12-26 15:33:05 -06:00
|
|
|
def get_pile_count(self):
|
|
|
|
|
return len(self.__pile)
|
|
|
|
|
|
2017-12-24 13:00:51 -06:00
|
|
|
def get_pile_index_of_card(self, card_name):
|
|
|
|
|
result = 0
|
2017-12-30 11:56:31 -06:00
|
|
|
|
2017-12-24 13:00:51 -06:00
|
|
|
for p in self.__pile:
|
|
|
|
|
if p.get_card_group().get_name() == card_name:
|
|
|
|
|
result = self.__pile.index(p)
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
def are_there_any_empty_piles(self):
|
|
|
|
|
result = False
|
|
|
|
|
for p in self.__pile:
|
|
|
|
|
result = result or p.get_remaining() == 0
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
|
def play(self):
|
|
|
|
|
turn = 0
|
2017-12-30 22:33:43 -06:00
|
|
|
# turn < 10 is for testing, otherwise endless as buying card is not yet done
|
2018-01-04 01:50:34 -06:00
|
|
|
while not self.are_there_any_empty_piles(): # and turn < 10:
|
2017-12-24 13:00:51 -06:00
|
|
|
self.print()
|
|
|
|
|
self.__player[turn % len(self.__player)].take_turn()
|
|
|
|
|
turn += 1
|
|
|
|
|
else:
|
|
|
|
|
self.print()
|
2018-01-05 04:23:27 -06:00
|
|
|
print("\n\nGame had " + str(turn) + " turns in " + str(turn/len(self.__player)) + " rounds.")
|
2017-12-24 13:00:51 -06:00
|
|
|
for p in self.__player:
|
2018-01-04 01:50:34 -06:00
|
|
|
print("" + str(p) + " scored " + str(p.get_score()) + " points.")
|
2017-12-24 13:00:51 -06:00
|
|
|
if p.get_score() > self.__winning_score:
|
2018-01-04 01:50:34 -06:00
|
|
|
self.__winning_score = p.get_score()
|
2017-12-24 13:00:51 -06:00
|
|
|
self.__winner = p
|
2018-01-05 04:23:27 -06:00
|
|
|
print("\n" + str(self.__winner) + " won with " + str(self.__winning_score) + " points.\n\n")
|
2017-12-24 13:00:51 -06:00
|
|
|
|
|
|
|
|
def print(self):
|
2017-12-26 15:33:05 -06:00
|
|
|
print("\nPiles: ")
|
|
|
|
|
index = 0
|
2017-12-24 13:00:51 -06:00
|
|
|
for s in self.__pile:
|
2017-12-26 15:33:05 -06:00
|
|
|
print(str(index) + ": " + s.get_card_group().identify() + ": " + str(s.get_remaining()))
|
|
|
|
|
index += 1
|
2017-12-30 11:56:31 -06:00
|
|
|
|
|
|
|
|
print("\nTrash: ")
|
|
|
|
|
index = 0
|
|
|
|
|
for s in self.__trash.get_supply():
|
|
|
|
|
print(str(index) + ": " + s.identify())
|
|
|
|
|
index += 1
|
2017-12-31 17:02:27 -06:00
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
|
return "A table with " + str(len(self.__pile)) + " card piles and " + str(len(self.__player)) + " players."
|