X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?p=rmac;a=blobdiff_plain;f=token.h;h=251a503f424036a705edf559b3ecd9302b85d56b;hp=59e6ff50051ee7edf2aa4041029cb9e80d53e7cb;hb=619867988ebf5dafbf8e1adbda157d85ba9eedeb;hpb=30a208654896284b50e7b362e97d3e63ec717b96 diff --git a/token.h b/token.h index 59e6ff5..251a503 100644 --- a/token.h +++ b/token.h @@ -1,7 +1,7 @@ // // RMAC - Reboot's Macro Assembler for all Atari computers // TOKEN.H - Token Handling -// Copyright (C) 199x Landon Dyer, 2011-2018 Reboot and Friends +// Copyright (C) 199x Landon Dyer, 2011-2020 Reboot and Friends // RMAC derived from MADMAC v1.07 Written by Landon Dyer, 1986 // Source utilised with the kind permission of Landon Dyer // @@ -17,16 +17,17 @@ #define SRC_IREPT 2 // Input source is IREPT // Macros -#define INOBJ struct _inobj -#define IUNION union _iunion -#define IFILE struct _incldfile -#define IMACRO struct _imacro -#define IREPT struct _irept -#define IFENT struct _ifent +#define INOBJ struct _inobj +#define IUNION union _iunion +#define IFILE struct _incldfile +#define TOKENSTREAM struct _tokenstream +#define IMACRO struct _imacro +#define IREPT struct _irept +#define IFENT struct _ifent // Tunable definitions #define LNSIZ 1024 // Maximum size of a line of text -#define TOKBUFSIZE 400 // Size of token-line buffer +#define TOKBUFSIZE 4096 // Size of token-line buffer #define QUANTUM 4096L // # bytes to eat at a time from a file #define LNBUFSIZ (QUANTUM*2) // Size of file's buffer #define KWSIZE 7 // Maximum size of keyword in kwtab.h @@ -74,7 +75,8 @@ #define CR_TIME 'x' // ^^time - DOS format time #define CR_DATE 'y' // ^^date - DOS format date #define CR_ABSCOUNT 'z' // ^^abscount - count the number of bytes - // defined in curent .abs section + // defined in current .abs section +#define CR_FILESIZE 'F' // ^^filesize - return the size in bytes of a file // Character Attributes #define ILLEG 0 // Illegal character (unused) @@ -125,10 +127,14 @@ IFILE { char ifbuf[LNBUFSIZ]; // Line buffer }; -#define TOKENSTREAM struct _tokenstream +// Consts for maximums in TOKENSTREAM +#define TS_MAXTOKENS 64 // 32 ought to be enough for anybody (including XiA!) +#define TS_MAXSTRINGS 32 // same for attached strings +#define TS_MAXARGS 20 // Assume no more than 20 arguments in an invocation + TOKENSTREAM { - TOKEN token[32]; // 32 ought to be enough for anybody (including XiA!) - char * string[32]; // same for attached strings + TOKEN token[TS_MAXTOKENS]; + char * string[TS_MAXSTRINGS]; }; // Information about a macro invocation @@ -140,7 +146,7 @@ IMACRO { LONG im_olduniq; // Old value of 'macuniq' SYM * im_macro; // Pointer to macro we're in char im_lnbuf[LNSIZ]; // Line buffer - TOKENSTREAM argument[20]; // Assume no more than 20 arguments in an invocation + TOKENSTREAM argument[TS_MAXARGS]; }; // Information about a .rept invocation @@ -153,7 +159,7 @@ IREPT { // Exported variables extern int lnsave; -extern uint16_t curlineno; +extern uint32_t curlineno; extern char * curfname; extern WORD cfileno; extern TOKEN * tok;