Skip to main content

Debuging and conversion tool for 1980s magazine type-in programs

Project description

retrotype

Tools for typing-in, debugging, and converting 1980s magazine type-in games and programs for use with Commodore emulators and original hardware.

Installation (requires Python 3.8 or later)

pip3 install retrotype --upgrade

Tool: retrotype_cli

The retrotype_cli tool is a command line debugger and converter for Commodore BASIC programs focused on tokenizing magazine type-in programs popular in the 1980s. Given an input text file containing BASIC source code in magazine type-in format, it checks the typed line entries against line checksums that were printed in the magazines to insure program is bug-free. It outputs both the checksums to the terminal and writes a file with the extension '.chk' for comparison with the checksums printed in the magazine or with a '.ref' file containing the line numbers and checksums from the magazine. Finally, it outputs an executable '.prg' file for direct use with an emulator or original hardware.

Usage

After installation, use retrotype_cli directly from the command line - consult the help for the latest usage:

Note: Currently the only implemented options are for Ahoy C64 programs.

retrotype_cli [-l load_address] [-s source_format] [-w] input_file
positional arguments:
  input_file            Specify the input file name, including path.
                        Note:  Output files will use input file basename

optional arguments:
  -h, --help            show this help message and exit

  -l load_address, --loadaddr load_address
                        Specifies the target BASIC memory address when loading:
                        - 0x0801 - C64 (default)
                        - 0x1001 - VIC20 Unexpanded
                        - 0x0401 - VIC20 +3K
                        - 0x1201 - VIC20 +8K
                        - 0x1201 - VIC20 +16
                        - 0x1201 - VIC20 +24K

  -s source_format, --source source_format
                        Specifies the magazine source for conversion and checksum:
                        ahoy1 - Ahoy magazine (Apr-May 1984)
                        ahoy2 - Ahoy magazine (Jun 1984-Apr 1987) (default)
                        ahoy3 - Ahoy magazine (May 1987-)

  -w, --wip             Work in progress, do not output executable binary file.

As an example for an Ahoy! magazine file:

Input:  basename.bas

Outputs:  basename.prg (tokenized file that can be run on a Commodore computer
                        or on an emulator like VICE)
          basename.chk (list of line numbers and checksums, along with the
                        number of lines, for comparision to checksums printed
                        in the magazine)

Notes for entering programs from Ahoy issues prior to November 1984:

In addition to the special character codes contained in braces in the magazine, Ahoy also used a shorthand convention for specifying a key entry preceeded by either the Shift key or the Commodore key as follows:

Underlined characters - preceed entry with Shift key
Overlined characters - preceed entry with Commodore key

Standard keyboard letters should be typed as follows for these two cases.

{s A}, {s B}, {s *} etc.
{c A}, {c B}, {c *}, etc.

There are a few instances where the old hardware has keys not available on a modern keyboard or are otherwise ambiguous. Those should be entered as follows:

{EP} - British Pound symbol
{UP_ARROW} - up arrow symbol
{LEFT_ARROW} - left arrow symbol
{PI} - Pi symbol
{s RETURN} - shifted return
{s SPACE} - shifted space
{c EP} - Commodore-Bristish Pound symbol
{s UP_ARROW} - shifted up arrow symbol

After the October 1984 issue, the over/under score representation was discontinued as was the use of braces as delineators. After October 1984, the braces were replaced by brackets, however, either can be used while typing in the programs for any issue. The special characters can be typed as listed in the magazines after that issue.

Using the output files

You can run the .prg file generated by the retrotype_cli program by running it with the VICE emulator with the following command (must have VICE installed):

x64sc -basicload program_name.prg &

Of course, you can also run the .prg file on original hardware.

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

retrotype-1.1.0.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

retrotype-1.1.0-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file retrotype-1.1.0.tar.gz.

File metadata

  • Download URL: retrotype-1.1.0.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for retrotype-1.1.0.tar.gz
Algorithm Hash digest
SHA256 1d5cfde3293683968c2833a753bfdefcbd917d0ac6c3a433c7fc3a1826935733
MD5 8600fe9539d880a211e9f73ce41eb4dc
BLAKE2b-256 4d7c91482a66ee1b169280c5e1abaf4e5adb8f5a56ca8d156b7689b142b8265c

See more details on using hashes here.

File details

Details for the file retrotype-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: retrotype-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 14.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for retrotype-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 54ef4ceeb324a6c2c8c1df11fd30177edee03dc1d20dfc67a64048c706110283
MD5 36c14cc10ffb1d516aa1f0a0b7f432f0
BLAKE2b-256 ffd2f82d7f5c41f48c7a54763bf517312e87b26455a7e6e954826c1bbdf3d1e6

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