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

Matching type cardset support for allowing Memory games to use any cardset.

This commit is contained in:
Joe R 2023-01-28 10:44:57 -05:00
parent b4d75cb46c
commit 03de3e84a6
21 changed files with 215 additions and 50 deletions

View file

@ -41,6 +41,7 @@ Cardsets Types:
* Navagraha Ganjiga = 7 * Navagraha Ganjiga = 7
* Dashavatara Ganjifa = 8 * Dashavatara Ganjifa = 8
* Trumps Only = 9 * Trumps Only = 9
* Matching = 10
*$C:* The number of cards in the cardset, generally 42, 48, 52, 68, 78, 96 or 120 *$C:* The number of cards in the cardset, generally 42, 48, 52, 68, 78, 96 or 120
@ -65,6 +66,7 @@ Cardsets Styles:
* Hex A Deck = 29 * Hex A Deck = 29
* Holiday = 13 * Holiday = 13
* Mahjongg = 28 * Mahjongg = 28
* Matching = 32
* Movies = 14 * Movies = 14
* Matrix = 31 * Matrix = 31
* Music = 15 * Music = 15

Binary file not shown.

After

Width:  |  Height:  |  Size: 129 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 129 B

View file

@ -44,6 +44,9 @@ back01.ext;back02.ext;back03.ext</pre>
<li> <li>
<p>Trumps Only = 9</p> <p>Trumps Only = 9</p>
</li> </li>
<li>
<p>Matching = 10</p>
</li>
</ul> </ul>
<p><b>$C:</b> The number of cards in the cardset, generally 42, <p><b>$C:</b> The number of cards in the cardset, generally 42,
48, 52, 68, 78, 96 or 120</p> 48, 52, 68, 78, 96 or 120</p>
@ -99,6 +102,9 @@ back01.ext;back02.ext;back03.ext</pre>
<li> <li>
<p>Mahjongg = 28</p> <p>Mahjongg = 28</p>
</li> </li>
<li>
<p>Matching = 32</p>
</li>
<li> <li>
<p>Movies = 14</p> <p>Movies = 14</p>
</li> </li>

View file

@ -0,0 +1,30 @@
<h1>Memory 16</h1>
<p>
Memory game type. 16 cards. No redeal.
<h3>Object</h3>
<p>
Flip all pairs of matching cards and get a score of 40 points or more.
<h3>Rules</h3>
<p>
At game start 8 pairs of cards are dealt to the tableau piles.
<p>
Flip any 2 cards that match in suit and rank (or just rank or picture,
depending on the cardset used).
<p>
Any pair that matches will gain you 5 points, while a pair that
doesn't match will cost you 1 point.
<p>
You win if your final score reaches 30 points.
<h3>Notes</h3>
<p>
To get awarded for a perfect game you must reach the maximum score of
40 points. You can reach this by restarting the game.
<p>
<i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i>
are disabled for this game.
<p>
Memory can be played with any type of cardset, including special
Matching cardsets.

View file

@ -10,7 +10,8 @@ Flip all pairs of matching cards and get a score of 40 points or more.
<p> <p>
At game start 12 pairs of cards are dealt to the tableau piles. At game start 12 pairs of cards are dealt to the tableau piles.
<p> <p>
Flip any 2 cards that match in suit and rank. Flip any 2 cards that match in suit and rank (or just rank or picture,
depending on the cardset used).
<p> <p>
Any pair that matches will gain you 5 points, while a pair that Any pair that matches will gain you 5 points, while a pair that
doesn't match will cost you 1 point. doesn't match will cost you 1 point.
@ -24,3 +25,6 @@ To get awarded for a perfect game you must reach the maximum score of
<p> <p>
<i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i> <i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i>
are disabled for this game. are disabled for this game.
<p>
Memory can be played with any type of cardset, including special
Matching cardsets.

View file

