]> git.sur5r.net Git - cc65/blob - src/ca65/toklist.h
Mark tokens with the file position from where they're read. Restore this
[cc65] / src / ca65 / toklist.h
1 /*****************************************************************************/
2 /*                                                                           */
3 /*                                 toklist.h                                 */
4 /*                                                                           */
5 /*                  Token list for the ca65 macroassembler                   */
6 /*                                                                           */
7 /*                                                                           */
8 /*                                                                           */
9 /* (C) 2000-2011, Ullrich von Bassewitz                                      */
10 /*                Roemerstrasse 52                                           */
11 /*                D-70794 Filderstadt                                        */
12 /* EMail:         uz@cc65.org                                                */
13 /*                                                                           */
14 /*                                                                           */
15 /* This software is provided 'as-is', without any expressed or implied       */
16 /* warranty.  In no event will the authors be held liable for any damages    */
17 /* arising from the use of this software.                                    */
18 /*                                                                           */
19 /* Permission is granted to anyone to use this software for any purpose,     */
20 /* including commercial applications, and to alter it and redistribute it    */
21 /* freely, subject to the following restrictions:                            */
22 /*                                                                           */
23 /* 1. The origin of this software must not be misrepresented; you must not   */
24 /*    claim that you wrote the original software. If you use this software   */
25 /*    in a product, an acknowledgment in the product documentation would be  */
26 /*    appreciated but is not required.                                       */
27 /* 2. Altered source versions must be plainly marked as such, and must not   */
28 /*    be misrepresented as being the original software.                      */
29 /* 3. This notice may not be removed or altered from any source              */
30 /*    distribution.                                                          */
31 /*                                                                           */
32 /*****************************************************************************/
33
34
35
36 #ifndef TOKLIST_H
37 #define TOKLIST_H
38
39
40
41 /* common */
42 #include "strbuf.h"
43
44 /* ca65 */
45 #include "scanner.h"
46
47
48
49 /*****************************************************************************/
50 /*                                   Data                                    */
51 /*****************************************************************************/
52                                 
53
54
55 /* Struct holding a token */
56 typedef struct TokNode TokNode;
57 struct TokNode {
58     TokNode*    Next;                   /* For single linked list */
59     Token       T;                      /* Token value */
60 };
61
62 /* Struct holding a token list */
63 typedef struct TokList TokList;
64 struct TokList {
65     TokList*    Next;                   /* Single linked list (for replay) */
66     TokNode*    Root;                   /* First node in list */
67     TokNode*    Last;                   /* Last node in list or replay */
68     unsigned    RepCount;               /* Repeat counter (used for replay) */
69     unsigned    RepMax;                 /* Maximum repeat count for replay */
70     unsigned    Count;                  /* Token count */
71     void        (*Check)(TokList*);     /* Token check function */
72     void*       Data;                   /* Additional data for check */
73 };
74
75
76
77 /* Return codes for TokCmp - higher numeric code means better match */
78 enum TC {
79     tcDifferent,                        /* Different tokents */
80     tcSameToken,                        /* Same token, different attribute */
81     tcIdentical                         /* Identical (token + attribute) */
82 };
83
84
85
86 /*****************************************************************************/
87 /*                                   Code                                    */
88 /*****************************************************************************/
89
90
91
92 TokNode* NewTokNode (void);
93 /* Create and return a token node with the current token value */
94
95 void FreeTokNode (TokNode* N);
96 /* Free the given token node */
97
98 void TokSet (TokNode* N);
99 /* Set the scanner token from the given token node */
100
101 enum TC TokCmp (const TokNode* N);
102 /* Compare the token given as parameter against the current token */
103
104 void InitTokList (TokList* T);
105 /* Initialize a token list structure for later use */
106
107 TokList* NewTokList (void);
108 /* Create a new, empty token list */
109
110 void FreeTokList (TokList* T);
111 /* Delete the token list including all token nodes */
112
113 token_t GetTokListTerm (token_t Term);
114 /* Determine if the following token list is enclosed in curly braces. This is
115  * the case if the next token is the opening brace. If so, skip it and return
116  * a closing brace, otherwise return Term.
117  */
118
119 void AddCurTok (TokList* T);
120 /* Add the current token to the token list */
121
122 void PushTokList (TokList* List, const char* Desc);
123 /* Push a token list to be used as input for InputFromStack. This includes
124  * several initializations needed in the token list structure, so don't use
125  * PushInput directly.
126  */
127
128
129
130 /* End of toklist.h */
131
132 #endif
133
134
135
136