From b55c0a9015cd7cab36ce7238dbc7dbbade757c52 Mon Sep 17 00:00:00 2001 From: Joe R Date: Tue, 18 Jan 2022 17:30:29 -0500 Subject: [PATCH] Some game organization, particularly with Colorado family games. --- html-src/rules/belvedere.html | 23 ++++++++++ html-src/rules/casket.html | 5 ++- html-src/rules/colorado.html | 24 ++++++++++ html-src/rules/doubledot.html | 22 ++++++++++ html-src/rules/grandfather.html | 24 ++++++++++ html-src/rules/grandmammaspatience.html | 21 +++++++++ html-src/rules/tvetesgrandfather.html | 30 +++++++++++++ html-src/rules/twenty.html | 14 ++++++ pysollib/gamedb.py | 3 +- pysollib/games/auldlangsyne.py | 58 ++++++++++++++++++++----- pysollib/games/calculation.py | 2 +- pysollib/games/grandfathersclock.py | 2 +- pysollib/games/hitormiss.py | 2 +- pysollib/games/klondike.py | 2 +- pysollib/games/knockout.py | 1 + pysollib/games/montecarlo.py | 4 +- pysollib/games/picturegallery.py | 3 +- pysollib/games/royalcotillion.py | 2 +- pysollib/games/windmill.py | 3 +- pysollib/games/yukon.py | 2 +- 20 files changed, 223 insertions(+), 24 deletions(-) create mode 100644 html-src/rules/belvedere.html create mode 100644 html-src/rules/colorado.html create mode 100644 html-src/rules/doubledot.html create mode 100644 html-src/rules/grandfather.html create mode 100644 html-src/rules/grandmammaspatience.html create mode 100644 html-src/rules/tvetesgrandfather.html create mode 100644 html-src/rules/twenty.html diff --git a/html-src/rules/belvedere.html b/html-src/rules/belvedere.html new file mode 100644 index 00000000..4eec327a --- /dev/null +++ b/html-src/rules/belvedere.html @@ -0,0 +1,23 @@ +

Belvedere

+

+Fan game type. 1 deck. No redeal. + +

Object

+

+Move all cards to the foundations. + +

Rules

+

+Three cards are dealt to each of eight tableau piles, +and a single ace is dealt to a foundation. +

+Tableau piles are built down by rank, regardless of suit. +Single cards can be moved between tableau piles. Empty +tableau piles cannot be filled. Foundations are built up +by rank regardless of suit. +

+When there are no moves left, cards from the talon can be +dealt to each of three waste piles, which can then be moved +to the tableau or foundations. No redeal is allowed. +

+The game is won if all cards are moved to the foundations. diff --git a/html-src/rules/casket.html b/html-src/rules/casket.html index 6a5b6700..463b2824 100644 --- a/html-src/rules/casket.html +++ b/html-src/rules/casket.html @@ -10,13 +10,14 @@ Move all the cards to the foundations.

The main tableau is set up in the shape of a casket, with the body of the casket containing 8 cards, with a 5 card lid on top. A face-down -reserve of 13 cards is placed inside the casket. +reserve of 13 cards is placed inside the casket. This reserve is called +the jewels.

The cards in the body of the casket are built down by same suit, whereas the cards in the lid of the casket can't be built. A card from the lid of the casket can only be moved to a non-empty pile in the body of the casket or a foundation. Empty piles in the lid of the casket are -immediately filled with the top card from the reserve, while piles in +immediately filled with the top card from the jewels, while piles in the body can be filled freely.

Deal cards from the stock one at a time. Each card dealt from the stock diff --git a/html-src/rules/colorado.html b/html-src/rules/colorado.html new file mode 100644 index 00000000..dd71c741 --- /dev/null +++ b/html-src/rules/colorado.html @@ -0,0 +1,24 @@ +

Colorado

+

+Numerica type. 2 decks. No redeal. + +

Object

+

+Move all cards to the foundations. + +

Rules

+

+Twenty cards are dealt to twenty piles. An ace and a +king of each suit is dealt to the foundation piles. +

+Cards from the tableau can be moved to foundations. The +foundations that start from aces are built up by suit, +while the foundations that start from kings are built +down by suit. +