@ -10,7 +10,8 @@ Flip all pairs of matching cards and get a score of 45 points or more.
<p> <p>
At game start 15 pairs of cards are dealt to the tableau piles. At game start 15 pairs of cards are dealt to the tableau piles.
<p> <p>
Flip any 2 cards that match in suit and rank. Flip any 2 cards that match in suit and rank (or just rank or picture,
depending on the cardset used).
<p> <p>
Any pair that matches will gain you 5 points, while a pair that Any pair that matches will gain you 5 points, while a pair that
doesn't match will cost you 1 point. doesn't match will cost you 1 point.
@ -24,3 +25,6 @@ To get awarded for a perfect game you must reach the maximum score of
<p> <p>
<i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i> <i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i>
are disabled for this game. are disabled for this game.
<p>
Memory can be played with any type of cardset, including special
Matching cardsets.

View file

@ -10,7 +10,8 @@ Flip all pairs of matching cards and get a score of 50 points or more.
<p> <p>
At game start 20 pairs of cards are dealt to the tableau piles. At game start 20 pairs of cards are dealt to the tableau piles.
<p> <p>
Flip any 2 cards that match in suit and rank. Flip any 2 cards that match in suit and rank (or just rank or picture,
depending on the cardset used).
<p> <p>
Any pair that matches will gain you 5 points, while a pair that Any pair that matches will gain you 5 points, while a pair that
doesn't match will cost you 1 point. doesn't match will cost you 1 point.
@ -24,3 +25,6 @@ To get awarded for a perfect game you must reach the maximum score of
<p> <p>
<i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i> <i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i>
are disabled for this game. are disabled for this game.
<p>
Memory can be played with any type of cardset, including special
Matching cardsets.

View file

@ -0,0 +1,30 @@
<h1>Memory 52</h1>
<p>
Memory game type. 52 cards. No redeal.
<h3>Object</h3>
<p>
Flip all pairs of matching cards and get a score of 40 points or more.
<h3>Rules</h3>
<p>
At game start 26 pairs of cards are dealt to the tableau piles.
<p>
Flip any 2 cards that match in suit and rank (or just rank or picture,
depending on the cardset used).
<p>
Any pair that matches will gain you 5 points, while a pair that
doesn't match will cost you 1 point.
<p>
You win if your final score reaches 50 points.
<h3>Notes</h3>
<p>
To get awarded for a perfect game you must reach the maximum score of
130 points. You can reach this by restarting the game.
<p>
<i>Undo</i>, <i>Bookmarks</i>, <i>Autodrop</i> and <i>Quickplay</i>
are disabled for this game.
<p>
Memory can be played with any type of cardset, including special
Matching cardsets.

View file

@ -868,6 +868,9 @@ msgstr "Dashavatara Ganjifa (120 Karten)"
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "Trumpf nur Typ (variable Karten)" msgstr "Trumpf nur Typ (variable Karten)"
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "Französisch" msgstr "Französisch"
@ -904,6 +907,9 @@ msgstr "Dashavatara Ganjifa"
msgid "Trumps only" msgid "Trumps only"
msgstr "Nur Trumpf" msgstr "Nur Trumpf"
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "Erwachsene" msgstr "Erwachsene"

View file

@ -898,6 +898,9 @@ msgstr "Type Dashavatara Ganjifa (120 cartes)"
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "Type Atouts seulement (cartes variables)" msgstr "Type Atouts seulement (cartes variables)"
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "Français" msgstr "Français"
@ -934,6 +937,9 @@ msgstr "Dashavatara Ganjifa"
msgid "Trumps only" msgid "Trumps only"
msgstr "Atouts seulement" msgstr "Atouts seulement"
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "Adulte" msgstr "Adulte"

View file

@ -906,6 +906,9 @@ msgstr "Tipo Dashavatara Ganjifa (120 carte)"
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "Tipo Trionfi (carte variabili)" msgstr "Tipo Trionfi (carte variabili)"
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "Francesi" msgstr "Francesi"
@ -942,6 +945,9 @@ msgstr "Dashavatara Ganjifa"
msgid "Trumps only" msgid "Trumps only"
msgstr "Solo Trionfi" msgstr "Solo Trionfi"
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "Adulti" msgstr "Adulti"

