Skip to main content

Python bindings for the dos-like programming library

Project description

python-dos-like is a set of Python bindings for the dos-like programming library by Mattias Gustavsson.

Tests status Documentation Status

Documentation: https://python-dos-like.readthedocs.io/en/latest/

Source Code: https://github.com/cknave/python-dos-like

Usage

pip install python-dos-like

python-dos-like can be used in the same way as dos-like by calling dos_like.start on your main function:

from random import randrange

import dos_like
from dos_like.dos import *


def main():
    setvideomode(videomode_320x200)

    while not shuttingdown():
        waitvbl()
        for _ in range(50):
            setcolor(randrange(256))
            line(randrange(320), randrange(200), randrange(320), randrange(200))
            setcolor(randrange(256))
            fillcircle(randrange(320), randrange(200), randrange(30))
            setcolor(randrange(256))
            circle(randrange(320), randrange(200), randrange(30))

dos_like.start(main)

You can also use python-dos-like in the Python REPL by calling dos_like.run_in_background:

>>> import dos_like
>>> from dos_like.dos import *
>>> dos_like.run_in_background(['-w'])
>>> cputs('hello world!')

Building

Building python-dos-like requires C development tools to be installed.

On Linux and macOS, the SDL2 and GLEW libraries are required.

If building from a git repository, you must update submodules to get the dos-like source.

git submodule update --init --recursive
$ python -mvenv .venv
$ . .venv/bin/activate
(.venv) $ pip install -e '.[dev]'
(.venv) $ coverage run -m unittest && coverage report

Several environment variables may be set to control compile-time options:

Environment variable

Default

Description

ALWAYS_UPDATE

1

Update the screen in the background. Set this to 0 to restore dos-like’s default behavior of pausing updates when the window loses focus.

CFLAGS

Extra compiler flags. Of note, -DNULL_PLATFORM is useful to build a library for headless build servers.

Limitations

Memory management

Memory allocated by dos-like will be freed when its corresponding bython buffer object is garbage collected. The current draw target and music will be retained even if no other python code has a reference, but any playing sounds will not be. Deleting or releasing the last reference to a playing sound may cause issues.

Platforms

This library has been tested on Linux, Windows, and macOS.

macOS does not support GUI operations in a background thread, so it cannot be used from the Python REPL by calling run_in_background().

python-dos-like can be compiled as a WebAssembly Pyodide module, but will fail to import due to a missing symbol from WAjic. Even if this symbol (J, an object containing JS functions to be called from C) is added to the imports when loaded by Pyodide, it does not appear to be compatible.

It is not clear to me what the best way forward is for WebAssembly support: getting a Pyodide module to import WAjic functions, building a Pyodide module in WAjic, or removing Pyodide or WAjic from the project entirely.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python-dos-like-0.0.4.tar.gz (1.8 MB view details)

Uploaded Source

Built Distributions

python_dos_like-0.0.4-cp310-cp310-win_amd64.whl (1.3 MB view details)

Uploaded CPython 3.10 Windows x86-64

python_dos_like-0.0.4-cp310-cp310-manylinux_2_28_x86_64.whl (2.4 MB view details)

Uploaded CPython 3.10 manylinux: glibc 2.28+ x86-64

python_dos_like-0.0.4-cp310-cp310-macosx_10_15_x86_64.whl (1.3 MB view details)

Uploaded CPython 3.10 macOS 10.15+ x86-64

python_dos_like-0.0.4-cp39-cp39-win_amd64.whl (1.3 MB view details)

Uploaded CPython 3.9 Windows x86-64

python_dos_like-0.0.4-cp39-cp39-manylinux_2_28_x86_64.whl (2.4 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.28+ x86-64

python_dos_like-0.0.4-cp39-cp39-macosx_10_15_x86_64.whl (1.3 MB view details)

Uploaded CPython 3.9 macOS 10.15+ x86-64

File details

Details for the file python-dos-like-0.0.4.tar.gz.

File metadata

  • Download URL: python-dos-like-0.0.4.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for python-dos-like-0.0.4.tar.gz
Algorithm Hash digest
SHA256 1e45cbd6af2065305801b51322d14a9a5b0dd9b66999eda3fbcf5f6cc4af70ff
MD5 aefdd9e169a7a509809cb171d1ab78c9
BLAKE2b-256 9cc46ada218dcfe1529c79312af18f1028ef1ad2144be9f80f60e425c4b3404e

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 dc115fb894803f6b3d81f2520bd11e1eb7e850a432d50d88c6c3030f75a4e428
MD5 b3c07f175f3c57f4b4d86e143364aefb
BLAKE2b-256 c98d98934d741088ffaf64f7ffb29b00f26e72a373ce325b9342ab7925a5b89c

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp310-cp310-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp310-cp310-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 0b31cd105516547f7f3f5f47a7bb2a8ca64c47370ec6f6d9941ed1a57d792e3a
MD5 a69b8c53105d51ce50c0add28a136716
BLAKE2b-256 0c3b885212d048b9de50910e24c098906d8e1ff20339ce992aadee51d6c4b9b7

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp310-cp310-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp310-cp310-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 8c8c772d147c21140fc225cb39b9d38013998c69224d91b75adcd5abdcb26199
MD5 09efd75cdf3fb1eb0de5aab3fcabb280
BLAKE2b-256 fe328cd4bfd0a7492ed39670330f4474b83ba3f3f04d3e200ccf44513bcf798d

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp39-cp39-win_amd64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 5f93ba9b7e16f88484846ed9a814e2de1b943732d0a0fb165bfae46002834fdb
MD5 f5344dd1242def1689f889893747089e
BLAKE2b-256 2c054bbb7d084c51c57300024f52e35c40f8646333d2aeb76ab6e98cc213ab47

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp39-cp39-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp39-cp39-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 cc5c2e23b8990da7747da89a8883099c9acb9333402b012faddb35dabcd0d4a3
MD5 2f7811ba3957f6e2483d77174a33803f
BLAKE2b-256 b0a460cf427dc6c24e28e9146a92de4c8fb42df38561cf9cc448e4fd2045a1e3

See more details on using hashes here.

File details

Details for the file python_dos_like-0.0.4-cp39-cp39-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for python_dos_like-0.0.4-cp39-cp39-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 f2e0edf213edc39ab92be7877e16f067dc6d6d088b36b9e4e2c674ff01649766
MD5 709083ca138c9527aaf5647c516b279c
BLAKE2b-256 2cb2e1a1acf7ea8e126175e4310028b7e8b665812938c96e6b950b019ad50952

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page