+Cards are dealt from the stock one at a time and are +immediately moved to the tableau or foundation piles. +Cards cannot be moved between tableau piles, and empty +piles are filled from the stock immediately. +

+The game is won if all cards are moved to the foundations. diff --git a/html-src/rules/doubledot.html b/html-src/rules/doubledot.html new file mode 100644 index 00000000..dd117117 --- /dev/null +++ b/html-src/rules/doubledot.html @@ -0,0 +1,22 @@ +

Double Dot

+

+One-Deck game type. 1 deck. No redeal. + +

Object

+

+Move all cards to the foundations. + +

Rules

+

+Eight cards are dealt to eight tableau piles, and the black aces +and red deuces are dealt to the foundations. Tableau piles are +built down by rank, regardless of suit, building by every other +rank, wrapping from two to king or ace to queen as necessary. +Any card can fill an empty pile. +

+Foundations are built up by same suit, by every other rank, +wrapping in the same manner as necessary. +

+When there are no moves left, one card can be dealt to each tableau +pile from the stock. The game is won if all cards are moved to +the foundations. diff --git a/html-src/rules/grandfather.html b/html-src/rules/grandfather.html new file mode 100644 index 00000000..a3a18dc7 --- /dev/null +++ b/html-src/rules/grandfather.html @@ -0,0 +1,24 @@ +

Grandfather

+

+Numerica type. 2 decks. 1 redeal. + +

Object

+

+Move all cards to the foundations. + +

Rules

+

+Twenty cards are dealt to twenty piles. +

+Cards from the tableau can be moved to foundations. The +four foundations on the left are built up by suit from ace +to king, while the four on the right are built down by suit +from king to ace. +

+Cards are dealt from the stock one at a time and can be moved +to the tableau or foundation piles. Though each tableau pile +can only have a max of two cards. Cards cannot be moved +between tableau piles, and empty piles are filled from the +stock immediately. A single redeal is allowed. +

+The game is won if all cards are moved to the foundations. diff --git a/html-src/rules/grandmammaspatience.html b/html-src/rules/grandmammaspatience.html new file mode 100644 index 00000000..a69a78de --- /dev/null +++ b/html-src/rules/grandmammaspatience.html @@ -0,0 +1,21 @@ +

Grandmamma's Patience

+

+Numerica game type. 2 decks. No redeal. + +

Object

+

+Move all the cards to the foundations. + +

Quick Description

+

+Like Grandfather, +but there are twenty-two tableau piled, all cards +dealt from the stock must be played to tableau +or foundation piles immediately, and there are +four reserve piles. +

+Additionally, at the start of the game, one card +is dealt to a foundation. One set of foundations is +built down by suit from that rank while the other is +built up by suit from the rank one higher. Foundation +piles wrap from ace to king as necessary. diff --git a/html-src/rules/tvetesgrandfather.html b/html-src/rules/tvetesgrandfather.html new file mode 100644 index 00000000..5de4f829 --- /dev/null +++ b/html-src/rules/tvetesgrandfather.html @@ -0,0 +1,30 @@ +

Tvete's Grandfather

+

+Yukon type. 1 deck. No redeal. + +

Object

+

+Move all cards to the foundations. + +

Rules

+

+The cards are dealt to seven tableau piles, with one card in +the first, and the remaining piles containing 3, 5, 7, 4, 6, and +2 cards respectively, and the remaining cards dealt over top. +

+Tableau piles can be moved regardless of sequence, and are built +down by same suit. Foundations are built up by same suit, starting +from ace. +

+When there are no moves left, the remaining tableau cards can be +shuffled, and redealt in the same manner as described above. +This can be done twice. +

+The game is won if all cards are moved to the foundations. + +

Notes

+

+This game was taught to KPatience developer Paul Olav Tvete by +his grandfather. In KPatience, it goes by the name Grandfather, +but it is often known as Tvete's Grandfather to differentiate it +from another game more commonly known as Grandfather. diff --git a/html-src/rules/twenty.html b/html-src/rules/twenty.html new file mode 100644 index 00000000..20498520 --- /dev/null +++ b/html-src/rules/twenty.html @@ -0,0 +1,14 @@ +

Twenty

+

+Numerica game type. 2 decks. No redeal. + +

Object

+

+Move all cards to the foundations. + +

Quick Description

+