View file

@ -899,6 +899,9 @@ msgstr "Typ Dashavatara Ganjifa (120 kart)"
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "Typ tylko Atu (różne karty)" msgstr "Typ tylko Atu (różne karty)"
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "Francuski" msgstr "Francuski"
@ -935,6 +938,9 @@ msgstr "Dashavatara Ganjifa"
msgid "Trumps only" msgid "Trumps only"
msgstr "Tylko Atu" msgstr "Tylko Atu"
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "Dla dorosłych" msgstr "Dla dorosłych"

View file

@ -812,6 +812,9 @@ msgstr ""
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "" msgstr ""
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "" msgstr ""
@ -848,6 +851,9 @@ msgstr ""
msgid "Trumps only" msgid "Trumps only"
msgstr "" msgstr ""
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "" msgstr ""

View file

@ -893,6 +893,9 @@ msgstr "Дашаватара Ганджифа (120 карт)"
msgid "Trumps only type (variable cards)" msgid "Trumps only type (variable cards)"
msgstr "Без мастей (переменное количество карт)" msgstr "Без мастей (переменное количество карт)"
msgid "Matching type (variable cards)"
msgstr ""
#: pysollib/resource.py:194 #: pysollib/resource.py:194
msgid "French" msgid "French"
msgstr "Классические" msgstr "Классические"
@ -929,6 +932,9 @@ msgstr "Дашаватара Ганджифа"
msgid "Trumps only" msgid "Trumps only"
msgstr "Без мастей" msgstr "Без мастей"
msgid "Matching"
msgstr ""
#: pysollib/resource.py:219 #: pysollib/resource.py:219
msgid "Adult" msgid "Adult"
msgstr "Для взрослых" msgstr "Для взрослых"

View file

@ -794,6 +794,10 @@ class Application:
t1 = t0 t1 = t0
elif len(cs.trumps) < gi.ncards: # not enough cards elif len(cs.trumps) < gi.ncards: # not enough cards
t1 = t0 t1 = t0
elif gc == GI.GC_MATCHING:
t0 = "Matching"
if cs.ncards < (gi.ncards / 2): # not enough cards
t1 = t0
else: else:
# we should not come here # we should not come here
t0 = t1 = "Unknown" t0 = t1 = "Unknown"

View file

@ -3456,9 +3456,7 @@ class Game(object):
# for find_card_dialog # for find_card_dialog
def canFindCard(self): def canFindCard(self):
# All games currently support find card, though return self.gameinfo.category != GI.GC_MATCHING
# this may change later.
return True
# #
# subclass hooks # subclass hooks

View file

