Source code for wmwpy
__version__ = "0.5.2-beta"
__author__ = 'ego-lay-atman-bay'
import typing
import logging
from . import utils
from . import classes
from . import Font
from .classes import widget
from .gametemplate import GAMES
from .utils import filesystem
from .game import Game
__all__ = ['load', 'Game', 'utils', 'classes', 'GAMES', 'filesystem']
[docs]def load(
gamepath : str,
platform : typing.Literal['android', 'ios'] = 'android',
game : str = 'WMW',
assets : str = None,
db : str = None,
profile : str = None,
baseassets : str = None,
load_callback : typing.Callable[[int, str, int], typing.Any] = None,
) -> Game:
"""load game
Args:
gamepath (str): Folder to extracted game.
platform (Literal['android', 'ios'], optional): What platform this game is for. Can be 'android' or 'ios'. Defaults to 'android'.
game (str, optional): Which game is being loaded. A full list of games is in `gametemplate.GAMES`. Defaults to 'WMW'.
assets (str, optional): Relative path to assets folder. Defaults to '/assets'.
db (str, optional): Relative path to database file from assets folder. Defaults to '/Data/water.db'.
profile (str, optional): Relative path to profile file in WMW2. Defaults to `None`.
baseassets (str, optional): Base assets path within the assets folder, e.g. '/perry/' in wmp. Defaults to '/'.
load_callback (Callable[[int, str, int], Any], optional): A callback function to be ran while loading the game. Defaults to `None`.
"""
game = game.upper()
platform = platform.lower()
platforms = {
'android': {
'assets': '/assets',
},
'ios': {
'assets': '/Content',
},
}
if assets == None:
assets = platforms[platform]['assets']
# try:
return GAMES.get(game, Game)(
gamepath = gamepath,
assets = assets,
db = db,
profile = profile,
load_callback = load_callback,
baseassets = baseassets,
)