1
0
Fork 0
mirror of https://github.com/shlomif/PySolFC.git synced 2025-04-05 00:02:29 -04:00

+ 1 new game

* minor fixes


git-svn-id: file:///home/shlomif/Backup/svn-dumps/PySolFC/svnsync-repos/pysolfc/PySolFC/trunk@249 efabe8c0-fbe8-4139-b769-b5e6d273206e
This commit is contained in:
skomoroh 2009-08-08 05:33:50 +00:00
parent 735f0c0e5a
commit 1ac67d54c4
5 changed files with 14 additions and 24 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.1 KiB

After

Width:  |  Height:  |  Size: 4.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.1 KiB

After

Width:  |  Height:  |  Size: 3.8 KiB

View file

@ -914,6 +914,7 @@ class FirTree_GameMethods:
class ThreeFirTrees(Golf, FirTree_GameMethods):
Hint_Class = CautiousDefaultHint
Waste_Class = Golf_Waste
def createGame(self):
@ -929,7 +930,7 @@ class ThreeFirTrees(Golf, FirTree_GameMethods):
s.talon = Golf_Talon(x, y, self, max_rounds=1)
l.createText(s.talon, 'n')
x += l.XS
s.waste = Golf_Waste(x, y, self)
s.waste = self.Waste_Class(x, y, self)
s.waste.CARD_XOFFSET = l.XOFFSET/4
l.createText(s.waste, 'n')
# the Waste is also our only Foundation in this game
@ -946,6 +947,10 @@ class ThreeFirTrees(Golf, FirTree_GameMethods):
self.s.talon.dealCards()
class RelaxedThreeFirTrees(ThreeFirTrees):
Waste_Class = StackWrapper(Golf_Waste, mod=13)
# ************************************************************************
# * Napoleon Takes Moscow
# * Napoleon Leaves Moscow
@ -1169,4 +1174,6 @@ registerGame(GameInfo(763, Wasatch, "Wasatch",
GI.GT_1DECK_TYPE, 1, UNLIMITED_REDEALS, GI.SL_MOSTLY_LUCK))
registerGame(GameInfo(764, Beacon, "Beacon",
GI.GT_1DECK_TYPE | GI.GT_ORIGINAL, 1, 0, GI.SL_MOSTLY_SKILL))
registerGame(GameInfo(768, RelaxedThreeFirTrees, "Relaxed Three Fir-trees",
GI.GT_GOLF, 2, 0, GI.SL_BALANCED))

View file

@ -727,22 +727,10 @@ class TripleAlliance(Game):
# * Pharaohs
# ************************************************************************
class Pharaohs_RowStack(Pyramid_RowStack):
def acceptsCards(self, from_stack, cards):
if not self.basicAcceptsCards(from_stack, cards):
return False
if not self.cards:
return False
r0, r1 = cards[0].rank, self.cards[-1].rank
if r0+r1 == 11:
return True
return r0 == r1
class Pharaohs(Pyramid):
Talon_Class = InitialDealTalonStack
RowStack_Class = Pharaohs_RowStack
RowStack_Class = Pyramid_RowStack
PYRAMID_Y_FACTOR = 3
@ -769,6 +757,7 @@ class Pharaohs(Pyramid):
s.foundations.append(Pyramid_Foundation(x, y, self,
suit=ANY_SUIT, dir=0, base_rank=ANY_RANK,
max_move=0, max_cards=52))
l.createText(s.foundations[0], 's')
# define stack-groups
l.defaultStackGroups()
@ -867,7 +856,7 @@ class Apophis_Hint(Pyramid_Hint):
self.addHint(50000+len(r1.cards)+len(r2.cards), 1, r1, r2)
class Apophis_RowStack(Pharaohs_RowStack):
class Apophis_RowStack(Pyramid_RowStack):
def acceptsCards(self, from_stack, cards):
if not self.basicAcceptsCards(from_stack, cards):
return False

View file

@ -194,9 +194,7 @@ class DutchSolitaire(Windmill):
# * Napoleon's Tomb
# ************************************************************************
class NapoleonsTomb(Windmill):
FILL_STACK = False
class NapoleonsTomb(Game):
#
# game layout
@ -223,12 +221,11 @@ class NapoleonsTomb(Windmill):
s.rows.append(Windmill_RowStack(x, y, self))
x, y = x0 + l.XS, y0 + l.YS
s.foundations.append(Windmill_Foundation(x, y, self, base_rank=5,
mod=6, min_cards=1, max_cards=24,
max_move=0, dir=-1))
mod=13, max_cards=24, dir=-1))
for d in ((0.1, 0.1), (1.9, 0.1), (0.1, 1.9), (1.9, 1.9)):
x, y = x0 + d[0] * l.XS, y0 + d[1] * l.YS
s.foundations.append(Windmill_Foundation(x, y, self,
max_cards=7, base_rank=6, max_move=0))
max_cards=7, base_rank=6, mod=13))
# define stack-groups
l.defaultStackGroups()
@ -238,9 +235,6 @@ class NapoleonsTomb(Windmill):
# game overrides
#
def _shuffleHook(self, cards):
return cards
def startGame(self):
self.startDealSample()
self.s.talon.dealRow()