mirror of
https://github.com/dmolony/DiskBrowser.git
synced 2025-02-11 07:30:39 +00:00
better CP/M basic
This commit is contained in:
parent
954b0c0bd8
commit
08d6d1b136
@ -78,13 +78,6 @@ public class ApplesoftBasicProgram extends BasicProgram implements ApplesoftCons
|
||||
return sourceLines;
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------------//
|
||||
// byte[] getBuffer ()
|
||||
// // ---------------------------------------------------------------------------------//
|
||||
// {
|
||||
// return buffer;
|
||||
// }
|
||||
|
||||
// ---------------------------------------------------------------------------------//
|
||||
int getEndPtr ()
|
||||
// ---------------------------------------------------------------------------------//
|
||||
|
@ -2,16 +2,46 @@ package com.bytezone.diskbrowser.applefile;
|
||||
|
||||
import static com.bytezone.diskbrowser.utilities.Utility.getShort;
|
||||
|
||||
import com.bytezone.diskbrowser.utilities.HexFormatter;
|
||||
|
||||
// -----------------------------------------------------------------------------------//
|
||||
public class CPMBasicFile extends TextFile
|
||||
// -----------------------------------------------------------------------------------//
|
||||
{
|
||||
String[] tokens = { //
|
||||
"", "END", "FOR", "NEXT", "DATA", "INPUT", "DIM", "READ", // 0x80
|
||||
"", "GOTO", "", "IF", "", "GOSUB", "RETURN", "REM", // 0x88
|
||||
"POS", "PRINT", "", "", "", "ON", "DEF", "POKE", // 0x90
|
||||
"", "", "", "", "", "", "ELSE", "", // 0x98
|
||||
"", "", "", "", "", "", "", "", // 0xA0
|
||||
"", "", "DEFINT", "", "", "", "", "", // 0xA8
|
||||
"", "", "", "DIM", "", "", "", "", // 0xB0
|
||||
"", "", "", "", "CLOSE", "", "", "", // 0xB8
|
||||
"", "", "LSET", "", "", "RESET", "TEXT", "HOME", // 0xC0
|
||||
"VTAB", "HTAB", "", "", "", "", "", "", // 0xC8
|
||||
"", "", "", "", "", "", "", "", // 0xD0
|
||||
"", "", "", "", "", "TO", "THEN", "TAB(", // 0xD8
|
||||
"STEP", "USR", "FN", "", "", "", "", "STRING$", // 0xE0
|
||||
"", "", "", "", "", "", "", ">", // 0xE8
|
||||
"=", "<", "+", "-", "*", "", "", "AND", // 0xF0
|
||||
"OR", "", "", "", "MOD", "", "", "", // 0xF8
|
||||
};
|
||||
|
||||
// ---------------------------------------------------------------------------------//
|
||||
public CPMBasicFile (String name, byte[] buffer)
|
||||
// ---------------------------------------------------------------------------------//
|
||||
{
|
||||
super (name, buffer);
|
||||
|
||||
if (false)
|
||||
for (int i = 0; i < tokens.length; i++)
|
||||
{
|
||||
String t1 = tokens[i];
|
||||
String t2 = getToken (i + 0x80);
|
||||
|
||||
String flag = t1.length () == 0 || t1.equals (t2) ? "" : "***************";
|
||||
System.out.printf ("%02X %-8s %-8s %s%n", i + 0x80, t1, t2, flag);
|
||||
}
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------------//
|
||||
@ -40,25 +70,28 @@ public class CPMBasicFile extends TextFile
|
||||
|
||||
int lineNumber = getShort (buffer, ptr + 2);
|
||||
|
||||
text.append (String.format ("%7d ", lineNumber));
|
||||
text.append (String.format (" %d ", lineNumber));
|
||||
ptr += 4;
|
||||
|
||||
while (buffer[ptr] != 0)
|
||||
{
|
||||
int val = buffer[ptr++] & 0xFF;
|
||||
|
||||
if (val == 0x0E)
|
||||
if (val == 0x07)
|
||||
{
|
||||
int next1 = buffer[ptr++] & 0xFF;
|
||||
int next2 = buffer[ptr++] & 0xFF;
|
||||
text.append (next2 * 256 + next1);
|
||||
text.append ("<BELL>");
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x0F)
|
||||
if (val == 0x09)
|
||||
{
|
||||
int nextVal = buffer[ptr++] & 0xFF;
|
||||
text.append (nextVal);
|
||||
text.append (" ");
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x0A)
|
||||
{
|
||||
text.append ("\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -75,18 +108,59 @@ public class CPMBasicFile extends TextFile
|
||||
System.out.println ("found 0x0D");
|
||||
}
|
||||
|
||||
if (val == 0x0E) // same as 0x1C ??
|
||||
{
|
||||
int next1 = buffer[ptr++] & 0xFF;
|
||||
int next2 = buffer[ptr++] & 0xFF;
|
||||
text.append (next2 * 256 + next1);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x0F)
|
||||
{
|
||||
int nextVal = buffer[ptr++] & 0xFF;
|
||||
text.append (nextVal);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val >= 0x11 && val <= 0x1A)
|
||||
{
|
||||
text.append (val - 0x11);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x1C) // same as 0x0E ??
|
||||
{
|
||||
int b1 = buffer[ptr++] & 0xFF;
|
||||
int b2 = buffer[ptr++] & 0xFF;
|
||||
text.append (b2 * 256 + b1);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x1D)
|
||||
{
|
||||
text.append ("<" + HexFormatter.getHexString (buffer, ptr, 4, true) + ">");
|
||||
ptr += 4;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0x1F)
|
||||
{
|
||||
text.append ("<" + HexFormatter.getHexString (buffer, ptr, 8, true) + ">");
|
||||
ptr += 8;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (val == 0xFF)
|
||||
{
|
||||
int next = buffer[ptr++] & 0xFF;
|
||||
String token = switch (next)
|
||||
{
|
||||
case 0x81 -> "LEFT$";
|
||||
case 0x82 -> "RIGHT$";
|
||||
case 0x83 -> "MID$";
|
||||
case 0x94 -> "ASC";
|
||||
case 0x95 -> "CHR$";
|
||||
case 0x96 -> "PEEK";
|
||||
default -> String.format ("<%02X>", next);
|
||||
};
|
||||
@ -114,118 +188,147 @@ public class CPMBasicFile extends TextFile
|
||||
private String getToken (int val)
|
||||
// ---------------------------------------------------------------------------------//
|
||||
{
|
||||
switch (val)
|
||||
if (val < 0x80)
|
||||
{
|
||||
case 0x81:
|
||||
return "END";
|
||||
|
||||
case 0x82:
|
||||
return "FOR";
|
||||
|
||||
case 0x83:
|
||||
return "NEXT";
|
||||
|
||||
case 0x84:
|
||||
return "DATA";
|
||||
|
||||
case 0x85:
|
||||
return "INPUT";
|
||||
|
||||
case 0x8B:
|
||||
return "IF";
|
||||
|
||||
case 0x89:
|
||||
return "GOTO";
|
||||
|
||||
case 0x8D:
|
||||
return "GOSUB";
|
||||
|
||||
case 0x8E:
|
||||
return "RETURN";
|
||||
|
||||
case 0x8F:
|
||||
return "REM";
|
||||
|
||||
case 0x90:
|
||||
return "POS";
|
||||
|
||||
case 0x91:
|
||||
return "PRINT";
|
||||
|
||||
case 0x95:
|
||||
return "ON";
|
||||
|
||||
case 0x97:
|
||||
return "POKE";
|
||||
|
||||
case 0x9E:
|
||||
return "ELSE";
|
||||
|
||||
case 0xB3:
|
||||
return "DIM ";
|
||||
|
||||
case 0xC5:
|
||||
return "RESET";
|
||||
|
||||
case 0xC6:
|
||||
return "TEXT";
|
||||
|
||||
case 0xC7:
|
||||
return "HOME";
|
||||
|
||||
case 0xC8:
|
||||
return "VTAB";
|
||||
|
||||
case 0xC9:
|
||||
return "HTAB";
|
||||
|
||||
case 0xDD:
|
||||
return "TO";
|
||||
|
||||
case 0xDE:
|
||||
return "THEN";
|
||||
|
||||
case 0xDF:
|
||||
return "TAB(";
|
||||
|
||||
case 0xE0:
|
||||
return "STEP";
|
||||
|
||||
case 0xE1:
|
||||
return "USR";
|
||||
|
||||
case 0xE7:
|
||||
return "STRING$";
|
||||
|
||||
case 0xEF:
|
||||
return ">";
|
||||
|
||||
case 0xF0:
|
||||
return "=";
|
||||
|
||||
case 0xF1:
|
||||
return "<";
|
||||
|
||||
case 0xF2:
|
||||
return "+";
|
||||
|
||||
case 0xF3:
|
||||
return "-";
|
||||
|
||||
case 0xF4:
|
||||
return "*";
|
||||
|
||||
case 0xF7:
|
||||
return "AND";
|
||||
|
||||
case 0xF8:
|
||||
return "OR";
|
||||
|
||||
case 0xFC:
|
||||
return "MOD";
|
||||
|
||||
default:
|
||||
return String.format ("<%02X>", val);
|
||||
return String.format ("<****%02X*****>", val);
|
||||
}
|
||||
|
||||
String token = tokens[val - 128];
|
||||
if (token.length () == 0)
|
||||
token = String.format ("<%02X>", val);
|
||||
|
||||
return token;
|
||||
|
||||
// switch (val)
|
||||
// {
|
||||
// case 0x81:
|
||||
// return "END";
|
||||
//
|
||||
// case 0x82:
|
||||
// return "FOR";
|
||||
//
|
||||
// case 0x83:
|
||||
// return "NEXT";
|
||||
//
|
||||
// case 0x84:
|
||||
// return "DATA";
|
||||
//
|
||||
// case 0x85:
|
||||
// return "INPUT";
|
||||
//
|
||||
// case 0x86:
|
||||
// return "DIM";
|
||||
//
|
||||
// case 0x87:
|
||||
// return "READ";
|
||||
//
|
||||
// case 0x89:
|
||||
// return "GOTO";
|
||||
//
|
||||
// case 0x8B:
|
||||
// return "IF";
|
||||
//
|
||||
// case 0x8D:
|
||||
// return "GOSUB";
|
||||
//
|
||||
// case 0x8E:
|
||||
// return "RETURN";
|
||||
//
|
||||
// case 0x8F:
|
||||
// return "REM";
|
||||
//
|
||||
// case 0x90:
|
||||
// return "POS";
|
||||
//
|
||||
// case 0x91:
|
||||
// return "PRINT";
|
||||
//
|
||||
// case 0x95:
|
||||
// return "ON";
|
||||
//
|
||||
// case 0x96:
|
||||
// return "DEF";
|
||||
//
|
||||
// case 0x97:
|
||||
// return "POKE";
|
||||
//
|
||||
// case 0x9E:
|
||||
// return "ELSE";
|
||||
//
|
||||
// case 0xAA:
|
||||
// return "DEFINT";
|
||||
//
|
||||
// case 0xB3:
|
||||
// return "DIM";
|
||||
//
|
||||
// case 0xC2:
|
||||
// return "LSET";
|
||||
//
|
||||
// case 0xC5:
|
||||
// return "RESET";
|
||||
//
|
||||
// case 0xC6:
|
||||
// return "TEXT";
|
||||
//
|
||||
// case 0xC7:
|
||||
// return "HOME";
|
||||
//
|
||||
// case 0xC8:
|
||||
// return "VTAB";
|
||||
//
|
||||
// case 0xC9:
|
||||
// return "HTAB";
|
||||
//
|
||||
// case 0xDD:
|
||||
// return "TO";
|
||||
//
|
||||
// case 0xDE:
|
||||
// return "THEN";
|
||||
//
|
||||
// case 0xDF:
|
||||
// return "TAB(";
|
||||
//
|
||||
// case 0xE0:
|
||||
// return "STEP";
|
||||
//
|
||||
// case 0xE1:
|
||||
// return "USR";
|
||||
//
|
||||
// case 0xE2:
|
||||
// return "FN";
|
||||
//
|
||||
// case 0xE7:
|
||||
// return "STRING$";
|
||||
//
|
||||
// case 0xEF:
|
||||
// return ">";
|
||||
//
|
||||
// case 0xF0:
|
||||
// return "=";
|
||||
//
|
||||
// case 0xF1:
|
||||
// return "<";
|
||||
//
|
||||
// case 0xF2:
|
||||
// return "+";
|
||||
//
|
||||
// case 0xF3:
|
||||
// return "-";
|
||||
//
|
||||
// case 0xF4:
|
||||
// return "*";
|
||||
//
|
||||
// case 0xF7:
|
||||
// return "AND";
|
||||
//
|
||||
// case 0xF8:
|
||||
// return "OR";
|
||||
//
|
||||
// case 0xFC:
|
||||
// return "MOD";
|
||||
//
|
||||
// default:
|
||||
// return String.format ("<%02X>", val);
|
||||
// }
|
||||
}
|
||||
}
|
||||
|
@ -52,7 +52,7 @@ public class StoredVariables extends AbstractFile
|
||||
else if (suffix == '%')
|
||||
{
|
||||
intValue = Utility.intValue (buffer[ptr + 3], buffer[ptr + 2]); // backwards!
|
||||
if ((buffer[ptr + 2] & 0x80) > 0)
|
||||
if ((buffer[ptr + 2] & 0x80) != 0)
|
||||
intValue -= 65536;
|
||||
text.append (" = " + intValue);
|
||||
}
|
||||
@ -101,7 +101,7 @@ public class StoredVariables extends AbstractFile
|
||||
suffix = ' ';
|
||||
}
|
||||
|
||||
StringBuffer variableName = new StringBuffer ();
|
||||
StringBuilder variableName = new StringBuilder ();
|
||||
variableName.append (c1);
|
||||
if (c2 > 32)
|
||||
variableName.append (c2);
|
||||
@ -116,12 +116,14 @@ public class StoredVariables extends AbstractFile
|
||||
// ---------------------------------------------------------------------------------//
|
||||
{
|
||||
StringBuilder text = new StringBuilder ("(");
|
||||
|
||||
for (int i = 0; i < values.length; i++)
|
||||
{
|
||||
text.append (values[i]);
|
||||
if (i < values.length - 1)
|
||||
text.append (',');
|
||||
}
|
||||
|
||||
return text.append (')').toString ();
|
||||
}
|
||||
|
||||
@ -201,6 +203,7 @@ public class StoredVariables extends AbstractFile
|
||||
for (int i = 0; i < 5; i++)
|
||||
if (buffer[p + i] != 0)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -242,6 +242,7 @@ public class HexFormatter
|
||||
// ---------------------------------------------------------------------------------//
|
||||
{
|
||||
StringBuilder hex = new StringBuilder ();
|
||||
|
||||
int max = Math.min (offset + length, buffer.length);
|
||||
for (int i = offset; i < max; i++)
|
||||
{
|
||||
@ -249,8 +250,10 @@ public class HexFormatter
|
||||
if (space)
|
||||
hex.append (' ');
|
||||
}
|
||||
|
||||
if (length > 0 && space)
|
||||
hex.deleteCharAt (hex.length () - 1);
|
||||
|
||||
return hex.toString ();
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user