Skip to main content

Python automation framework for driving asid-vice (a binmon-extended C64 emulator) — protocol client, key matrix + chord typing, screen scrape, container management, code-coverage harness.

Project description

vice-driver

CI License: Apache 2.0

vice-driver is a Python automation framework for driving asid-vice, an extension of the VICE C64 emulator that exposes a binary monitor with key-matrix tap and screen-scrape opcodes.

It is application-agnostic: use it to drive any C64 program inside a binmon-extended VICE container. (The companion defmon-driver package builds defMON-specific automation on top of this library.)

The driver itself is pure-Python with no runtime dependencies beyond the standard library. It speaks the asid-vice binary monitor protocol over a single TCP socket per connection.

Capabilities

  • vice_driver.binmon — wire-level binary-monitor client. Handles framing, request/response matching by id, asynchronous events (STOPPED / RESUMED / JAM), checkpoints (CHECK_EXEC / CHECK_LOAD / CHECK_STORE), cpuhistory, mem_get / mem_set, register get/set, keymatrix tap + set + get, SCREEN_GET.
  • vice_driver.keys — symbolic C64 key-matrix names (case-insensitive with aliases) + ASCII → chord conversion for typing text into programs that read the matrix directly.
  • vice_driver.screen — SCREEN_GET response parser + screencode → PETSCII → ASCII rendering with find_text().
  • vice_driver.vice_dockerViceContainer context manager that spins up a one-shot asid-vice Docker container with the right binmon binding, sound dump, SID configuration, and disk mounts.
  • vice_driver.coverage — per-action 6502 code-coverage harness built on CHECK_EXEC checkpoints + cpuhistory drains. Byte- or page-granularity.
  • vice_driver.expectExpect dataclass + verify() polling helper for "did this byte change to X within T seconds" assertions.

Requirements

  • Python ≥ 3.10
  • Docker, with a built asid-vice:latest image — see anarkiwi/asid-vice for the Dockerfile and build instructions.
  • A C64 .d64 (or PRG / TAP) image to autostart.

Installation

pip install vice-driver

For development:

git clone https://github.com/anarkiwi/vice-driver
cd vice-driver
pip install -e ".[dev]"
pytest

Quick start

import logging

from vice_driver import BinMon, DiskMount, ViceContainer

logging.basicConfig(level=logging.INFO)

container = ViceContainer(
    autostart="/work/program.d64",
    mounts=[DiskMount("/host/path/to/program.d64", "/work/program.d64", read_only=True)],
)

with container:
    bm = BinMon("127.0.0.1", 6502)
    bm.connect(timeout=10.0, attempts=80, retry_delay=0.25)
    # Drain the initial halt and resume the CPU.
    bm.exit()

    # ... drive the program: bm.keymatrix_tap, bm.mem_get/set, bm.screen_get ...

    bm.close()

Testing

pytest                      # runs unit tests + lint + format gates
pytest --cov-report=html    # open htmlcov/index.html for the line-level report

CI enforces:

  • ruff check (lint)
  • ruff format --check (format)
  • black --check (format, redundant with ruff format but explicit)
  • pytest (unit tests)
  • Coverage ≥ 85% over vice_driver/

Run individual gates locally:

ruff check vice_driver tests
ruff format --check vice_driver tests
black --check vice_driver tests
pytest --cov=vice_driver --cov-fail-under=85

License

Apache 2.0 — see LICENSE.

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

vice_driver-0.1.0.tar.gz (34.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vice_driver-0.1.0-py3-none-any.whl (33.4 kB view details)

Uploaded Python 3

File details

Details for the file vice_driver-0.1.0.tar.gz.

File metadata

  • Download URL: vice_driver-0.1.0.tar.gz
  • Upload date:
  • Size: 34.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vice_driver-0.1.0.tar.gz
Algorithm Hash digest
SHA256 56dc8523aa78d087f416d788257f24c13103c4028faccbf4ea77ce78e8f9cdda
MD5 0f807a86b6907ed703415807a030293d
BLAKE2b-256 204f7d8514d3a42296164904d490834bcc4b4b74d95df1feded0649362c0c080

See more details on using hashes here.

Provenance

The following attestation bundles were made for vice_driver-0.1.0.tar.gz:

Publisher: publish.yml on anarkiwi/vice-driver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vice_driver-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: vice_driver-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 33.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vice_driver-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2e7bbd01a81eb1abe52d6326d201222ab3c06f71ab752a80649759f1a5b02c1e
MD5 5e2225eefde4c3917109c8fa3dae8199
BLAKE2b-256 5e958c8265408885b93014bbcecda9f7ae843dbcc18d06c196751e68de4adbc9

See more details on using hashes here.

Provenance

The following attestation bundles were made for vice_driver-0.1.0-py3-none-any.whl:

Publisher: publish.yml on anarkiwi/vice-driver

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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