mirror of
https://github.com/shlomif/PySolFC.git
synced 2025-04-05 00:02:29 -04:00
+ 6 new game
* fixed game `Arachnida' + expanded debug support git-svn-id: https://pysolfc.svn.sourceforge.net/svnroot/pysolfc/PySolFC/trunk@20 39dd0a4e-7c14-0410-91b3-c4f2d318f732
This commit is contained in:
parent
3c25e97e13
commit
e97a944692
9 changed files with 234 additions and 45 deletions
|
@ -91,7 +91,7 @@ class StreetsAndAlleys(Game):
|
||||||
y += l.YS
|
y += l.YS
|
||||||
x = x1
|
x = x1
|
||||||
for i in range(4):
|
for i in range(4):
|
||||||
s.foundations.append(self.Foundation_Class(x, y, self, i, max_move=0))
|
s.foundations.append(self.Foundation_Class(x, y, self, suit=i, max_move=0))
|
||||||
y = y + l.YS
|
y = y + l.YS
|
||||||
if texts:
|
if texts:
|
||||||
tx, ty, ta, tf = l.getTextAttr(None, "ss")
|
tx, ty, ta, tf = l.getTextAttr(None, "ss")
|
||||||
|
@ -148,6 +148,7 @@ class BeleagueredCastle(StreetsAndAlleys):
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // Citadel
|
# // Citadel
|
||||||
|
# // Exiled Kings
|
||||||
# ************************************************************************/
|
# ************************************************************************/
|
||||||
|
|
||||||
class Citadel(StreetsAndAlleys):
|
class Citadel(StreetsAndAlleys):
|
||||||
|
@ -174,6 +175,10 @@ class Citadel(StreetsAndAlleys):
|
||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
|
class ExiledKings(Citadel):
|
||||||
|
RowStack_Class = StackWrapper(RK_RowStack, base_rank=KING)
|
||||||
|
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // Fortress
|
# // Fortress
|
||||||
# ************************************************************************/
|
# ************************************************************************/
|
||||||
|
@ -750,3 +755,5 @@ registerGame(GameInfo(508, CastleMount, "Castle Mount",
|
||||||
GI.GT_BELEAGUERED_CASTLE | GI.GT_OPEN, 3, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_BELEAGUERED_CASTLE | GI.GT_OPEN, 3, 0, GI.SL_MOSTLY_SKILL))
|
||||||
registerGame(GameInfo(524, SelectiveCastle, "Selective Castle",
|
registerGame(GameInfo(524, SelectiveCastle, "Selective Castle",
|
||||||
GI.GT_BELEAGUERED_CASTLE | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_BELEAGUERED_CASTLE | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
registerGame(GameInfo(535, ExiledKings, "Exiled Kings",
|
||||||
|
GI.GT_BELEAGUERED_CASTLE | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
|
|
@ -47,9 +47,11 @@ class CurdsAndWhey_RowStack(BasicRowStack):
|
||||||
if not self.cards:
|
if not self.cards:
|
||||||
return True
|
return True
|
||||||
c1, c2 = self.cards[-1], cards[0]
|
c1, c2 = self.cards[-1], cards[0]
|
||||||
|
if c1.rank == c2.rank:
|
||||||
|
return True
|
||||||
if c1.suit == c2.suit:
|
if c1.suit == c2.suit:
|
||||||
return c1.rank == c2.rank+1
|
return c1.rank == c2.rank+1
|
||||||
return c1.rank == c2.rank
|
return False
|
||||||
|
|
||||||
def canMoveCards(self, cards):
|
def canMoveCards(self, cards):
|
||||||
return isSameSuitSequence(cards) or isRankSequence(cards, dir=0)
|
return isSameSuitSequence(cards) or isRankSequence(cards, dir=0)
|
||||||
|
@ -197,6 +199,7 @@ class Robin(Dumfries):
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // Arachnida
|
# // Arachnida
|
||||||
|
# // Harvestman
|
||||||
# ************************************************************************/
|
# ************************************************************************/
|
||||||
|
|
||||||
class Arachnida_RowStack(BasicRowStack):
|
class Arachnida_RowStack(BasicRowStack):
|
||||||
|
@ -216,13 +219,14 @@ class Arachnida_RowStack(BasicRowStack):
|
||||||
|
|
||||||
|
|
||||||
class Arachnida(CurdsAndWhey):
|
class Arachnida(CurdsAndWhey):
|
||||||
|
RowStack_Class = Arachnida_RowStack
|
||||||
|
|
||||||
def createGame(self):
|
def createGame(self):
|
||||||
# create layout
|
# create layout
|
||||||
l, s = Layout(self), self.s
|
l, s = Layout(self), self.s
|
||||||
|
|
||||||
# set window
|
# set window
|
||||||
w, h = l.XM+11*l.XS, l.YM+l.YS+16*l.YOFFSET
|
w, h = l.XM+12*l.XS, l.YM+l.YS+16*l.YOFFSET
|
||||||
self.setSize(w, h)
|
self.setSize(w, h)
|
||||||
|
|
||||||
# create stacks
|
# create stacks
|
||||||
|
@ -231,11 +235,14 @@ class Arachnida(CurdsAndWhey):
|
||||||
l.createText(s.talon, "ss")
|
l.createText(s.talon, "ss")
|
||||||
x += l.XS
|
x += l.XS
|
||||||
for i in range(10):
|
for i in range(10):
|
||||||
stack = Arachnida_RowStack(x, y, self, base_rank=ANY_RANK,
|
stack = self.RowStack_Class(x, y, self, base_rank=ANY_RANK,
|
||||||
max_move=UNLIMITED_MOVES,
|
max_move=UNLIMITED_MOVES,
|
||||||
max_accept=UNLIMITED_ACCEPTS)
|
max_accept=UNLIMITED_ACCEPTS)
|
||||||
s.rows.append(stack)
|
s.rows.append(stack)
|
||||||
x += l.XS
|
x += l.XS
|
||||||
|
s.foundations.append(AbstractFoundationStack(x, y, self, suit=ANY_SUIT,
|
||||||
|
max_accept=0))
|
||||||
|
l.createText(s.foundations[0], "ss")
|
||||||
|
|
||||||
# define stack-groups
|
# define stack-groups
|
||||||
l.defaultStackGroups()
|
l.defaultStackGroups()
|
||||||
|
@ -247,10 +254,31 @@ class Arachnida(CurdsAndWhey):
|
||||||
self.startDealSample()
|
self.startDealSample()
|
||||||
self.s.talon.dealRow()
|
self.s.talon.dealRow()
|
||||||
|
|
||||||
|
def canDealCards(self):
|
||||||
|
if not CurdsAndWhey.canDealCards(self):
|
||||||
|
return False
|
||||||
|
# no row may be empty
|
||||||
|
for r in self.s.rows:
|
||||||
|
if not r.cards:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
|
def fillStack(self, stack):
|
||||||
|
for r in self.s.rows:
|
||||||
|
if len(r.cards) >= 13 and isSameSuitSequence(r.cards[-13:]):
|
||||||
|
old_state = self.enterState(self.S_FILL)
|
||||||
|
self.playSample("drop", priority=200)
|
||||||
|
self.moveMove(13, r, self.s.foundations[0])
|
||||||
|
self.leaveState(old_state)
|
||||||
|
|
||||||
def shallHighlightMatch(self, stack1, card1, stack2, card2):
|
def shallHighlightMatch(self, stack1, card1, stack2, card2):
|
||||||
return card1.rank == card2.rank or abs(card1.rank-card2.rank) == 1
|
return card1.rank == card2.rank or abs(card1.rank-card2.rank) == 1
|
||||||
|
|
||||||
|
|
||||||
|
class Harvestman(Arachnida):
|
||||||
|
RowStack_Class = CurdsAndWhey_RowStack
|
||||||
|
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // German Patience
|
# // German Patience
|
||||||
# // Bavarian Patience
|
# // Bavarian Patience
|
||||||
|
@ -412,4 +440,7 @@ registerGame(GameInfo(481, KnottyNines, "Knotty Nines",
|
||||||
GI.GT_1DECK_TYPE, 1, 0, GI.SL_BALANCED))
|
GI.GT_1DECK_TYPE, 1, 0, GI.SL_BALANCED))
|
||||||
registerGame(GameInfo(482, SweetSixteen, "Sweet Sixteen",
|
registerGame(GameInfo(482, SweetSixteen, "Sweet Sixteen",
|
||||||
GI.GT_1DECK_TYPE, 1, 0, GI.SL_BALANCED))
|
GI.GT_1DECK_TYPE, 1, 0, GI.SL_BALANCED))
|
||||||
|
registerGame(GameInfo(534, Harvestman, "Harvestman",
|
||||||
|
GI.GT_SPIDER | GI.GT_ORIGINAL, 2, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,7 @@ from pysollib.game import Game
|
||||||
from pysollib.layout import Layout
|
from pysollib.layout import Layout
|
||||||
from pysollib.hint import AbstractHint, DefaultHint, CautiousDefaultHint
|
from pysollib.hint import AbstractHint, DefaultHint, CautiousDefaultHint
|
||||||
|
|
||||||
from pysollib.games.gypsy import DieKoenigsbergerin_Talon, DieRussische_Foundation
|
from gypsy import DieKoenigsbergerin_Talon, DieRussische_Foundation
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // Die böse Sieben
|
# // Die böse Sieben
|
||||||
|
|
|
@ -251,9 +251,14 @@ class Carnation(Limited):
|
||||||
|
|
||||||
|
|
||||||
class SanJuanHill(FortyThieves):
|
class SanJuanHill(FortyThieves):
|
||||||
def createGame(self):
|
|
||||||
FortyThieves.createGame(self, XOFFSET=0)
|
|
||||||
|
|
||||||
|
def _shuffleHook(self, cards):
|
||||||
|
return self._shuffleHookMoveToTop(cards,
|
||||||
|
lambda c: (c.rank == ACE, c.suit))
|
||||||
|
|
||||||
|
def startGame(self):
|
||||||
|
self.s.talon.dealRow(rows=self.s.foundations, frames=0)
|
||||||
|
FortyThieves.startGame(self)
|
||||||
|
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
|
|
|
@ -44,20 +44,13 @@ from pysollib.layout import Layout
|
||||||
from pysollib.hint import AbstractHint, DefaultHint, CautiousDefaultHint
|
from pysollib.hint import AbstractHint, DefaultHint, CautiousDefaultHint
|
||||||
from pysollib.pysoltk import MfxCanvasText
|
from pysollib.pysoltk import MfxCanvasText
|
||||||
|
|
||||||
from pysollib.games.braid import Braid_Foundation
|
from braid import Braid_Foundation
|
||||||
|
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
# // stacks
|
# // stacks
|
||||||
# ************************************************************************/
|
# ************************************************************************/
|
||||||
|
|
||||||
class Napoleon_Talon(InitialDealTalonStack):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
class Napoleon_Foundation(Braid_Foundation):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
class Napoleon_RowStack(UD_SS_RowStack):
|
class Napoleon_RowStack(UD_SS_RowStack):
|
||||||
def getBottomImage(self):
|
def getBottomImage(self):
|
||||||
|
@ -96,13 +89,14 @@ class Napoleon_FreeCell(ReserveStack):
|
||||||
|
|
||||||
class DerKleineNapoleon(Game):
|
class DerKleineNapoleon(Game):
|
||||||
|
|
||||||
|
Foundation_Class = Braid_Foundation
|
||||||
RowStack_Class = StackWrapper(Napoleon_RowStack, mod=13)
|
RowStack_Class = StackWrapper(Napoleon_RowStack, mod=13)
|
||||||
|
|
||||||
#
|
#
|
||||||
# game layout
|
# game layout
|
||||||
#
|
#
|
||||||
|
|
||||||
def createGame(self, reserves=1):
|
def createGame(self, cells=1):
|
||||||
# create layout
|
# create layout
|
||||||
l, s = Layout(self), self.s
|
l, s = Layout(self), self.s
|
||||||
|
|
||||||
|
@ -119,7 +113,7 @@ class DerKleineNapoleon(Game):
|
||||||
s.rows.append(self.RowStack_Class(x2, y, self))
|
s.rows.append(self.RowStack_Class(x2, y, self))
|
||||||
y = y + l.YS
|
y = y + l.YS
|
||||||
y = self.height - l.YS
|
y = self.height - l.YS
|
||||||
if reserves == 1:
|
if cells == 1:
|
||||||
s.rows.append(Napoleon_ReserveStack(x0, y, self))
|
s.rows.append(Napoleon_ReserveStack(x0, y, self))
|
||||||
s.rows.append(Napoleon_ReserveStack(x2, y, self))
|
s.rows.append(Napoleon_ReserveStack(x2, y, self))
|
||||||
s.reserves.append(Napoleon_SingleFreeCell(x1, y, self))
|
s.reserves.append(Napoleon_SingleFreeCell(x1, y, self))
|
||||||
|
@ -131,15 +125,15 @@ class DerKleineNapoleon(Game):
|
||||||
# foundations
|
# foundations
|
||||||
x, y = x1, l.YM
|
x, y = x1, l.YM
|
||||||
for i in range(4):
|
for i in range(4):
|
||||||
s.foundations.append(Napoleon_Foundation(x, y, self, i))
|
s.foundations.append(self.Foundation_Class(x, y, self, i))
|
||||||
y = y + l.YS
|
y = y + l.YS
|
||||||
# talon
|
# talon
|
||||||
if reserves == 1:
|
if cells == 1:
|
||||||
##x, y = l.XM, self.height - l.YS
|
##x, y = l.XM, self.height - l.YS
|
||||||
y = self.height + l.YS
|
y = self.height + l.YS
|
||||||
else:
|
else:
|
||||||
y = self.height - l.YS
|
y = self.height - l.YS
|
||||||
s.talon = Napoleon_Talon(x, y, self)
|
s.talon = InitialDealTalonStack(x, y, self)
|
||||||
|
|
||||||
# update stack building direction
|
# update stack building direction
|
||||||
for r in s.rows:
|
for r in s.rows:
|
||||||
|
@ -200,12 +194,16 @@ class DerKleineNapoleon(Game):
|
||||||
|
|
||||||
class DerFreieNapoleon(DerKleineNapoleon):
|
class DerFreieNapoleon(DerKleineNapoleon):
|
||||||
|
|
||||||
|
Foundation_Class = Braid_Foundation
|
||||||
RowStack_Class = StackWrapper(Napoleon_RowStack, mod=13)
|
RowStack_Class = StackWrapper(Napoleon_RowStack, mod=13)
|
||||||
|
ReserveStack_Class = Napoleon_ReserveStack
|
||||||
|
FreeCell_Class = Napoleon_SingleFreeCell
|
||||||
|
|
||||||
#
|
#
|
||||||
# game layout
|
# game layout
|
||||||
#
|
#
|
||||||
|
|
||||||
def createGame(self, reserves=1):
|
def createGame(self, cells=1, reserves=2, texts=True):
|
||||||
# create layout
|
# create layout
|
||||||
l, s = Layout(self), self.s
|
l, s = Layout(self), self.s
|
||||||
|
|
||||||
|
@ -213,7 +211,8 @@ class DerFreieNapoleon(DerKleineNapoleon):
|
||||||
# set size so that at least 2/3 of a card is visible with 15 cards
|
# set size so that at least 2/3 of a card is visible with 15 cards
|
||||||
h = l.CH*2/3 + (15-1)*l.YOFFSET
|
h = l.CH*2/3 + (15-1)*l.YOFFSET
|
||||||
h = l.YS + max(h, 3*l.YS)
|
h = l.YS + max(h, 3*l.YS)
|
||||||
self.setSize(l.XM + 2*l.XM + 10*l.XS, l.YM + h)
|
max_rows = 8+max(cells, reserves)
|
||||||
|
self.setSize(l.XM + 2*l.XM + max_rows*l.XS, l.YM + h)
|
||||||
x1 = l.XM + 8*l.XS + 2*l.XM
|
x1 = l.XM + 8*l.XS + 2*l.XM
|
||||||
|
|
||||||
# create stacks
|
# create stacks
|
||||||
|
@ -221,27 +220,32 @@ class DerFreieNapoleon(DerKleineNapoleon):
|
||||||
for j in range(8):
|
for j in range(8):
|
||||||
x = l.XM + j*l.XS
|
x = l.XM + j*l.XS
|
||||||
s.rows.append(self.RowStack_Class(x, y, self))
|
s.rows.append(self.RowStack_Class(x, y, self))
|
||||||
for j in range(2):
|
for j in range(reserves):
|
||||||
x = x1 + j*l.XS
|
x = x1 + j*l.XS
|
||||||
s.rows.append(Napoleon_ReserveStack(x, y, self))
|
s.rows.append(self.ReserveStack_Class(x, y, self))
|
||||||
self.setRegion(s.rows, (-999, y - l.YM/2, 999999, 999999))
|
self.setRegion(s.rows, (-999, y - l.YM/2, 999999, 999999))
|
||||||
y = l.YM
|
y = l.YM
|
||||||
if reserves == 1:
|
x = x1+(max(cells, reserves)-cells)*l.XS/2
|
||||||
s.reserves.append(Napoleon_SingleFreeCell(x1 + l.XS/2, y, self))
|
for i in range(cells):
|
||||||
else:
|
s.reserves.append(self.FreeCell_Class(x, y, self))
|
||||||
s.reserves.append(Napoleon_FreeCell(x1, y, self))
|
x += l.XS
|
||||||
s.reserves.append(Napoleon_FreeCell(x1 + l.XS, y, self))
|
## if cells == 1:
|
||||||
|
## s.reserves.append(Napoleon_SingleFreeCell(x1 + l.XS/2, y, self))
|
||||||
|
## else:
|
||||||
|
## s.reserves.append(Napoleon_FreeCell(x1, y, self))
|
||||||
|
## s.reserves.append(Napoleon_FreeCell(x1 + l.XS, y, self))
|
||||||
# foundations
|
# foundations
|
||||||
x = l.XM + 2*l.XS
|
x = l.XM + 2*l.XS
|
||||||
for i in range(4):
|
for i in range(4):
|
||||||
s.foundations.append(Napoleon_Foundation(x, y, self, i))
|
s.foundations.append(self.Foundation_Class(x, y, self, i))
|
||||||
x = x + l.XS
|
x = x + l.XS
|
||||||
tx, ty, ta, tf = l.getTextAttr(s.foundations[-1], "se")
|
if texts:
|
||||||
font = self.app.getFont("canvas_default")
|
tx, ty, ta, tf = l.getTextAttr(s.foundations[-1], "se")
|
||||||
self.texts.info = MfxCanvasText(self.canvas, tx, ty, anchor=ta, font=font)
|
font = self.app.getFont("canvas_default")
|
||||||
|
self.texts.info = MfxCanvasText(self.canvas, tx, ty, anchor=ta, font=font)
|
||||||
# talon
|
# talon
|
||||||
x, y = l.XM, self.height - l.YS
|
x, y = l.XM, self.height - l.YS
|
||||||
s.talon = Napoleon_Talon(x, y, self)
|
s.talon = InitialDealTalonStack(x, y, self)
|
||||||
|
|
||||||
# define stack-groups
|
# define stack-groups
|
||||||
l.defaultStackGroups()
|
l.defaultStackGroups()
|
||||||
|
@ -253,12 +257,101 @@ class DerFreieNapoleon(DerKleineNapoleon):
|
||||||
|
|
||||||
class Napoleon(DerKleineNapoleon):
|
class Napoleon(DerKleineNapoleon):
|
||||||
def createGame(self):
|
def createGame(self):
|
||||||
DerKleineNapoleon.createGame(self, reserves=2)
|
DerKleineNapoleon.createGame(self, cells=2)
|
||||||
|
|
||||||
|
|
||||||
class FreeNapoleon(DerFreieNapoleon):
|
class FreeNapoleon(DerFreieNapoleon):
|
||||||
|
FreeCell_Class = Napoleon_FreeCell
|
||||||
def createGame(self):
|
def createGame(self):
|
||||||
DerFreieNapoleon.createGame(self, reserves=2)
|
DerFreieNapoleon.createGame(self, cells=2)
|
||||||
|
|
||||||
|
|
||||||
|
# /***********************************************************************
|
||||||
|
# // Master
|
||||||
|
# ************************************************************************/
|
||||||
|
|
||||||
|
class Master(DerFreieNapoleon):
|
||||||
|
|
||||||
|
Foundation_Class = SS_FoundationStack
|
||||||
|
|
||||||
|
def createGame(self):
|
||||||
|
DerFreieNapoleon.createGame(self, cells=2, texts=False)
|
||||||
|
|
||||||
|
def _shuffleHook(self, cards):
|
||||||
|
return self._shuffleHookMoveToBottom(cards,
|
||||||
|
lambda c: (c.rank == ACE, c.suit))
|
||||||
|
|
||||||
|
|
||||||
|
# /***********************************************************************
|
||||||
|
# // The Little Corporal
|
||||||
|
# // Bonaparte
|
||||||
|
# ************************************************************************/
|
||||||
|
|
||||||
|
class TheLittleCorporal_RowStack(UD_SS_RowStack):
|
||||||
|
def acceptsCards(self, from_stack, cards):
|
||||||
|
if not UD_SS_RowStack.acceptsCards(self, from_stack, cards):
|
||||||
|
return False
|
||||||
|
if from_stack in self.game.s.reserves:
|
||||||
|
return not self.cards
|
||||||
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
class TheLittleCorporal(DerFreieNapoleon):
|
||||||
|
|
||||||
|
def createGame(self, rows=10):
|
||||||
|
l, s = Layout(self), self.s
|
||||||
|
# set size so that at least 2/3 of a card is visible with 15 cards
|
||||||
|
h = l.CH*2/3 + (15-1)*l.YOFFSET
|
||||||
|
h = l.YS + max(h, 3*l.YS)
|
||||||
|
self.setSize(l.XM+rows*l.XS, l.YM + h)
|
||||||
|
|
||||||
|
x, y = l.XM+(rows-8)*l.XS, l.YM
|
||||||
|
for i in range(4):
|
||||||
|
s.foundations.append(Braid_Foundation(x, y, self, suit=i))
|
||||||
|
x += l.XS
|
||||||
|
tx, ty, ta, tf = l.getTextAttr(s.foundations[-1], "se")
|
||||||
|
font = self.app.getFont("canvas_default")
|
||||||
|
self.texts.info = MfxCanvasText(self.canvas, tx, ty, anchor=ta, font=font)
|
||||||
|
x += 2*l.XS
|
||||||
|
stack = ReserveStack(x, y, self, max_cards=UNLIMITED_CARDS)
|
||||||
|
s.reserves.append(stack)
|
||||||
|
l.createText(stack, 'se')
|
||||||
|
x, y = l.XM, l.YM+l.YS
|
||||||
|
for i in range(rows):
|
||||||
|
s.rows.append(TheLittleCorporal_RowStack(x, y, self, mod=13))
|
||||||
|
x += l.XS
|
||||||
|
|
||||||
|
# talon
|
||||||
|
x, y = l.XM, self.height - l.YS
|
||||||
|
s.talon = InitialDealTalonStack(x, y, self)
|
||||||
|
|
||||||
|
# define stack-groups
|
||||||
|
l.defaultStackGroups()
|
||||||
|
|
||||||
|
def startGame(self):
|
||||||
|
for i in range(4):
|
||||||
|
self.s.talon.dealRow(rows=self.s.rows, frames=0)
|
||||||
|
self.startDealSample()
|
||||||
|
self.s.talon.dealRow(rows=self.s.rows[1:-1])
|
||||||
|
self.s.talon.dealBaseCards(ncards=4)
|
||||||
|
|
||||||
|
def getQuickPlayScore(self, ncards, from_stack, to_stack):
|
||||||
|
if to_stack in self.s.reserves:
|
||||||
|
return 0
|
||||||
|
return int(len(to_stack.cards) != 0)+1
|
||||||
|
|
||||||
|
|
||||||
|
class Bonaparte(TheLittleCorporal):
|
||||||
|
|
||||||
|
def createGame(self):
|
||||||
|
TheLittleCorporal.createGame(self, rows=8)
|
||||||
|
|
||||||
|
def startGame(self):
|
||||||
|
for i in range(5):
|
||||||
|
self.s.talon.dealRow(rows=self.s.rows, frames=0)
|
||||||
|
self.startDealSample()
|
||||||
|
self.s.talon.dealRow()
|
||||||
|
self.s.talon.dealBaseCards(ncards=4)
|
||||||
|
|
||||||
|
|
||||||
# register the game
|
# register the game
|
||||||
|
@ -270,4 +363,10 @@ registerGame(GameInfo(169, Napoleon, "Napoleon",
|
||||||
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
registerGame(GameInfo(170, FreeNapoleon, "Free Napoleon",
|
registerGame(GameInfo(170, FreeNapoleon, "Free Napoleon",
|
||||||
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
registerGame(GameInfo(536, Master, "Master",
|
||||||
|
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
registerGame(GameInfo(537, TheLittleCorporal, "The Little Corporal",
|
||||||
|
GI.GT_NAPOLEON | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
registerGame(GameInfo(538, Bonaparte, "Bonaparte",
|
||||||
|
GI.GT_NAPOLEON | GI.GT_OPEN | GI.GT_ORIGINAL, 1, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
|
||||||
|
|
|
@ -178,7 +178,7 @@ class Spider2Suits(Spider):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
class OpenSpider(Spider):
|
class OpenSpider(Spider):
|
||||||
def startGame(self, flip=0):
|
def startGame(self):
|
||||||
Spider.startGame(self, flip=1)
|
Spider.startGame(self, flip=1)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -121,6 +121,7 @@ class Terrace_RowStack(AC_RowStack):
|
||||||
# ************************************************************************/
|
# ************************************************************************/
|
||||||
|
|
||||||
class Terrace(Game):
|
class Terrace(Game):
|
||||||
|
Talon_Class = Terrace_Talon
|
||||||
Foundation_Class = Terrace_AC_Foundation
|
Foundation_Class = Terrace_AC_Foundation
|
||||||
RowStack_Class = Terrace_RowStack
|
RowStack_Class = Terrace_RowStack
|
||||||
ReserveStack_Class = OpenStack
|
ReserveStack_Class = OpenStack
|
||||||
|
@ -149,7 +150,7 @@ class Terrace(Game):
|
||||||
|
|
||||||
# create stacks
|
# create stacks
|
||||||
x, y = l.XM + w1, l.YM
|
x, y = l.XM + w1, l.YM
|
||||||
s.talon = Terrace_Talon(x, y, self, max_rounds=max_rounds, num_deal=num_deal)
|
s.talon = self.Talon_Class(x, y, self, max_rounds=max_rounds, num_deal=num_deal)
|
||||||
l.createText(s.talon, "sw")
|
l.createText(s.talon, "sw")
|
||||||
x = x + l.XS
|
x = x + l.XS
|
||||||
s.waste = WasteStack(x, y, self)
|
s.waste = WasteStack(x, y, self)
|
||||||
|
@ -288,6 +289,46 @@ class Madame(Terrace):
|
||||||
Terrace.startGame(self, nrows=10)
|
Terrace.startGame(self, nrows=10)
|
||||||
|
|
||||||
|
|
||||||
|
# /***********************************************************************
|
||||||
|
# // Mamy Susan
|
||||||
|
# ************************************************************************/
|
||||||
|
|
||||||
|
class MamySusan_RowStack(AC_RowStack):
|
||||||
|
def acceptsCards(self, from_stack, cards):
|
||||||
|
if from_stack in self.game.s.reserves:
|
||||||
|
return False
|
||||||
|
return AC_RowStack.acceptsCards(self, from_stack, cards)
|
||||||
|
|
||||||
|
|
||||||
|
class MamySusan(Terrace):
|
||||||
|
|
||||||
|
Talon_Class = WasteTalonStack
|
||||||
|
Foundation_Class = StackWrapper(SS_FoundationStack, max_move=0)
|
||||||
|
RowStack_Class = StackWrapper(MamySusan_RowStack, max_move=1)
|
||||||
|
|
||||||
|
def createGame(self):
|
||||||
|
Terrace.createGame(self, rows=10)
|
||||||
|
|
||||||
|
def startGame(self, nrows=4):
|
||||||
|
for i in range(6):
|
||||||
|
self.s.talon.dealRow(rows=self.s.reserves, flip=0, frames=0)
|
||||||
|
self.flipMove(self.s.reserves[0])
|
||||||
|
for i in range(3):
|
||||||
|
self.s.talon.dealRow(frames=0)
|
||||||
|
self.startDealSample()
|
||||||
|
self.s.talon.dealRow()
|
||||||
|
self.s.talon.dealCards()
|
||||||
|
|
||||||
|
def fillStack(self, stack):
|
||||||
|
pass
|
||||||
|
def _restoreGameHook(self, game):
|
||||||
|
pass
|
||||||
|
def _loadGameHook(self, p):
|
||||||
|
pass
|
||||||
|
def _saveGameHook(self, p):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# register the game
|
# register the game
|
||||||
registerGame(GameInfo(135, Terrace, "Terrace",
|
registerGame(GameInfo(135, Terrace, "Terrace",
|
||||||
|
@ -304,4 +345,6 @@ registerGame(GameInfo(499, Signora, "Signora",
|
||||||
GI.GT_TERRACE, 2, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_TERRACE, 2, 0, GI.SL_MOSTLY_SKILL))
|
||||||
registerGame(GameInfo(500, Madame, "Madame",
|
registerGame(GameInfo(500, Madame, "Madame",
|
||||||
GI.GT_TERRACE, 3, 0, GI.SL_MOSTLY_SKILL))
|
GI.GT_TERRACE, 3, 0, GI.SL_MOSTLY_SKILL))
|
||||||
|
registerGame(GameInfo(533, MamySusan, "Mamy Susan",
|
||||||
|
GI.GT_TERRACE, 2, 0, GI.SL_BALANCED))
|
||||||
|
|
||||||
|
|
|
@ -183,7 +183,7 @@ class ResourceManager:
|
||||||
self._addDir(result, os.path.join(dir, s))
|
self._addDir(result, os.path.join(dir, s))
|
||||||
except EnvError, ex:
|
except EnvError, ex:
|
||||||
pass
|
pass
|
||||||
if app.debug >= 2:
|
if app.debug >= 5:
|
||||||
print "getSearchDirs", env, search, "->", result
|
print "getSearchDirs", env, search, "->", result
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
@ -210,7 +210,7 @@ class ResourceManager:
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
#
|
#
|
||||||
if app.debug >= 2:
|
if app.debug >= 5:
|
||||||
print "getRegistryDirs", category, "->", result
|
print "getRegistryDirs", category, "->", result
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
|
@ -1194,10 +1194,14 @@ class Stack:
|
||||||
return s
|
return s
|
||||||
|
|
||||||
def getNumCards(self):
|
def getNumCards(self):
|
||||||
|
if self.game.app.debug >= 3:
|
||||||
|
t = repr(self)+' '
|
||||||
|
else:
|
||||||
|
t = ''
|
||||||
n = len(self.cards)
|
n = len(self.cards)
|
||||||
if n == 0 : return _('No cards')
|
if n == 0 : return t+_('No cards')
|
||||||
elif n == 1 : return _('1 card')
|
elif n == 1 : return t+_('1 card')
|
||||||
else : return str(n)+_(' cards')
|
else : return t+str(n)+_(' cards')
|
||||||
|
|
||||||
|
|
||||||
# /***********************************************************************
|
# /***********************************************************************
|
||||||
|
|
Loading…
Add table
Reference in a new issue