diff --git a/html-src/rules/microbe.html b/html-src/rules/microbe.html new file mode 100644 index 00000000..0c7c222d --- /dev/null +++ b/html-src/rules/microbe.html @@ -0,0 +1,27 @@ +

Microbe

+

+Spider type. 2 decks. No redeal. + +

Object

+

+Group all the cards in sets of 13 cards in descending sequence +by alternate color from King to Ace and move such sets to the foundations. + +

Rules

+

+The decks are separated. From one deck, four cards are dealt to each of +eleven tableau piles, with alternating cards face-up and face-down (the +bottom and third from the bottom cards are face-down). The remaining +eight cards from that deck are combined with the other deck to form the +talon. +

+Tableau piles are built down by alternate color, and any card or valid +sequence of cards can be moved between tableau piles. Any valid card or +sequence can fill empty piles. +

+The object is to group the cards in sets of 13 cards, from King to Ace +in an alternating color sequence. Such groups can be moved to the foundations. +

+When there are no moves left, you can deal one card from the talon to +each tableau pile. The game is won if all cards are grouped into sequences +and moved to the foundations. diff --git a/pysollib/gamedb.py b/pysollib/gamedb.py index 1eb75a89..ece07692 100644 --- a/pysollib/gamedb.py +++ b/pysollib/gamedb.py @@ -595,6 +595,7 @@ class GI: tuple(range(19000, 19012)) + tuple(range(22303, 22311)) + tuple(range(22353, 22361))), ('fc-3.1', tuple(range(961, 971))), + ('dev', tuple(range(971, 972))), ) # deprecated - the correct way is to or a GI.GT_XXX flag diff --git a/pysollib/games/spider.py b/pysollib/games/spider.py index cb4769c4..fdcc7564 100644 --- a/pysollib/games/spider.py +++ b/pysollib/games/spider.py @@ -1158,6 +1158,7 @@ class Tarantula(Spider): # ************************************************************************ # * Fechter's Game +# * Microbe # ************************************************************************ class FechtersGame_Talon(TalonStack): @@ -1180,14 +1181,7 @@ class FechtersGame_Talon(TalonStack): class FechtersGame_RowStack(AC_RowStack): - def canDropCards(self, stacks): - if len(self.cards) < 13: - return (None, 0) - cards = self.cards[-13:] - for s in stacks: - if s is not self and s.acceptsCards(self, cards): - return (s, 13) - return (None, 0) + canDropCards = BasicRowStack.spiderCanDropCards class FechtersGame(RelaxedSpider): @@ -1208,6 +1202,17 @@ class FechtersGame(RelaxedSpider): shallHighlightMatch = Game._shallHighlightMatch_AC +class Microbe(FechtersGame): + Talon_Class = DealRowTalonStack + RowStack_Class = StackWrapper(FechtersGame_RowStack, base_rank=ANY_RANK) + + def createGame(self): + RelaxedSpider.createGame(self, rows=11) + + def shuffle(self): + self.shuffleSeparateDecks() + + # ************************************************************************ # * Bebop # ************************************************************************ @@ -1663,3 +1668,5 @@ registerGame(GameInfo(870, FairMaids, "Fair Maids", GI.GT_SPIDER, 1, 0, GI.SL_BALANCED)) registerGame(GameInfo(917, Astrocyte, "Astrocyte", GI.GT_SPIDER, 2, 0, GI.SL_MOSTLY_SKILL)) +registerGame(GameInfo(971, Microbe, "Microbe", + GI.GT_SPIDER | GI.GT_SEPARATE_DECKS, 2, 0, GI.SL_MOSTLY_SKILL))