1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-12 02:30:44 +00:00
cc65/samples/sym1/symNotepad.c

193 lines
5.3 KiB
C
Raw Normal View History

2021-05-12 01:08:13 +01:00
// --------------------------------------------------------------------------
// Sym-1 Notepad
//
// Wayne Parham
//
// wayne@parhamdata.com
// --------------------------------------------------------------------------
//
// Note: This program requires RAM memory in locations 0xE000 - 0xEFFF
// Alternatively, the tape I/O buffer location and size can be
// changed by altering the defined TAPIO values below.
//
// --------------------------------------------------------------------------
2021-06-07 11:50:47 -05:00
#include <sym1.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
2021-05-12 01:08:13 +01:00
2021-06-15 16:39:28 -05:00
#define TAPIO_ADDRESS 0xE000
#define TAPIO_MAX_SIZE 0x0FFF
2021-05-12 01:08:13 +01:00
2021-06-16 16:47:38 -05:00
int main (void) {
char c = 0x00;
2021-06-15 16:39:28 -05:00
int l = 0x00;
int p = 0x00;
int error = 0x00;
int running = 0x01;
int writing = 0x01;
int instruction_needed = 0x01;
int heap_size = 0x00;
2021-05-12 01:08:13 +01:00
char* tapio = (char*) TAPIO_ADDRESS;
char* buffer;
heap_size = _heapmaxavail();
if ( heap_size > TAPIO_MAX_SIZE ) { // No need to malloc more than
2021-05-12 01:08:13 +01:00
heap_size = TAPIO_MAX_SIZE; // the interface allows
}
buffer = malloc ( heap_size );
memset ( buffer, 0x00, heap_size );
2021-05-12 01:08:13 +01:00
if ( buffer == 0x00 ) {
2021-06-16 16:47:38 -05:00
puts ("Memory full.");
2021-05-12 01:08:13 +01:00
running = 0;
}
tapio[0] = 0x00; // Check tape interface memory
if ( tapio[0] != 0x00 )
2021-05-12 01:08:13 +01:00
error = 1;
tapio[0] = 0xFF;
if ( tapio[0] != 0xFF )
2021-05-12 01:08:13 +01:00
error = 1;
tapio[TAPIO_MAX_SIZE] = 0x00;
if ( tapio[TAPIO_MAX_SIZE] != 0x00 )
2021-05-12 01:08:13 +01:00
error = 1;
tapio[TAPIO_MAX_SIZE] = 0xFF;
if ( tapio[TAPIO_MAX_SIZE] != 0xFF )
2021-05-12 01:08:13 +01:00
error = 1;
if ( error ) {
printf ("\nNo memory at location %p, aborting.\n", tapio);
2021-05-12 01:08:13 +01:00
running = 0;
}
else {
memset ( tapio, 0, TAPIO_MAX_SIZE );
2022-04-16 18:16:14 +02:00
}
2021-05-12 01:08:13 +01:00
while ( running ) {
2021-05-12 01:08:13 +01:00
putchar ( '\r' );
for ( l = 0; l < 25; l++ ) {
putchar ( '\n' );
2021-05-12 01:08:13 +01:00
}
2021-06-16 16:47:38 -05:00
puts ("===================== Sym-1 Notepad ====================");
2021-05-12 01:08:13 +01:00
if ( instruction_needed ) {
2021-06-16 16:47:38 -05:00
puts ("Enter text and you can save it to tape for reloading");
puts ("later. There are four special 'command' characters:\n");
puts (" Control-S Save to tape");
puts (" Control-L Load from tape");
puts (" Control-C Clear memory");
puts (" Control-X Exit");
puts ("========================================================\n");
2021-05-12 01:08:13 +01:00
}
while ( writing ) {
2021-05-12 01:08:13 +01:00
c = getchar();
if ( c == 0x08 ) { // Backspace
if ( p > 0 ) {
2021-05-12 01:08:13 +01:00
buffer[p] = 0x00;
p--;
}
}
else if ( c == 0x13 ) { // Save
2021-06-16 16:47:38 -05:00
puts ("\n========================= Save =========================");
puts ("\nPress any key to save.");
2021-05-12 01:08:13 +01:00
c = getchar();
for ( l = 0; l <= p; l++ ) {
2021-05-12 01:08:13 +01:00
tapio[l] = buffer[l];
}
2021-05-13 14:43:16 -05:00
l++;
2021-05-12 01:08:13 +01:00
tapio[l] = 0x00;
2021-06-16 16:47:38 -05:00
puts ("Saving to tape.");
error = dumpt ( 'N', tapio, tapio+p );
if ( error ) {
2021-06-16 16:47:38 -05:00
puts ("\nTape error.");
2021-05-12 01:08:13 +01:00
}
2021-05-13 14:43:16 -05:00
else
2021-05-12 01:08:13 +01:00
{
putchar ( '\r' );
for ( l = 0; l < 25; l++ ) {
putchar ( '\n' );
2021-05-12 01:08:13 +01:00
}
}
2021-06-16 16:47:38 -05:00
puts ("===================== Sym-1 Notepad ====================\n");
for ( l = 0; l <= p; l++ ) {
putchar ( buffer[l] );
2021-05-12 01:08:13 +01:00
}
}
else if ( c == 0x0C ) { // Load
2021-05-12 01:08:13 +01:00
p = 0;
2021-06-16 16:47:38 -05:00
puts ("\nLoading from tape.");
memset ( buffer, 0, heap_size );
memset ( tapio, 0, TAPIO_MAX_SIZE );
error = loadt ( 'N' );
if ( error ) {
2021-06-16 16:47:38 -05:00
puts ("\nTape error.");
puts ("===================== Sym-1 Notepad ====================\n");
2021-05-12 01:08:13 +01:00
}
else
{
2022-04-16 18:16:14 +02:00
for ( l = 0; l <= heap_size; l++ ) {
buffer[l] = tapio[l];
}
2021-05-12 01:08:13 +01:00
2022-04-16 18:16:14 +02:00
p = strlen ( buffer );
2021-05-12 01:08:13 +01:00
2022-04-16 18:16:14 +02:00
putchar ( '\r' );
for ( l = 0; l < 25; l++ ) {
putchar ( '\n' );
}
puts ("===================== Sym-1 Notepad ====================\n");
2021-05-12 01:08:13 +01:00
2022-04-16 18:16:14 +02:00
for ( l = 0; l <= p; l++ ) {
putchar ( buffer[l] );
}
2021-05-12 01:08:13 +01:00
}
}
else if ( c == 0x03 ) { // Clear
2021-05-12 01:08:13 +01:00
p = 0;
memset ( buffer, 0, heap_size );
putchar ( '\r' );
for ( l = 0; l < 25; l++ ) {
putchar ( '\n' );
2021-05-12 01:08:13 +01:00
}
2021-06-16 16:47:38 -05:00
puts ("===================== Sym-1 Notepad ====================\n");
2021-05-12 01:08:13 +01:00
}
else if ( c == 0x18 ) { // Exit
2021-05-12 01:08:13 +01:00
writing = 0;
running = 0;
}
else {
if ( p >= heap_size - 1 ) {
2021-06-16 16:47:38 -05:00
puts ("\n========================= End =========================");
puts ("Buffer full.");
2021-05-12 01:08:13 +01:00
}
else {
if ( c == '\n' ) {
putchar ( '\n' );
2021-05-12 01:08:13 +01:00
}
buffer[p] = c;
}
p++;
}
}
}
free ( buffer );
2021-06-16 16:47:38 -05:00
puts ("\nEnjoy your day!\n");
return 0;
2021-05-12 01:08:13 +01:00
}