]> Shamusworld >> Repos - rmac/blobdiff - token.h
Fixed .cargs problem, more code cleanup/fixup
[rmac] / token.h
diff --git a/token.h b/token.h
index 6bc1102e3671b70faf0d857c7dfd8ef9cc7808e9..becd0747f9a6ba93e79566ef258025afad109feb 100644 (file)
--- 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);