1 /*****************************************************************************/
5 /* The scanner for the ca65 macroassembler */
9 /* (C) 1998-2007 Ullrich von Bassewitz */
10 /* Roemerstrasse 52 */
11 /* D-70794 Filderstadt */
12 /* EMail: uz@cc65.org */
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. */
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: */
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 */
32 /*****************************************************************************/
50 /*****************************************************************************/
52 /*****************************************************************************/
56 /* Scanner variables */
57 extern Token Tok; /* Current token */
58 extern int WS; /* Flag: Whitespace before token */
59 extern long IVal; /* Integer token attribute */
60 extern StrBuf SVal; /* String token attribute */
62 extern FilePos CurPos; /* Name and position in file */
63 extern int ForcedEnd; /* Force end of assembly */
67 /*****************************************************************************/
69 /*****************************************************************************/
74 /* Return true if the character is a valid character for an identifier */
76 int IsIdStart (int C);
77 /* Return true if the character may start an identifier */
79 int NewInputFile (const char* Name);
80 /* Open a new input file. Returns true if the file could be successfully opened
81 * and false otherwise.
84 void NewInputData (char* Text, int Malloced);
85 /* Add a chunk of input data to the input stream */
87 void LocaseSVal (void);
88 /* Make SVal lower case */
90 void UpcaseSVal (void);
91 /* Make SVal upper case */
93 void NextRawTok (void);
94 /* Read the next raw token from the input stream */
96 int GetSubKey (const char** Keys, unsigned Count);
97 /* Search for a subkey in a table of keywords. The current token must be an
98 * identifier and all keys must be in upper case. The identifier will be
99 * uppercased in the process. The function returns the index of the keyword,
100 * or -1 if the keyword was not found.
103 unsigned char ParseAddrSize (void);
104 /* Check if the next token is a keyword that denotes an address size specifier.
105 * If so, return the corresponding address size constant, otherwise output an
106 * error message and return ADDR_SIZE_DEFAULT.
109 void InitScanner (const char* InFile);
110 /* Initialize the scanner, open the given input file */
112 void DoneScanner (void);
113 /* Release scanner resources */
117 /* End of scanner.h */