Login
Tools - AdvSkelVic65
Title:AdvSkelVic65
Version:
ActiveYes
Last updated:2024-02-22
CategoryProgramming
Platform:Windows
Created by:Harry Potter
Download: https://sourceforge.net/projects/cc65extra/files/game/


Notes
Text adventure code for cc65 and the Vic20, C16, PET, C64 and Atari 8-bit
targets. Very efficient! The main executable of the Vic20 version is ~1.71k,
the c16 version is ~1.28k and the PET version 1.99k. These figures were taken
without text compression and as disk support. Includes Windows batch files to
compile the program. CBM disk versions require cbmconvert, and Atari disks
use Dir2Atr.

The Vic20 binary version requires 16k memory expansion, but the cartridge
versions use an unexpanded memory setup.

The C64 version now supports disks and single files. The Vic20 and C16 versions
also now support single-file binaries. Support is provided for Atari 800
disks.

The Atari 8-bit cartridge format works up to 32k now. The 32k version is a
bank-switched MegaCart cartridge.

[Benefits]

* Very efficient, as I used my CBMSimpleIO and AtaSimpleIO libraries,
lots of inline assembler, global and zeropage variables, function
parameters in global and zeropage variables, numbers to identify verbs
and nouns, the Cubbyhole optimization technique that uses a computer's
Low memory when otherwise unused during a cc65 program, optimizations
to the crt0.s files by excluding unneeded code in them and other
optimizations, most of which can be found online at
https://sourceforge.net/projects/cc65extra/files/.
* Supports limited compression of text: uses tokenization and RLE of spaces.
* Easy-to-use: provided you know what you're doing, it should be easy to
adapt this code to a specific text adventure.
* This program supports the Commodore PET, the Vic20, the C16, the C64
and the Atari 800 and C16, C64 and Atari8 cartridges. All but the
Vic20 cartridge versions support 32k cartridges.
* Customizability: you can change the prompt and add things such as
colors and new verbs and nouns to the code.
* Memory: this code supports systems with little memory and has ways to
maximize usable memory.
* This code has ways to target each supported system with codes that
take adventage of each system's abilities and otherwise make the code
more efficient.

[Drawbacks]

* You currently can't swap rooms from disk: all rooms have to fit in
memory.
* Compression is limited and requires manual compression.
* Doesn't include ANSI support, as it would waste a lot of space, so
support for other machines has to be written in the code.
* Other text adventure creators probably support more platforms.

[New]

* Heavy optimizations and cleaning up of code

[Known Bug]

* Text compression on PET targets doesn't work properly: tokens expand to
garbage.

[Planned]

* Small Apple2 support
* Better compression
* One-part Atari8 and PET binaries
* Expandibility of used zeropage space on CBM targets
* The ability to add more directions
* Optimizations to save game support
* Support for more control characters when not compressing text
* Updates to AdvSkel65, including save game support and some bug-fixes to
some 128k versions

This is to update the last version of AdvSkelVic65 with some bug fixes.
The following are the bugs that this is supposed to fix:

* The PET target was displaying garbage when printing compressed strings.
This bug was caused by not switching the character definitions as
needed by PrintTok, the mechanism that prints compressed strings.
This is needed because, otherwise, capital letters would be inter-
preted as tokens.
* When printing valid exits from a room and using text compression, on
the PET target, the exits, which use upper-case, print the wrong
symbol. I needed to switch to the regular PETSCII key assignments
just for them.
* When targeting 32k cartridges and using text compression, some messages
stored in the main bank were not printed properly. This is caused by
using a function that prints from the auxilliary bank instead of one
that prints from the main bank. This was solved but at the cost that
such messages can't be compressed. PrintTok has a version that can
support both main memory and auxilliary memory, but that version is not
used here.
* The disk-based C16 target occasionally crashed. This was caused by
using the Cubbyhole optimization technique and having one extra block
overwrite two bytes needed by the kernal to display to the screen.

To install these bug fixes, simply extract these files to their own
folder and replace the .c files in the original distrbution with the same
names as these with these.

The documentation also neglected to mention that the first room as
included in the code showed an example of how to use PrintTok to display
compressed strings. It shows how to tokenize repeated text snippets. For more
information, read the printtok-002.c file included in the main distribution.

Copyright © Plus/4 World Team, 2001-2025. Support Plus/4 World on Patreon