@ -48,6 +48,9 @@ class GI:
GC_NAVAGRAHA_GANJIFA = CSI.TYPE_NAVAGRAHA_GANJIFA GC_NAVAGRAHA_GANJIFA = CSI.TYPE_NAVAGRAHA_GANJIFA
GC_DASHAVATARA_GANJIFA = CSI.TYPE_DASHAVATARA_GANJIFA GC_DASHAVATARA_GANJIFA = CSI.TYPE_DASHAVATARA_GANJIFA
GC_TRUMP_ONLY = CSI.TYPE_TRUMP_ONLY GC_TRUMP_ONLY = CSI.TYPE_TRUMP_ONLY
GC_MATCHING = CSI.TYPE_MATCHING
NUM_CATEGORIES = CSI.TYPE_MATCHING
# game type # game type
GT_1DECK_TYPE = 0 GT_1DECK_TYPE = 0
@ -549,13 +552,13 @@ class GI:
tuple(range(22217, 22219))), tuple(range(22217, 22219))),
('fc-2.14', tuple(range(811, 827))), ('fc-2.14', tuple(range(811, 827))),
('fc-2.15', tuple(range(827, 855)) + tuple(range(22400, 22407))), ('fc-2.15', tuple(range(827, 855)) + tuple(range(22400, 22407))),
('dev', tuple(range(855, 886))) ('dev', tuple(range(855, 888)))
) )
# deprecated - the correct way is to or a GI.GT_XXX flag # deprecated - the correct way is to or a GI.GT_XXX flag
# in the registerGame() call # in the registerGame() call
_CHILDREN_GAMES = [16, 33, 55, 90, 91, 96, 97, 176, 328, 329, 862, 865, _CHILDREN_GAMES = [16, 33, 55, 90, 91, 96, 97, 176, 328, 329, 862, 865,
903, ] 886, 903, ]
_OPEN_GAMES = [] _OPEN_GAMES = []
@ -631,7 +634,7 @@ class GameInfo(Struct):
if pysollib.settings.TRANSLATE_GAME_NAMES: if pysollib.settings.TRANSLATE_GAME_NAMES:
altnames = [_(n) for n in altnames] altnames = [_(n) for n in altnames]
# #
if not (1 <= category <= 9): if not (1 <= category <= GI.NUM_CATEGORIES):
if game_type == GI.GT_HANAFUDA: if game_type == GI.GT_HANAFUDA:
category = GI.GC_HANAFUDA category = GI.GC_HANAFUDA
elif game_type == GI.GT_TAROCK: elif game_type == GI.GT_TAROCK:

View file

@ -143,7 +143,6 @@ class Memory24(Game):
def startGame(self): def startGame(self):
n = self.COLUMNS * self.ROWS n = self.COLUMNS * self.ROWS
assert len(self.s.talon.cards) == n
self.other_stack = None self.other_stack = None
self.closed_cards = n self.closed_cards = n
self.score = 0 self.score = 0
@ -152,7 +151,6 @@ class Memory24(Game):
self.s.talon.dealRow(rows=self.s.rows[:n], flip=0, frames=0) self.s.talon.dealRow(rows=self.s.rows[:n], flip=0, frames=0)
self.startDealSample() self.startDealSample()
self.s.talon.dealRow(rows=self.s.rows[n:], flip=0) self.s.talon.dealRow(rows=self.s.rows[n:], flip=0)
assert len(self.s.talon.cards) == 0
def isGameWon(self): def isGameWon(self):
return self.closed_cards == 0 and self.score >= self.WIN_SCORE return self.closed_cards == 0 and self.score >= self.WIN_SCORE
@ -221,6 +219,13 @@ class Memory24(Game):
p.dump(self.score) p.dump(self.score)
class Memory16(Memory24):
COLUMNS = 4
ROWS = 4
WIN_SCORE = 30
PERFECT_SCORE = 40 # 5 * (4*4)/2
class Memory30(Memory24): class Memory30(Memory24):
COLUMNS = 6 COLUMNS = 6
ROWS = 5 ROWS = 5
@ -235,6 +240,13 @@ class Memory40(Memory24):
PERFECT_SCORE = 100 # 5 * (8*5)/2 PERFECT_SCORE = 100 # 5 * (8*5)/2
class Memory52(Memory24):
COLUMNS = 13
ROWS = 4
WIN_SCORE = 50
PERFECT_SCORE = 130 # 5 * (13*4)/2
# ************************************************************************ # ************************************************************************
# * Concentration # * Concentration
# ************************************************************************ # ************************************************************************
@ -379,15 +391,26 @@ class MemorySequence(Memory24):
# register the game # register the game
registerGame(GameInfo(886, Memory16, "Memory 16",
GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL,
category=GI.GC_MATCHING,
suits=(), ranks=(), trumps=list(range(8))))
registerGame(GameInfo(176, Memory24, "Memory 24", registerGame(GameInfo(176, Memory24, "Memory 24",
GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL, GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL,
suits=(0, 2), ranks=(0, 8, 9, 10, 11, 12))) category=GI.GC_MATCHING,
suits=(), ranks=(), trumps=list(range(12))))
registerGame(GameInfo(219, Memory30, "Memory 30", registerGame(GameInfo(219, Memory30, "Memory 30",
GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL, GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL,
suits=(0, 2, 3), ranks=(0, 9, 10, 11, 12))) category=GI.GC_MATCHING,
suits=(), ranks=(), trumps=list(range(15))))
registerGame(GameInfo(177, Memory40, "Memory 40", registerGame(GameInfo(177, Memory40, "Memory 40",
GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL, GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL,
suits=(0, 2), ranks=(0, 4, 5, 6, 7, 8, 9, 10, 11, 12))) category=GI.GC_MATCHING,
suits=(), ranks=(), trumps=list(range(20))))
registerGame(GameInfo(887, Memory52, "Memory 52",
GI.GT_MEMORY | GI.GT_SCORE, 2, 0, GI.SL_SKILL,
category=GI.GC_MATCHING,
suits=(), ranks=(), trumps=list(range(26))))
registerGame(GameInfo(178, Concentration, "Concentration", registerGame(GameInfo(178, Concentration, "Concentration",
GI.GT_MEMORY | GI.GT_SCORE, 1, 0, GI.SL_SKILL, GI.GT_MEMORY | GI.GT_SCORE, 1, 0, GI.SL_SKILL,
altnames=("Pelmanism"))) altnames=("Pelmanism")))

