1
0
Fork 0
mirror of https://github.com/shlomif/PySolFC.git synced 2025-04-05 00:02:29 -04:00
PySolFC/pysollib/wizardutil.py
skomoroh a7e7aab703 * improved solitaire wizard
* removed round changes from turnStackMove


git-svn-id: file:///home/shlomif/Backup/svn-dumps/PySolFC/svnsync-repos/pysolfc/PySolFC/trunk@160 efabe8c0-fbe8-4139-b769-b5e6d273206e
2007-05-06 21:42:40 +00:00

412 lines
12 KiB
Python

##---------------------------------------------------------------------------##
##
## PySol -- a Python Solitaire game
##
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by
## the Free Software Foundation; either version 2 of the License, or
## (at your option) any later version.
##
## This program is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
## GNU General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with this program; see the file COPYING.
## If not, write to the Free Software Foundation, Inc.,
## 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
##
##---------------------------------------------------------------------------##
import sys, os
from gamedb import GI, loadGame
from util import *
from stack import *
#from game import Game
from layout import Layout
#from hint import AbstractHint, DefaultHint, CautiousDefaultHint
#from pysoltk import MfxCanvasText
gettext = _
n_ = lambda x: x
# /***********************************************************************
# //
# ************************************************************************/
class WizSetting:
def __init__(self, values_map, default, var_name,
label, widget='menu'):
self.values_map = values_map
self.default = gettext(default)
##self.values_dict = dict(self.values_map)
self.translation_map = {}
##self.values = [i[0] for i in self.values_map]
if widget == 'menu':
self.values = []
for k, v in self.values_map:
t = gettext(k)
self.values.append(t)
self.translation_map[t] = k
assert self.default in self.values
else:
self.values = self.values_map
self.var_name = var_name
self.label = label
self.widget = widget
self.variable = None # Tk variable
self.current_value = None
GameName = WizSetting(
values_map = (),
default = 'My Game',
widget = 'entry',
label = _('Name:'),
var_name = 'name',
)
SkillLevel = WizSetting(
values_map = ((n_('Luck only'), GI.SL_LUCK),
(n_('Mostly luck'), GI.SL_MOSTLY_LUCK),
(n_('Balanced'), GI.SL_BALANCED),
(n_('Mostly skill'), GI.SL_MOSTLY_SKILL),
(n_('Skill only'), GI.SL_SKILL),
),
default = n_('Balanced'),
label = _('Skill level:'),
var_name = 'skill_level',
)
NumDecks = WizSetting(
values_map = ((n_('One'), 1),
(n_('Two'), 2),
(n_('Three'), 3),
(n_('Four'), 4)),
default = n_('One'),
label = _('Number of decks:'),
var_name = 'decks',
)
LayoutType = WizSetting(
values_map = ((n_('FreeCell'), Layout.freeCellLayout),
(n_('Klondike'), Layout.klondikeLayout),
(n_('Gypsy'), Layout.gypsyLayout),
(n_('Harp'), Layout.harpLayout),
),
default = n_('FreeCell'),
label = _('Layout:'),
var_name = 'layout',
)
TalonType = WizSetting(
values_map = ((n_('Initial dealing'), InitialDealTalonStack),
(n_('Deal to waste'), WasteTalonStack),
(n_('Deal to rows'), DealRowRedealTalonStack),
),
default = n_('Initial dealing'),
label = _('Type:'),
var_name = 'talon',
)
Redeals = WizSetting(
values_map = ((n_('No redeals'), 0),
(n_('One redeal'), 1),
(n_('Two redeals'), 2),
(n_('Three redeals'), 3),
(n_('Unlimited redeals'), -1),
),
default = n_('No redeals'),
label = _('Number of redeals:'),
var_name = 'redeals',
)
DealToWaste = WizSetting(
values_map = (1, 5),
default = 1,
widget = 'spin',
label = _('Deal to waste:'),
var_name = 'deal_to_waste',
)
TalonShuffle = WizSetting(
values_map = (0, 1),
default = 0,
label = _('Shuffle:'),
var_name = 'talon_shuffle',
widget = 'check',
)
FoundType = WizSetting(
values_map = ((n_('Same suit'), SS_FoundationStack),
(n_('Alternate color'), AC_FoundationStack),
(n_('Same color'), SC_FoundationStack),
(n_('Rank'), RK_FoundationStack),
(n_('Spider same suit'), Spider_SS_Foundation),
(n_('Spider alternate color'), Spider_AC_Foundation),
),
default = n_('Same suit'),
label = _('Type:'),
var_name = 'found_type',
)
FoundBaseCard = WizSetting(
values_map = ((n_('Ace'), ACE),
(n_('King'), KING),
(n_('Any'), ANY_RANK),
),
default = n_('Ace'),
label = _('Base card:'),
var_name = 'found_base_card',
)
FoundDir = WizSetting(
values_map = ((n_('Up'), 1), (n_('Down'), -1)),
default = n_('Up'),
label = _('Direction:'),
var_name = 'found_dir',
)
FoundWrap = WizSetting(
values_map = (0, 1),
default = 0,
label = _('Wrapping:'),
var_name = 'found_wrap',
widget = 'check',
)
FoundMaxMove = WizSetting(
values_map = ((n_('No move'), 0,), (n_('One card'), 1)),
default = n_('One card'),
label = _('Max move cards:'),
var_name = 'found_max_move',
)
FoundEqual = WizSetting(
values_map = (0, 1),
default = 1,
label = _('Equal base cards:'),
var_name = 'found_equal',
widget = 'check',
)
RowsNum = WizSetting(
values_map = (1, 20),
default = 8,
widget = 'spin',
label = _('Number of rows:'),
var_name = 'rows_num',
)
RowsType = WizSetting(
values_map = ((n_('Same suit'), SS_RowStack),
(n_('Alternate color'), AC_RowStack),
(n_('Same color'), SC_RowStack),
(n_('Rank'), RK_RowStack),
(n_('Any suit but the same'), BO_RowStack),
(n_('Up or down by same suit'), UD_SS_RowStack),
(n_('Up or down by alternate color'), UD_AC_RowStack),
(n_('Up or down by rank'), UD_RK_RowStack),
(n_('Up or down by same color'), UD_SC_RowStack),
(n_('Spider same suit'), Spider_SS_RowStack),
(n_('Spider alternate color'), Spider_AC_RowStack),
(n_('Yukon same suit'), Yukon_SS_RowStack),
(n_('Yukon alternate color'), Yukon_AC_RowStack),
(n_('Yukon rank'), Yukon_RK_RowStack),
),
default = n_('Alternate color'),
label = _('Type:'),
var_name = 'rows_type',
)
RowsBaseCard = WizSetting(
values_map = ((n_('Ace'), ACE),
(n_('King'), KING),
(n_('Any'), ANY_RANK),
(n_('No'), NO_RANK),
),
default = n_('Any'),
label = _('Base card:'),
var_name = 'rows_base_card',
)
RowsDir = WizSetting(
values_map = ((n_('Up'), 1), (n_('Down'), -1)),
default = n_('Down'),
label = _('Direction:'),
var_name = 'rows_dir',
)
RowsWrap = WizSetting(
values_map = (True, False),
default = False,
label = _('Wrapping:'),
var_name = 'rows_wrap',
widget = 'check',
)
RowsMaxMove = WizSetting(
values_map = ((n_('One card'), 1), (n_('Unlimited'), UNLIMITED_MOVES)),
default = n_('Unlimited'),
label = _('Max move cards:'),
var_name = 'rows_max_move',
)
ReservesNum = WizSetting(
values_map = (0, 20),
default = 4,
widget = 'spin',
label = _('Number of reserves:'),
var_name = 'reserves_num',
)
ReservesMaxAccept = WizSetting(
values_map = (0, 20),
default = 1,
widget = 'spin',
label = _('Max accept:'),
var_name = 'reserves_max_accept',
)
DealType = WizSetting(
values_map = ((n_('Triangle'), 'triangle'),
(n_('Rectangle'), 'rectangle'),
),
default = n_('Rectangle'),
label = _('Type:'),
var_name = 'deal_type',
)
DealFaceDown = WizSetting(
values_map = (0, 20),
default = 0,
widget = 'spin',
label = _('# of face-down cards:'),
var_name = 'deal_face_down',
)
DealFaceUp = WizSetting(
values_map = (1, 20),
default = 8,
widget = 'spin',
label = _('# of face-up cards:'),
var_name = 'deal_face_up',
)
DealToReseves = WizSetting(
values_map = (0, 20),
default = 0,
widget = 'spin',
label = _('Deal to reserves:'),
var_name = 'deal_to_reserves',
)
DealMaxCards = WizSetting(
values_map = (0, 208),
default = 52,
widget = 'spin',
label = _('Max # of dealt cards:'),
var_name = 'deal_max_cards',
)
WizardWidgets = (
_('General'),
GameName,
SkillLevel,
NumDecks,
LayoutType,
_('Talon'),
TalonType,
Redeals,
DealToWaste,
TalonShuffle,
_('Foundations'),
FoundType,
FoundBaseCard,
FoundDir,
##FoundWrap,
FoundMaxMove,
FoundEqual,
_('Tableau'),
RowsNum,
RowsType,
RowsBaseCard,
RowsDir,
RowsMaxMove,
RowsWrap,
_('Reserves'),
ReservesNum,
ReservesMaxAccept,
_('Initial dealing'),
DealType,
DealFaceDown,
DealFaceUp,
DealToReseves,
DealMaxCards,
)
def write_game(app, game=None):
if game is None:
# new game
d = app.dn.plugins
ls = os.listdir(d)
n = 1
while True:
fn = os.path.join(d, 'customgame%d.py' % n) # file name
mn = 'customgame%d' % n # module name
gameid = 200000+n
if not os.path.exists(fn):
break
n += 1
check_game = True
else:
# edit current game
fn = game.MODULE_FILENAME
mn = game.__module__
gameid = game.SETTINGS['gameid']
check_game = False
##print '===>', fn
fd = open(fn, 'w')
fd.write('''\
## -*- coding: utf-8 -*-
## THIS FILE WAS GENERATED AUTOMATICALLY BY SOLITAIRE WIZARD
## DO NOT EDIT
from pysollib.customgame import CustomGame, registerCustomGame
class MyCustomGame(CustomGame):
WIZARD_VERSION = 1
SETTINGS = {
''')
for w in WizardWidgets:
if isinstance(w, basestring):
continue
v = w.variable.get()
if w.widget == 'menu':
v = w.translation_map[v]
if isinstance(v, int):
fd.write(" '%s': %i,\n" % (w.var_name, v))
else:
if w.var_name == 'name':
v = v.replace('\\', '\\\\')
v = v.replace("'", "\\'")
if isinstance(v, unicode):
v = v.encode('utf-8')
if not v:
v = 'Invalid Game Name'
fd.write(" '%s': '%s',\n" % (w.var_name, v))
fd.write(" 'gameid': %i,\n" % gameid)
fd.write('''\
}
registerCustomGame(MyCustomGame)
''')
fd.close()
loadGame(mn, fn, check_game=check_game)
return gameid
def reset_wizard(game):
for w in WizardWidgets:
if isinstance(w, basestring):
continue
if game is None:
# set to default
v = w.default
else:
# set from current game
if w.var_name in game.SETTINGS:
v = game.SETTINGS[w.var_name]
else:
v = w.default
if w.widget == 'menu':
v = gettext(v)
w.current_value = v