X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?p=rmac;a=blobdiff_plain;f=token.h;h=becd0747f9a6ba93e79566ef258025afad109feb;hp=6bc1102e3671b70faf0d857c7dfd8ef9cc7808e9;hb=adc2f2df316f46cc70f8939f30c5f39ce6470a20;hpb=d16b8ea0ee65b2ad901ca6b0624c07e6e4930cc4 diff --git a/token.h b/token.h index 6bc1102..becd074 100644 --- a/token.h +++ b/token.h @@ -110,6 +110,12 @@ IFILE { char ifbuf[LNBUFSIZ]; // Line buffer }; +#define TOKENSTREAM struct _tokenstream +TOKENSTREAM { + TOKEN token[10]; // 10 ought to be enough for anybody + char * string[10]; // same for attached strings +}; + // Information about a macro invocation IMACRO { IMACRO * im_link; // Pointer to ancient IMACROs @@ -120,6 +126,8 @@ IMACRO { LONG im_olduniq; // Old value of 'macuniq' SYM * im_macro; // Pointer to macro we're in char im_lnbuf[LNSIZ]; // Line buffer + uint32_t argBase; // Base in argPtrs[] for current macro + TOKENSTREAM argument[20]; // Assume no more than 20 arguments in an invocation }; // Information about a .rept invocation @@ -148,7 +156,7 @@ extern char * string[]; // Prototypes int include(int, char *); void init_token(void); -void setfnum(WORD); +void SetFilenameForErrorReporting(void); int tokln(void); int fpop(void); int d_goto(WORD);