View file

@ -197,6 +197,7 @@ highlight_piles = float(0.2, 9.9)
7 = string_list(min=2, max=2) 7 = string_list(min=2, max=2)
8 = string_list(min=2, max=2) 8 = string_list(min=2, max=2)
9 = string_list(min=2, max=2) 9 = string_list(min=2, max=2)
10 = string_list(min=2, max=2)
scale_cards = boolean scale_cards = boolean
scale_x = float scale_x = float
scale_y = float scale_y = float
@ -547,6 +548,7 @@ class Options:
CSI.TYPE_NAVAGRAHA_GANJIFA: ("Dashavatara Ganjifa XL", ""), CSI.TYPE_NAVAGRAHA_GANJIFA: ("Dashavatara Ganjifa XL", ""),
CSI.TYPE_DASHAVATARA_GANJIFA: ("Dashavatara Ganjifa XL", ""), CSI.TYPE_DASHAVATARA_GANJIFA: ("Dashavatara Ganjifa XL", ""),
CSI.TYPE_TRUMP_ONLY: ("Next Matrix", ""), CSI.TYPE_TRUMP_ONLY: ("Next Matrix", ""),
CSI.TYPE_MATCHING: ("Neo", "")
} }
else: else:
self.cardset = { self.cardset = {
@ -562,6 +564,7 @@ class Options:
CSI.TYPE_NAVAGRAHA_GANJIFA: ("Dashavatara Ganjifa", ""), CSI.TYPE_NAVAGRAHA_GANJIFA: ("Dashavatara Ganjifa", ""),
CSI.TYPE_DASHAVATARA_GANJIFA: ("Dashavatara Ganjifa", ""), CSI.TYPE_DASHAVATARA_GANJIFA: ("Dashavatara Ganjifa", ""),
CSI.TYPE_TRUMP_ONLY: ("Matrix", ""), CSI.TYPE_TRUMP_ONLY: ("Matrix", ""),
CSI.TYPE_MATCHING: (c, ""),
} }
# not changeable options # not changeable options

View file

