459 lines
10 KiB
C
459 lines
10 KiB
C
#ifndef TOKEN_H
|
|
#define TOKEN_H
|
|
|
|
#include "autotypes.h"
|
|
#include "value.h"
|
|
#include "var.h"
|
|
|
|
enum SymbolType { GLOBALVAR, GLOBALARRAY, LOCALVAR, BUILTINFUNCTION, USERFUNCTION };
|
|
|
|
struct Symbol
|
|
{
|
|
char *name;
|
|
enum SymbolType type;
|
|
union
|
|
{
|
|
struct Var var; /* GLOBALVAR, GLOBALARRAY */
|
|
struct
|
|
{
|
|
int offset; /* LOCALVAR */
|
|
enum ValueType type;
|
|
} local;
|
|
struct
|
|
{
|
|
union
|
|
{
|
|
struct /* BUILTINFUNCTION */
|
|
{
|
|
struct Value *(* call)(struct Value *value, struct Auto *stack);
|
|
struct Symbol *next;
|
|
} bltin;
|
|
struct /* USERFUNTION */
|
|
{
|
|
struct Scope scope;
|
|
int localLength;
|
|
enum ValueType *localTypes;
|
|
} def;
|
|
} u;
|
|
int argLength;
|
|
enum ValueType *argTypes;
|
|
enum ValueType retType;
|
|
} sub;
|
|
} u;
|
|
struct Symbol *next;
|
|
};
|
|
|
|
#include "program.h"
|
|
#include "str.h"
|
|
|
|
struct Identifier
|
|
{
|
|
struct Symbol *sym;
|
|
enum ValueType defaultType;
|
|
char name[2/* ... */];
|
|
};
|
|
|
|
struct Next
|
|
{
|
|
struct Pc fr;
|
|
struct Pc var;
|
|
struct Pc limit;
|
|
struct Pc body;
|
|
};
|
|
|
|
struct On
|
|
{
|
|
int pcLength;
|
|
struct Pc *pc;
|
|
};
|
|
|
|
struct Selectcase
|
|
{
|
|
struct Pc endselect;
|
|
enum ValueType type;
|
|
struct Pc nextcasevalue;
|
|
};
|
|
|
|
struct Casevalue
|
|
{
|
|
struct Pc endselect;
|
|
struct Pc nextcasevalue;
|
|
};
|
|
|
|
enum TokenType
|
|
{
|
|
T_NOTOKEN=0,
|
|
T_ACCESS_READ,
|
|
T_ACCESS_READ_WRITE,
|
|
T_ACCESS_WRITE,
|
|
T_AND,
|
|
T_AS,
|
|
T_CALL,
|
|
T_CASEELSE,
|
|
T_CASEVALUE,
|
|
T_CHANNEL,
|
|
T_CHDIR,
|
|
T_CLEAR,
|
|
T_CLOSE,
|
|
T_CLS,
|
|
T_COLON,
|
|
T_COLOR,
|
|
T_COMMA,
|
|
T_CON,
|
|
T_COPY,
|
|
T_CP,
|
|
T_DATA,
|
|
T_DATAINPUT,
|
|
T_DEC,
|
|
T_DEFDBL,
|
|
T_DEFFN,
|
|
T_DEFINT,
|
|
T_DEFPROC,
|
|
T_DEFSTR,
|
|
T_DELETE,
|
|
T_DIM,
|
|
T_DISPLAY,
|
|
T_DIV,
|
|
T_DO,
|
|
T_DOUNTIL,
|
|
T_DOWHILE,
|
|
T_EDIT,
|
|
T_ELSE,
|
|
T_ELSEIFELSE,
|
|
T_ELSEIFIF,
|
|
T_END,
|
|
T_ENDFN,
|
|
T_ENDIF,
|
|
T_ENDPROC,
|
|
T_ENDSELECT,
|
|
T_ENVIRON,
|
|
T_EOL,
|
|
T_EQ,
|
|
T_EQV,
|
|
T_ERASE,
|
|
T_EXITDO,
|
|
T_EXITFOR,
|
|
T_FIELD,
|
|
T_FNEND,
|
|
T_FNEXIT,
|
|
T_FNRETURN,
|
|
T_FOR,
|
|
T_FOR_INPUT,
|
|
T_FOR_OUTPUT,
|
|
T_FOR_APPEND,
|
|
T_FOR_RANDOM,
|
|
T_FOR_BINARY,
|
|
T_FUNCTION,
|
|
T_GE,
|
|
T_GET,
|
|
T_GOSUB,
|
|
T_GOTO,
|
|
T_GT,
|
|
T_HEXINTEGER,
|
|
T_OCTINTEGER,
|
|
T_IDENTIFIER,
|
|
T_IDIV,
|
|
T_IDN,
|
|
T_IF,
|
|
T_IMAGE,
|
|
T_IMP,
|
|
T_INC,
|
|
T_INPUT,
|
|
T_INTEGER,
|
|
T_INV,
|
|
T_IS,
|
|
T_JUNK,
|
|
T_KILL,
|
|
T_LE,
|
|
T_LET,
|
|
T_LINEINPUT,
|
|
T_LIST,
|
|
T_LLIST,
|
|
T_LOAD,
|
|
T_LOCAL,
|
|
T_LOCATE,
|
|
T_LOCK,
|
|
T_LOCK_READ,
|
|
T_LOCK_WRITE,
|
|
T_LOOP,
|
|
T_LOOPUNTIL,
|
|
T_LPRINT,
|
|
T_LSET,
|
|
T_LT,
|
|
T_MAT,
|
|
T_MATINPUT,
|
|
T_MATPRINT,
|
|
T_MATREAD,
|
|
T_MATREDIM,
|
|
T_MATWRITE,
|
|
T_MINUS,
|
|
T_MKDIR,
|
|
T_MOD,
|
|
T_MULT,
|
|
T_NAME,
|
|
T_NE,
|
|
T_NEW,
|
|
T_NEXT,
|
|
T_NOT,
|
|
T_ON,
|
|
T_ONERROR,
|
|
T_ONERRORGOTO0,
|
|
T_ONERROROFF,
|
|
T_OP,
|
|
T_OPEN,
|
|
T_OPTIONBASE,
|
|
T_OPTIONRUN,
|
|
T_OPTIONSTOP,
|
|
T_OR,
|
|
T_OUT,
|
|
T_PLUS,
|
|
T_POKE,
|
|
T_POW,
|
|
T_PRINT,
|
|
T_PUT,
|
|
T_QUOTE,
|
|
T_RANDOMIZE,
|
|
T_READ,
|
|
T_REAL,
|
|
T_REM,
|
|
T_RENAME,
|
|
T_RENUM,
|
|
T_REPEAT,
|
|
T_RESTORE,
|
|
T_RESUME,
|
|
T_RETURN,
|
|
T_RSET,
|
|
T_RUN,
|
|
T_SAVE,
|
|
T_SELECTCASE,
|
|
T_SEMICOLON,
|
|
T_SHARED,
|
|
T_SHELL,
|
|
T_SLEEP,
|
|
T_SPC,
|
|
T_STEP,
|
|
T_STOP,
|
|
T_STRING,
|
|
T_SUB,
|
|
T_SUBEND,
|
|
T_SUBEXIT,
|
|
T_SWAP,
|
|
T_SYSTEM,
|
|
T_TAB,
|
|
T_THEN,
|
|
T_TO,
|
|
T_TRN,
|
|
T_TROFF,
|
|
T_TRON,
|
|
T_TRUNCATE,
|
|
T_UNLOCK,
|
|
T_UNNUM,
|
|
T_UNNUMBERED,
|
|
T_UNTIL,
|
|
T_USING,
|
|
T_WAIT,
|
|
T_WEND,
|
|
T_WHILE,
|
|
T_WIDTH,
|
|
T_WRITE,
|
|
T_XOR,
|
|
T_XREF,
|
|
T_ZER,
|
|
T_ZONE,
|
|
T_LASTTOKEN=T_ZONE
|
|
};
|
|
|
|
struct Token
|
|
{
|
|
enum TokenType type;
|
|
struct Value *(*statement)(struct Value *value);
|
|
union
|
|
{
|
|
/* T_ACCESS_READ */
|
|
/* T_ACCESS_READ_WRITE */
|
|
/* T_ACCESS_WRITE */
|
|
/* T_AND */
|
|
/* T_AS */
|
|
/* T_CALL */
|
|
/* T_CASEELSE */ struct Casevalue *casevalue;
|
|
/* T_CASEIS */ /* struct Casevalue *casevalue; */
|
|
/* T_CASEVALUE */ /* struct Casevalue *casevalue; */
|
|
/* T_CHANNEL */
|
|
/* T_CHDIR */
|
|
/* T_CLEAR */
|
|
/* T_CLOSE */
|
|
/* T_CLS */
|
|
/* T_COLON */
|
|
/* T_COLOR */
|
|
/* T_COMMA */
|
|
/* T_CON */
|
|
/* T_COPY */
|
|
/* T_CP */
|
|
/* T_DATA */ struct Pc nextdata;
|
|
/* T_DATAINPUT */ char *datainput;
|
|
/* T_DEFFN */ struct Symbol *localSyms;
|
|
/* T_DEFDBL */
|
|
/* T_DEFINT */
|
|
/* T_DEFPROC */ /* struct Symbol *localSyms; */
|
|
/* T_DELETE */
|
|
/* T_DIM */
|
|
/* T_DIV */
|
|
/* T_DO */ struct Pc exitdo;
|
|
/* T_DOUNTIL */ /* struct Pc exitdo; */
|
|
/* T_DOWHILE */ /* struct Pc exitdo; */
|
|
/* T_EDIT */
|
|
/* T_ELSE */ struct Pc endifpc;
|
|
/* T_ELSEIFELSE */ /* struct Pc endifpc; */
|
|
/* T_ELSEIFIF */ struct Pc elsepc;
|
|
/* T_END */ struct Pc endpc;
|
|
/* T_ENDFN */
|
|
/* T_ENDIF */
|
|
/* T_ENDPROC */
|
|
/* T_ENDSELECT */
|
|
/* T_ENVIRON */
|
|
/* T_EOL */
|
|
/* T_EQ */ enum ValueType type;
|
|
/* T_EQV */
|
|
/* T_ERASE */
|
|
/* T_EXITDO */ /* struct Pc exitdo; */
|
|
/* T_EXITFOR */ struct Pc exitfor;
|
|
/* T_FIELD */
|
|
/* T_FNEND */
|
|
/* T_FNRETURN */
|
|
/* T_FOR */ /* struct Pc exitfor */
|
|
/* T_FOR_INPUT */
|
|
/* T_FOR_OUTPUT */
|
|
/* T_FOR_APPEND */
|
|
/* T_FOR_RANDOM */
|
|
/* T_FOR_BINARY */
|
|
/* T_FUNCTION */ /* struct Symbol *localSyms; */
|
|
/* T_GE */
|
|
/* T_GET */
|
|
/* T_GOSUB */ struct Pc gosubpc;
|
|
/* T_GOTO */ struct Pc gotopc;
|
|
/* T_GT */
|
|
/* T_HEXINTEGER */ long int hexinteger;
|
|
/* T_OCTINTEGER */ long int octinteger;
|
|
/* T_IDENTIFIER */ struct Identifier *identifier;
|
|
/* T_IDIV */
|
|
/* T_IDN */
|
|
/* T_IF */ /* struct Pc elsepc; */
|
|
/* T_IMAGE */ /* struct String *string; */
|
|
/* T_IMP */
|
|
/* T_INPUT */
|
|
/* T_INTEGER */ long int integer;
|
|
/* T_INV */
|
|
/* T_IS */
|
|
/* T_JUNK */ char junk;
|
|
/* T_KILL */
|
|
/* T_LE */
|
|
/* T_LEN */
|
|
/* T_LET */
|
|
/* T_LINEINPUT */
|
|
/* T_LIST */
|
|
/* T_LLIST */
|
|
/* T_LOAD */
|
|
/* T_LOCAL */
|
|
/* T_LOCATE */
|
|
/* T_LOCK */
|
|
/* T_LOCK_READ */
|
|
/* T_LOCK_WRITE */
|
|
/* T_LOOP */ struct Pc dopc;
|
|
/* T_LOOPUNTIL */ /* struct Pc dopc; */
|
|
/* T_LPRINT */
|
|
/* T_LSET */
|
|
/* T_LT */
|
|
/* T_MAT */
|
|
/* T_MATINPUT */
|
|
/* T_MATPRINT */
|
|
/* T_MATREAD */
|
|
/* T_MATREDIM */
|
|
/* T_MINUS */
|
|
/* T_MKDIR */
|
|
/* T_MOD */
|
|
/* T_MULT */
|
|
/* T_NAME */
|
|
/* T_NE */
|
|
/* T_NEW */
|
|
/* T_NEXT */ struct Next *next;
|
|
/* T_NOT */
|
|
/* T_ON */ struct On on;
|
|
/* T_ONERROR */
|
|
/* T_ONERRORGOTO0 */
|
|
/* T_ONERROROFF */
|
|
/* T_OP */
|
|
/* T_OPEN */
|
|
/* T_OPTIONBASE */
|
|
/* T_OR */
|
|
/* T_OUT */
|
|
/* T_PLUS */
|
|
/* T_POKE */
|
|
/* T_POW */
|
|
/* T_PRINT */
|
|
/* T_PUT */
|
|
/* T_QUOTE */ /* char *rem; */
|
|
/* T_RANDOMIZE */
|
|
/* T_READ */
|
|
/* T_REAL */ double real;
|
|
/* T_REM */ char *rem;
|
|
/* T_RENAME */
|
|
/* T_RENUM */
|
|
/* T_REPEAT */
|
|
/* T_RESTORE */ struct Pc restore;
|
|
/* T_RESUME */ /* struct Pc gotopc; */
|
|
/* T_RETURN */
|
|
/* T_RSET */
|
|
/* T_RUN */
|
|
/* T_SAVE */
|
|
/* T_SELECTCASE */ struct Selectcase *selectcase;
|
|
/* T_SEMICOLON */
|
|
/* T_SHARED */
|
|
/* T_SHELL */
|
|
/* T_SLEEP */
|
|
/* T_SPC */
|
|
/* T_STEP */
|
|
/* T_STOP */
|
|
/* T_STRING */ struct String *string;
|
|
/* T_SUB */ /* struct Symbol *localSyms; */
|
|
/* T_SUBEND */
|
|
/* T_SUBEXIT */
|
|
/* T_SWAP */
|
|
/* T_SYSTEM */
|
|
/* T_TAB */
|
|
/* T_THEN */
|
|
/* T_TO */
|
|
/* T_TRN */
|
|
/* T_TROFF */
|
|
/* T_TRON */
|
|
/* T_TRUNCATE */
|
|
/* T_UNLOCK */
|
|
/* T_UNNUM */
|
|
/* T_UNNUMBERED */
|
|
/* T_UNTIL */ struct Pc until;
|
|
/* T_USING */ struct Pc image;
|
|
/* T_WAIT */
|
|
/* T_WEND */ struct Pc *whilepc;
|
|
/* T_WHILE */ struct Pc *afterwend;
|
|
/* T_WIDTH */
|
|
/* T_WRITE */
|
|
/* T_XOR */
|
|
/* T_XREF */
|
|
/* T_ZER */
|
|
/* T_ZONE */
|
|
} u;
|
|
};
|
|
|
|
extern struct Token *Token_newCode(const char *ln);
|
|
extern struct Token *Token_newData(const char *ln);
|
|
extern void Token_destroy(struct Token *token);
|
|
extern struct String *Token_toString(struct Token *token, struct Token *spaceto, struct String *s, int *indent, int full);
|
|
extern int Token_property[];
|
|
#define TOKEN_ISBINARYOPERATOR(t) (Token_property[t]&1)
|
|
#define TOKEN_ISUNARYOPERATOR(t) (Token_property[t]&(1<<1))
|
|
#define TOKEN_BINARYPRIORITY(t) ((Token_property[t]>>2)&7)
|
|
#define TOKEN_UNARYPRIORITY(t) ((Token_property[t]>>5)&7)
|
|
#define TOKEN_ISRIGHTASSOCIATIVE(t) (Token_property[t]&(1<<8))
|
|
extern void Token_init(int backslash_colon, int uppercase);
|
|
|
|
#endif
|