1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-25 11:30:06 +00:00
cc65/samples
Jeff Tranter 3a5fbd34da Add KIM-1 functions to write to the 7-segment LED display and get
keypresses from the keypad.
Includes sample program illustrating how to use them.
Tested on real KIM-1 hardware.
2023-03-29 18:40:10 -04:00
..
2022-04-18 17:43:56 +02:00
2022-04-18 17:43:56 +02:00
2020-10-15 19:34:40 +02:00
2022-02-05 17:34:22 +01:00
2023-01-14 13:49:16 +01:00
2022-04-18 17:43:56 +02:00
2022-04-17 16:06:45 +02:00
2022-04-18 17:43:56 +02:00
2016-06-18 23:57:17 +02:00
2021-06-10 20:08:58 +02:00
2016-06-18 23:57:17 +02:00

This directory contains sample programs for the cc65 compiler.

The programs contained here are
- used as samples and referenced from within the documentation (this is their
  main purpose)
- installed into the filesystem
- compiled (but NOT run) by the CI test

-----------------------------------------------------------------------------

Below is a short description for each of the programs, together with a list
of the supported platforms.

Please note:

  * The supplied makefile needs GNU make. It works out of the box on Linux and
    similar systems. If you're using Windows, then consider installing Cygwin
    or MSys2.

  * The makefile specifies the C64 as the default target system because most
    of the programs run on that platform. When compiling for another system,
    you will have to change the line that specifies the target system at the
    top of the makefile, specify the system with SYS=<target> on the make
    command line, or set a SYS environment variable. For example:

    make SYS=apple2

  * Use "make disk" to build a disk image with all sample programs.

  * All programs in the root of the "samples" directory have been written to
    be portable and work on more than one target. Programs that are specific
    to a certain target live in a subdirectory with the name of the target.

List of supplied sample programs:

-----------------------------------------------------------------------------
Name:           ascii
Description:    Shows the ASCII (or ATASCII, PETSCII) codes of typed
                characters. Written and contributed by Greg King
                <greg.king5@verizon.com>.
Platforms:      All platforms with conio or stdio (compile time configurable).

-----------------------------------------------------------------------------
Name:           diodemo
Description:    A disc copy program written and contributed by Oliver
                Schmidt, <ol.sc@web.de>. Supports single or dual disc copy.