@ -180,6 +180,7 @@ class CSI:
TYPE_NAVAGRAHA_GANJIFA = 7 TYPE_NAVAGRAHA_GANJIFA = 7
TYPE_DASHAVATARA_GANJIFA = 8 TYPE_DASHAVATARA_GANJIFA = 8
TYPE_TRUMP_ONLY = 9 TYPE_TRUMP_ONLY = 9
TYPE_MATCHING = 10
TYPE = { TYPE = {
1: _("French type (52 cards)"), 1: _("French type (52 cards)"),
@ -191,6 +192,7 @@ class CSI:
7: _("Navagraha Ganjifa type (108 cards)"), 7: _("Navagraha Ganjifa type (108 cards)"),
8: _("Dashavatara Ganjifa type (120 cards)"), 8: _("Dashavatara Ganjifa type (120 cards)"),
9: _("Trumps only type (variable cards)"), 9: _("Trumps only type (variable cards)"),
10: _("Matching type (variable cards)"),
} }
TYPE_NAME = { TYPE_NAME = {
@ -203,54 +205,59 @@ class CSI:
7: _("Navagraha Ganjifa"), 7: _("Navagraha Ganjifa"),
8: _("Dashavatara Ganjifa"), 8: _("Dashavatara Ganjifa"),
9: _("Trumps only"), 9: _("Trumps only"),
10: _("Matching"),
} }
TYPE_ID = { TYPE_ID = {
1: "french", 1: "french",
2: "hanafuda", 2: "hanafuda",
3: "tarock", 3: "tarock",
4: "mahjongg", 4: "mahjongg",
5: "hex-a-deck", 5: "hex-a-deck",
6: "mughal-ganjifa", 6: "mughal-ganjifa",
7: "navagraha-ganjifa", 7: "navagraha-ganjifa",
8: "dashavatara-ganjifa", 8: "dashavatara-ganjifa",
9: "trumps-only", 9: "trumps-only",
10: "matching"
} }
TYPE_SUITS = { TYPE_SUITS = {
1: "cshd", 1: "cshd",
2: "abcdefghijkl", 2: "abcdefghijkl",
3: "cshd", 3: "cshd",
4: "abc", 4: "abc",
5: "cshd", 5: "cshd",
6: "abcdefgh", 6: "abcdefgh",
7: "abcdefghi", 7: "abcdefghi",
8: "abcdefghij", 8: "abcdefghij",
9: "", 9: "",
10: ""
} }
TYPE_RANKS = { TYPE_RANKS = {
1: list(range(13)), 1: list(range(13)),
2: list(range(4)), 2: list(range(4)),
3: list(range(14)), 3: list(range(14)),
4: list(range(10)), 4: list(range(10)),
5: list(range(16)), 5: list(range(16)),
6: list(range(12)), 6: list(range(12)),
7: list(range(12)), 7: list(range(12)),
8: list(range(12)), 8: list(range(12)),
9: list(range(0)), 9: list(range(0)),
10: list(range(0)),
} }
TYPE_TRUMPS = { TYPE_TRUMPS = {
1: (), 1: (),
2: (), 2: (),
3: list(range(22)), 3: list(range(22)),
4: list(range(12)), 4: list(range(12)),
5: list(range(4)), 5: list(range(4)),
6: (), 6: (),
7: (), 7: (),
8: (), 8: (),
9: (), 9: (),
10: (),
} }
# cardset styles # cardset styles
@ -271,6 +278,7 @@ class CSI:
29: _("Hex A Deck"), # 29: _("Hex A Deck"), #
13: _("Holiday"), # 13: _("Holiday"), #
28: _("Mahjongg"), # 28: _("Mahjongg"), #
32: _("Matching"), #
14: _("Movies"), # 14: _("Movies"), #
31: _("Matrix"), # 31: _("Matrix"), #
15: _("Music"), # 15: _("Music"), #
@ -476,6 +484,16 @@ class CardsetManager(ResourceManager):
cs.nletters = 0 cs.nletters = 0
cs.nshadows = 0 cs.nshadows = 0
cs.trumps = list(range(cs.ncards)) cs.trumps = list(range(cs.ncards))
elif s == CSI.TYPE_MATCHING:
# ???return 0 ## FIXME
# cs.nbottoms = 7
# cs.ranks = ()
# cs.suits = ""
# cs.trumps = range(cs.ncards)
cs.nbottoms = 1
cs.nletters = 0
cs.nshadows = 0
cs.trumps = list(range(cs.ncards))
else: else:
return 0 return 0