Audio player/recorder software for legacy computers as tape recorder replacement
Project description
Supertape
An audio player/recorder software working with legacy computers as a tape recorder replacement. Supertape allows you to load, save, and play audio cassette tape data for vintage computers through modern audio interfaces.
Features
- Audio Interface Integration: Real-time audio input/output through modern sound cards
- File Format Support: Handle BASIC source files (.bas) and assembly source files (.asm)
- Audio Processing: Convert between audio signals and digital tape data
- Interactive Shell: Enhanced command-line interface with rich UI features
- Tape Database: Persistent storage of tape files using YAML format
- Image Conversion: Convert images to BASIC programs for display
- Audio Monitoring: Real-time audio level monitoring and device selection
Installation
Requirements
- Python 3.11+
- Audio interface (microphone/line input and speaker/line output)
Dependencies
Install using Poetry (recommended):
poetry install
Or install using pip after building with Poetry:
poetry build
pip install dist/supertape-*.whl
Poetry Setup (Recommended)
# Install Poetry if not already installed
curl -sSL https://install.python-poetry.org | python3 -
# Install dependencies
poetry install
Usage
Basic Commands
Run commands using Poetry:
poetry run supertape [command] [options]
Available Commands
Audio Operations
Listen to audio input or file:
poetry run supertape listen [--device N] [--dump] [--list] [file.wav]
--device N: Select audio device by index or name substring (case-insensitive)- Tip: Set
SUPERTAPE_AUDIO_DEVICEenvironment variable to avoid repeating--device --dump: Display raw byte data--list: Show BASIC program listingfile.wav: Process audio file instead of live input
Play files to audio output:
poetry run supertape play [--device N] file.bas
poetry run supertape play [--device N] file.asm
Converts BASIC or assembly source files to audio signals.
Interactive Tools
Interactive shell:
poetry run supertape shell [--device N] [database_name]
List audio devices:
poetry run supertape devices
Show help:
poetry run supertape
File Operations
Image to BASIC conversion:
poetry run supertape image_to_basic input.png output.bas
Preprocess BASIC files:
poetry run supertape preprocess input.bas output.bas
Example Workflows
Recording from vintage computer:
# List available audio devices
poetry run supertape devices
# Listen and save programs from audio input
poetry run supertape listen --device 1 --list
# Use interactive shell for managing recordings
poetry run supertape shell my_tapes
Playing programs to vintage computer:
# Convert and play a BASIC program
poetry run supertape play --device 0 basic/duke.bas
# Convert and play an assembly program
poetry run supertape play --device 0 test/programs/test.asm
Testing
Run the test suite:
poetry run pytest test/
Run specific test modules:
poetry run pytest test/test_basic.py
poetry run pytest test/test_assembly.py
Compatibility
Currently Supported
Matra Alice
Supertape fully supports the Matra Alice computer range:
- Alice 4k (original Alice)
- Alice 32
- Alice 90
Tandy MC-10
The Matra Alice 4k being a clone of the Tandy MC-10, both systems share the same tape formats and are fully compatible with Supertape.
File Format Support
- BASIC Programs:
.bassource files with preprocessing and minification - Assembly Programs:
.asmsource files - Audio Files:
.wavfiles for playback and analysis - Tape Data: Native tape file format with persistent database storage
Future Plans
This application is planning to support additional vintage computers with audio tape interfaces:
- Commodore 64
- Amstrad CPC
- Sinclair ZX Spectrum
- TRS-80
- Apple II
Architecture
Supertape uses a modular architecture with audio processing pipelines:
- Audio Layer: Real-time audio I/O with device abstraction
- Device selection by index or name substring
- Centralized exception hierarchy for error handling
- Signal Processing: Modulation/demodulation for tape data encoding
- File Processing: BASIC/assembly compilation and tape file management
- User Interfaces: Console commands and pluggable interactive shell with command registry
- Storage: YAML-based persistent tape file repository
- Configuration: Environment variable support (SUPERTAPE_*) for all settings
Technical Documentation
For detailed information about the tape format specification, see TAPE_FORMAT.md. This document covers:
- Physical FSK encoding (1200/2400 Hz frequencies)
- Block types and structure (header, data, EOF)
- Namefile header format with file types and addressing
- Complete cassette block layout and checksums
Developer Documentation
For comprehensive programming guides, see the docs/ directory:
-
Alice 32/90 Graphics Guide - Graphics programming using the EF9345 video processor
- Hardware comparison (MC-10/Alice 4k vs Alice 32/90)
- EF9345 register programming in C and Assembly
- Graphics modes, colors, and drawing operations
- Complete code examples with test programs
-
C Development Guide - C programming for M6803 microprocessor
- Fuzix-Compiler-Kit (FCC) setup and usage
- M6803 architecture and limitations
- Memory-mapped I/O patterns
- Code examples and optimization techniques
-
Assembly Development Guide - M6803 assembly programming
- Complete instruction set reference
- Addressing modes and assembler directives
- Programming patterns and optimization
- Debugging strategies
-
Memory Map Reference - Memory addressing for Alice 4k/32/90
- Complete memory maps for all models
- I/O register addresses and usage
- Zero page, RAM, ROM, and VRAM organization
- Programming examples and best practices
Contributing
- Fork the repository
- Create a feature branch
- Make your changes with appropriate tests
- Run the test suite:
poetry run pytest test/ - Submit a pull request
License
See the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file supertape-1.0.0.dev11.tar.gz.
File metadata
- Download URL: supertape-1.0.0.dev11.tar.gz
- Upload date:
- Size: 92.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eee5086ead236fb86069880718c6817b318c829d9cdf9290bbab0406966db9cf
|
|
| MD5 |
1ea7cfb1c55e7ec5abc5b5446afd0659
|
|
| BLAKE2b-256 |
1a520e47fc682d0eb0d7af4906e2848041b60bea53fe33373398e57fbbcad53b
|
File details
Details for the file supertape-1.0.0.dev11-py3-none-any.whl.
File metadata
- Download URL: supertape-1.0.0.dev11-py3-none-any.whl
- Upload date:
- Size: 122.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8c25e29b1426f4b02b9631853fbc38097af4ba551017e2971717b3edf9789ef0
|
|
| MD5 |
b26db941784a7652b897ac53d264ee1d
|
|
| BLAKE2b-256 |
388449ae03ce614c95f72871156b6611f3dde79731a0762a5dacf9abe8ab6001
|