+Like Colorado, +but instead of dealing cards from the stock one +at a time, cards are dealt from the stock to all +tableau piles at once. diff --git a/pysollib/gamedb.py b/pysollib/gamedb.py index 475b2df3..2d2b64c4 100644 --- a/pysollib/gamedb.py +++ b/pysollib/gamedb.py @@ -528,7 +528,7 @@ class GI: ('fc-2.12', tuple(range(774, 811)) + (16681,) + tuple(range(22217, 22219))), ('fc-2.14', tuple(range(811, 827))), - ('fc-2.16', tuple(range(827, 853)) + tuple(range(22400, 22407))) + ('fc-2.16', tuple(range(827, 854)) + tuple(range(22400, 22407))) ) # deprecated - the correct way is to or a GI.GT_XXX flag @@ -558,6 +558,7 @@ class GI: 5034, # Mahjongg Flying Dragon 5401, # Mahjongg Taipei 12345, # Oonsoo + 22231, # Three Peaks ] diff --git a/pysollib/games/auldlangsyne.py b/pysollib/games/auldlangsyne.py index 3e125abf..36c4229a 100644 --- a/pysollib/games/auldlangsyne.py +++ b/pysollib/games/auldlangsyne.py @@ -386,12 +386,17 @@ class Colorado(Game): # game layout # - def createGame(self): + def createGame(self, waste_max=1, max_rounds=1, tableau_max=999999): # create layout l, s = Layout(self), self.s + roff = 0 # set window - self.setSize(l.XM+10*l.XS, l.YM+4*l.YS+l.TEXT_HEIGHT) + if tableau_max < 10: + roff = l.YOFFSET * (tableau_max - 1) + + self.setSize(l.XM + 10 * l.XS, + l.YM + 4 * l.YS + l.TEXT_HEIGHT + (2 * roff)) # create stacks x, y, = l.XS, l.YM @@ -399,28 +404,31 @@ class Colorado(Game): s.foundations.append(self.Foundation_Class(x, y, self, suit=i, max_move=0)) x += l.XS - x += 2*l.XM + x += 2 * l.XM for i in range(4): s.foundations.append(self.Foundation_Class(x, y, self, suit=i, max_move=0, base_rank=KING, dir=-1)) x += l.XS - y = l.YM+l.YS + y = l.YM + l.YS for i in range(2): x = l.XM for j in range(10): stack = self.RowStack_Class(x, y, self, - max_move=1, max_accept=1) - s.rows.append(stack) - stack.CARD_XOFFSET = stack.CARD_YOFFSET = 0 - x += l.XS - y += l.YS + max_move=1, max_accept=1, + max_cards=tableau_max) - x, y = l.XM + 9*l.XS, self.height - l.YS - s.talon = WasteTalonStack(x, y, self, max_rounds=1) + s.rows.append(stack) + x += l.XS + y += l.YS + roff + + x, y = l.XM + 9 * l.XS, self.height - l.YS + s.talon = WasteTalonStack(x, y, self, max_rounds=max_rounds) l.createText(s.talon, "n") x -= l.XS - s.waste = WasteStack(x, y, self, max_cards=1) + s.waste = WasteStack(x, y, self, max_cards=waste_max) + if max_rounds > 1: + l.createRoundText(s.waste, "s") # define stack-groups l.defaultStackGroups() @@ -441,6 +449,30 @@ class Colorado(Game): self.s.waste.moveMove(1, stack) +class Grandfather_RowStack(BasicRowStack): + def acceptsCards(self, from_stack, cards): + if not BasicRowStack.acceptsCards(self, from_stack, cards): + return False + # this stack accepts any one card from the Waste + return from_stack is self.game.s.waste and len(cards) == 1 + + +class Grandfather(Colorado): + RowStack_Class = Grandfather_RowStack + + def createGame(self): + Colorado.createGame(self, waste_max=999999, max_rounds=2, + tableau_max=2) + + def startGame(self): + self.startDealSample() + self.s.talon.dealRow() + self.s.talon.dealCards() + + def _shuffleHook(self, cards): + return cards + + # ************************************************************************ # * Amazons # ************************************************************************ @@ -631,3 +663,5 @@ registerGame(GameInfo(636, StrategyPlus, "Strategy +", GI.GT_NUMERICA, 1, 0, GI.SL_SKILL)) registerGame(GameInfo(688, Formic, "Formic", GI.GT_NUMERICA, 1, 0, GI.SL_MOSTLY_SKILL)) +registerGame(GameInfo(853, Grandfather, "Grandfather", + GI.GT_NUMERICA, 2, 1, GI.SL_BALANCED)) diff --git a/pysollib/games/calculation.py b/pysollib/games/calculation.py index d88018d2..88168833 100644 --- a/pysollib/games/calculation.py +++ b/pysollib/games/calculation.py @@ -470,7 +470,7 @@ class SPatience(Game): # register the game registerGame(GameInfo(256, Calculation, "Calculation", GI.GT_1DECK_TYPE, 1, 0, GI.SL_MOSTLY_SKILL, - altnames=("Progression",))) + altnames=("Progression", "Broken Intervals"))) registerGame(GameInfo(94, Hopscotch, "Hopscotch", GI.GT_1DECK_TYPE, 1, 0, GI.SL_MOSTLY_SKILL)) registerGame(GameInfo(134, BetsyRoss, "Betsy Ross", diff --git a/pysollib/games/grandfathersclock.py b/pysollib/games/grandfathersclock.py index ec4c6dc1..d8cd3bd4 100644 --- a/pysollib/games/grandfathersclock.py +++ b/pysollib/games/grandfathersclock.py @@ -711,6 +711,6 @@ registerGame(GameInfo(697, BigBen, "Big Ben", GI.GT_2DECK_TYPE, 2, 0, GI.SL_BALANCED)) registerGame(GameInfo(737, Clock, "Clock", GI.GT_1DECK_TYPE, 1, 0, GI.SL_LUCK, - altnames=("Travellers",))) + altnames=("Travellers", "Sundial"))) registerGame(GameInfo(827, GermanClock, "German Clock", GI.GT_1DECK_TYPE, 1, 1, GI.SL_MOSTLY_LUCK)) diff --git a/pysollib/games/hitormiss.py b/pysollib/games/hitormiss.py index d9215637..78749853 100644 --- a/pysollib/games/hitormiss.py +++ b/pysollib/games/hitormiss.py @@ -158,4 +158,4 @@ class HitOrMiss(Game): # register the game registerGame(GameInfo(774, HitOrMiss, "Hit or Miss", GI.GT_1DECK_TYPE, 1, VARIABLE_REDEALS, - GI.SL_LUCK)) + GI.SL_LUCK, altnames=("Roll Call",))) diff --git a/pysollib/games/klondike.py b/pysollib/games/klondike.py index a35db276..d46b734d 100644 --- a/pysollib/games/klondike.py +++ b/pysollib/games/klondike.py @@ -1541,7 +1541,7 @@ registerGame(GameInfo(390, Arizona, "Arizona", registerGame(GameInfo(407, AuntMary, "Aunt Mary", GI.GT_KLONDIKE, 1, 0, GI.SL_BALANCED)) registerGame(GameInfo(420, DoubleDot, "Double Dot", - GI.GT_KLONDIKE, 1, 0, GI.SL_BALANCED)) + GI.GT_1DECK_TYPE, 1, 0, GI.SL_BALANCED)) registerGame(GameInfo(434, SevenDevils, "Seven Devils", GI.GT_RAGLAN, 2, 0, GI.SL_MOSTLY_LUCK)) registerGame(GameInfo(452, DoubleEasthaven, "Double Easthaven", diff --git a/pysollib/games/knockout.py b/pysollib/games/knockout.py index 25927572..a599925f 100644 --- a/pysollib/games/knockout.py +++ b/pysollib/games/knockout.py @@ -62,6 +62,7 @@ class Knockout_Talon(DealRowTalonStack): return False def redealCards(self): + self.game.startDealSample() for r in self.game.s.rows: if r.cards: while r.cards: diff --git a/pysollib/games/montecarlo.py b/pysollib/games/montecarlo.py index 8aff25f2..d95d3539 100644 --- a/pysollib/games/montecarlo.py +++ b/pysollib/games/montecarlo.py @@ -976,7 +976,9 @@ registerGame(GameInfo(92, Neighbour, "Neighbour", GI.GT_PAIRING_TYPE, 1, 0, GI.SL_MOSTLY_LUCK)) registerGame(GameInfo(96, Fourteen, "Fourteen", GI.GT_PAIRING_TYPE | GI.GT_OPEN, 1, 0, - GI.SL_MOSTLY_LUCK, altnames=("Fourteen Out",))) + GI.SL_MOSTLY_LUCK, altnames=("Fourteen Out", + "Fourteen Puzzle", + "Take Fourteen"))) registerGame(GameInfo(235, Nestor, "Nestor", GI.GT_PAIRING_TYPE | GI.GT_OPEN, 1, 0, GI.SL_MOSTLY_LUCK)) diff --git a/pysollib/games/picturegallery.py b/pysollib/games/picturegallery.py index e6fce828..9a52e138 100644 --- a/pysollib/games/picturegallery.py +++ b/pysollib/games/picturegallery.py @@ -598,7 +598,8 @@ registerGame(GameInfo(398, MountOlympus, "Mount Olympus", registerGame(GameInfo(399, Zeus, "Zeus", GI.GT_2DECK_TYPE, 2, 0, GI.SL_BALANCED)) registerGame(GameInfo(546, RoyalParade, "Royal Parade", - GI.GT_2DECK_TYPE, 2, 0, GI.SL_MOSTLY_SKILL)) + GI.GT_2DECK_TYPE, 2, 0, GI.SL_MOSTLY_SKILL, + altnames=("Hussars", "Financier"))) registerGame(GameInfo(547, VirginiaReel, "Virginia Reel", GI.GT_2DECK_TYPE, 2, 0, GI.SL_MOSTLY_SKILL)) registerGame(GameInfo(782, GreaterWheel, "Greater Wheel", diff --git a/pysollib/games/royalcotillion.py b/pysollib/games/royalcotillion.py index f633c059..b026b171 100644 --- a/pysollib/games/royalcotillion.py +++ b/pysollib/games/royalcotillion.py @@ -1377,7 +1377,7 @@ registerGame(GameInfo(392, NewBritishConstitution, "New British Constitution", ranks=list(range(11)) # without Queens and Kings )) registerGame(GameInfo(443, Twenty, "Twenty", - GI.GT_2DECK_TYPE, 2, 0, GI.SL_BALANCED)) + GI.GT_NUMERICA, 2, 0, GI.SL_BALANCED)) registerGame(GameInfo(465, Granada, "Granada", GI.GT_2DECK_TYPE, 2, 2, GI.SL_BALANCED)) registerGame(GameInfo(579, ThreePirates, "Three Pirates", diff --git a/pysollib/games/windmill.py b/pysollib/games/windmill.py index b3e82cc4..2bb66e73 100644 --- a/pysollib/games/windmill.py +++ b/pysollib/games/windmill.py @@ -428,7 +428,8 @@ class Simplicity(Game): # register the game registerGame(GameInfo(30, Windmill, "Windmill", - GI.GT_2DECK_TYPE, 2, 0, GI.SL_MOSTLY_LUCK)) + GI.GT_2DECK_TYPE, 2, 0, GI.SL_MOSTLY_LUCK, + altnames=('Propeller',))) registerGame(GameInfo(277, NapoleonsTomb, "Napoleon's Tomb", GI.GT_1DECK_TYPE, 1, 0, GI.SL_MOSTLY_LUCK)) registerGame(GameInfo(417, Corners, "Corners", diff --git a/pysollib/games/yukon.py b/pysollib/games/yukon.py index abbed3cf..0d043c49 100644 --- a/pysollib/games/yukon.py +++ b/pysollib/games/yukon.py @@ -753,7 +753,7 @@ registerGame(GameInfo(20, RussianSolitaire, "Russian Solitaire", GI.GT_YUKON, 1, 0, GI.SL_BALANCED)) registerGame(GameInfo(27, Odessa, "Odessa", GI.GT_YUKON, 1, 0, GI.SL_BALANCED)) -registerGame(GameInfo(278, Grandfather, "Grandfather", +registerGame(GameInfo(278, Grandfather, "Tvete's Grandfather", GI.GT_YUKON, 1, 2, GI.SL_BALANCED)) registerGame(GameInfo(186, Alaska, "Alaska", GI.GT_YUKON, 1, 0, GI.SL_BALANCED))