Source code for ppb

"""
A python game framework.

PursuedPyBear is object oriented and event driven. Practically, this means that
most of your code will be organized into classes. Game objects in
:mod:`ppb` are :class:`Sprite` instances, which get contained in
:class:`Scenes <Scene>`. In turn, the :class:`GameEngine`
contains the scenes and :class:`Systems <System>`.
:mod:`Events <events>` are defined as simple classes and event handlers
are based on their names.

The classes, modules, and methods exported directly are the most used parts of
the library and intended to be used by users at all levels (barring
make_engine). Advanced features tend to be in their own modules and subpackages.

Exports:

* :class:`~ppb_vector.Vector`
* :class:`Scene`
* :class:`Circle`
* :class:`Image`
* :class:`Sprite`
* :class:`Square`
* :class:`Sound`
* :class:`Triangle`
* :mod:`events`
* :class:`Font`
* :class:`Text`
* :mod:`directions`
"""

import logging
import warnings
from sys import version_info
from typing import Callable

from ppb import directions
from ppb import events
from ppb_vector import Vector
from ppb.assets import Circle
from ppb.assets import Ellipse
from ppb.assets import Rectangle
from ppb.assets import Square
from ppb.assets import Triangle
from ppb.engine import GameEngine
from ppb.engine import Signal
from ppb.scenes import Scene
from ppb.sprites import RectangleSprite
from ppb.sprites import Sprite
from ppb.systems import Image
from ppb.systems import Sound
from ppb.systems import Font
from ppb.systems import Text
from ppb.utils import get_time

__all__ = (
    # Shortcuts
    'Vector', 'Scene', 'Circle', 'Image', 'Sprite', 'RectangleSprite',
    'Square', 'Sound', 'Triangle', 'events', 'Font', 'Text', 'directions',
    'Rectangle', 'Ellipse', 'Signal',
    # Local stuff
    'run', 'make_engine',
)


def _make_kwargs(setup, title, engine_opts):
    kwargs = {
        "resolution": (800, 600),
        "scene_kwargs": {
            "set_up": setup,
        },
        "window_title": title,
        **engine_opts
    }
    return kwargs


def _validate_python_support(required_version='3.7', ppb_release='2.0',
                             release_date='June 2022'):
    """
    Verifies Supported Python Version.

    This function verifies ppb is running on a supported Python version.

    :param required_version: Minimum Python Version Supported by PPB
    :type required_version: str
    :param ppb_release: PPB release version deprecation will occur
    :type ppb_release: str
    :param release_date: Estimated release month for PPB Version
    :type release_date: str
    """
    # Creates (Major, Minor) version tuples for comparisson
    if version_info[0:2] <= tuple(map(int, required_version.split('.'))):
        deprecation_message = f"PPB v{ppb_release} will no longer support "\
                              f"Python {version_info[0]}.{version_info[1]} " \
                              f"once released around {release_date}. Please " \
                              f"update to Python {required_version} or newer."
        warnings.filterwarnings('default')
        warnings.warn(deprecation_message, DeprecationWarning)


[docs] def run(setup: Callable[[Scene], None] = None, *, log_level=logging.WARNING, starting_scene=Scene, title="PursuedPyBear", **engine_opts): """ Run a game. This is the default entry point for ppb games. Sample usage: :: import ppb def setup(scene): scene.add(ppb.Sprite()) ppb.run(setup) Alternatively: :: import ppb class Game(ppb.Scene): def __init__(self, **kwargs): super().__init__(**kwargs) self.add(ppb.Sprite()) ppb.run(starting_scene=Game) See the :doc:`../getting-started` guide for a more complete guide to building games. All parameters are optional. :param setup: Called with the first scene to allow initialization of your game. :type setup: Callable[[Scene], None] :param log_level: The logging level from :func:`logging` to send to the console. :param starting_scene: A scene class to use. Defaults to :class:`~ppb.scenes.Scene` :type starting_scene: type :param title: The title of the rendered window. :type title: str :param engine_opts: Additional keyword arguments passed to the :class:`~ppb.engine.GameEngine`. """ logging.basicConfig(level=log_level) _validate_python_support() with make_engine(setup, starting_scene=starting_scene, title=title, **engine_opts) as eng: eng.run()
[docs] def make_engine(setup: Callable[[Scene], None] = None, *, starting_scene=Scene, title="PursedPyBear", **engine_opts): """ Setup a :class:`GameEngine`. This function exists for third party modules to use the same code paths as :func:`run` for setting up their engine. If you want to instantiate your own engine, you can do so directly using the :class:`constructor <GameEngine>`. :param setup: Called with the first scene to allow initialization of your game. :type setup: Callable[[Scene], None] :param starting_scene: A scene class to use. Defaults to :class:`~ppb.scenes.Scene` :type starting_scene: type :param title: The title of the rendered window. :type title: str :param engine_opts: Additional keyword arguments passed to the :class:`~ppb.engine.GameEngine` :return: A GameEngine instance. """ return GameEngine(starting_scene, **_make_kwargs(setup, title, engine_opts))