Platforms:      The program does depend on conio and dio (direct disk i/o),
                so it currently does compile for only the Atari and Apple ][
                machines.

-----------------------------------------------------------------------------
Name:           enumdevdir
Description:    Enumerates all devices, directories, and files. Written and
                contributed by Oliver Schmidt, <ol.sc@web.de>.
Platforms:      All systems with device enumeration and directory access
                (currently the Commodore machines, the Commander X16,
                and the Apple ][).

-----------------------------------------------------------------------------
Name:           gunzip65
Description:    A gunzip utility for 6502-based machines, written by Piotr
                Fusik <fox@scene.pl>.
Platforms:      Runs on all platforms with file I/O (currently the Atari, the
                Apple ][, Commodore machines, and the Commander X16).

-----------------------------------------------------------------------------
Name:           hello
Description:    A nice "Hello world" type program that uses the conio
                console I/O library for output.
Platforms:      Runs on all platforms that support conio, which means:
                Apple ][, Atari, Commodore machines, Commander X16,
                Creativision, Gamate, NES.

-----------------------------------------------------------------------------
Name:           mandelbrot
Description:    A mandelbrot demo using integer arithmetic. The demo was
                written by groepaz, and converted to cc65 using TGI graphics
                by Stefan Haubenthal.
Platforms:      Runs on all platforms that have TGI support:
                Apple ][, Atari, C64, C128, Oric Atmos and Telestrat, GEOS,
                and NES.

-----------------------------------------------------------------------------
Name:           mousedemo
Description:    Shows how to use the mouse.
Platforms:      All systems with mouse and conio support:
                C64, C128, CBM510, Atari, Apple ][.

-----------------------------------------------------------------------------
Name:           multidemo
Description:    Shows how to combine multiple cc65 features incl. overlays
                and extended memory drivers. Written and contributed by
                Oliver Schmidt, <ol.sc@web.de>.
Platforms:      All systems with an overlay linker config., disk directory
                access, and EMD support (currently the C64, the C128,
                the Atari, and the Apple ][).

-----------------------------------------------------------------------------
Name:           overlaydemo
Description:    Shows how to load overlay files from disk. Written and
                contributed by Oliver Schmidt, <ol.sc@web.de>.
Platforms:      All systems with an overlay linker config. (currently the C64,
                the C128, the Atari, and the Apple ][).

-----------------------------------------------------------------------------
Name:           sieve
Description:    Implements the "Sieve of Eratosthenes" as a way to find all
                prime numbers in a specific number interval. Often used as
                a benchmark program.
Platforms:      All systems with conio and clock support:
                Atari, Commodore machines (VIC-20 needs memory expansion),
                Commander X16, Apple ][ (without timing due to missing clock
                support).

-----------------------------------------------------------------------------
Name:           tinyshell
Description:    Simple ("tiny") shell to test filename and directory functions.
Platforms:      Runs on all platforms that have stdio support

-----------------------------------------------------------------------------
Name:           tgidemo
Description:    Shows some of the graphics capabilities of the "Tiny Graphics
                Interface".
Platforms:      Runs on all platforms that have TGI support:
                Apple ][, Atari, C64, C128, Oric Atmos and Telestrat, GEOS,
                NES, and Lynx.

=============================================================================

Platform-specific samples follow:

atari 2600:
-----------

Name:           hello
Description:    A "Hello world" type program.
Platforms:      Runs on only the Atari 2600 Video Console System.
-----------------------------------------------------------------------------

atari 5200:
-----------

Name:           hello
Description:    A "Hello world" type program.
Platforms:      Runs on only the Atari 5200 Video Console System.
-----------------------------------------------------------------------------

apple2:
-------

Name:           hgrtest 
Description:    shows how to incorporate a hires screen right into the binary,
                thus allowing to place content both below and above the hires
                video ram without multiple files nor copying stuff around (plus
                having a nice splash screen as bonus). It basically demos how to
                make use of apple2-hgr.cfg.

Name:           hgrshow 
Description:    is a (single) hires program showing how to load (single) hires
                screens from files without support from TGI. TGI could be used
                to "paint" on the loaded screens.

Name:           dhgrshow 
Description:    is a double hires program showing how to load double hires
                screens from files. TGI is used for most of the I/O address
                manipulation, but (in contrast to hgrshow) is not actually
                functional.

-----------------------------------------------------------------------------

cbm:
----

Name:           fire
Description:    Another graphics demo written by groepaz.
Platforms:      C64, C128, CBM510

-----------------------------------------------------------------------------
Name:           nachtm
Description:    Plays "Eine kleine Nachtmusik" by Wolfgang Amadeus Mozart.
Platforms:      All systems that have the Commodore SID (Sound Interface
                Device):
                C64, C128, CBM510, CBM610.

-----------------------------------------------------------------------------
Name:           plasma
Description:    A fancy graphics demo written by groepaz.
Platforms:      The program needs a VIC-II or a TED, so it runs on the following
                systems:
                C64, C128, CBM510, Plus/4.
-----------------------------------------------------------------------------

gamate:
-------

Name:           nachtm
Description:    Plays "Eine kleine Nachtmusik" by Wolfgang Amadeus Mozart.
-----------------------------------------------------------------------------

lynx:
-----

These programs are adapted for the Atari Lynx because its library has no conio
output or stdio.

Name:           hello
Description:    A nice "Hello world" type program that uses the TGI graphics
                library for output.

Name:           mandelbrot
Description:    A mandelbrot demo using integer arithmetic. The demo was
                written by groepaz, and converted to cc65 using TGI graphics
                by Stefan Haubenthal.

Name:           tgidemo
Description:    Shows some of the graphics capabilities of the "Tiny Graphics
                Interface".

-----------------------------------------------------------------------------

sym1:
-----

Name:           symHello
Description:    Hello World for Sym-1

Name:           symTiny
Description:    Hello World for Sym-1 (tiny version without printf)

Name:           symDisplay
Description:    Sym-1 front panel display example

Name:           symIO
Description:    Sym-1 digital I/O interface example

Name:           symNotepad
Description:    Sym-1 Notepad

-----------------------------------------------------------------------------

supervision:
------------

Name:           hello
Description:    A "Hello world" type program.
Platforms:      Runs on only the Watara Supervision game console.
----------------------------------------------------------------------------