]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/common/lexer.l
* Fixed a bug in notebook.tex
[wxWidgets.git] / src / common / lexer.l
... / ...
CommitLineData
1SIGN [+-]
2DIGIT [0-9]
3ALPHA [a-zA-Z_]
4ALPHADIGIT [a-zA-Z_0-9]
5STRINGCHAR [^"\\]
6WORDCHAR [^'\\]
7
8%{
9/*
10 * File: lexer.l
11 * Description: Lexical analyser for PROLOGIO; can be used with
12 * either lex and flex.
13 */
14#include <string.h>
15
16/* +++steve162e: added, otherwise, PROIO_input will be undefined (at least under LINUX)
17 please check, if this is also TRUE under other UNIXes.
18 */
19
20#if defined(FLEX_SCANNER) && defined(_LINUX)
21#define PROIO_input my_input
22#endif
23/* ---steve162e */
24
25#include "wx/expr.h"
26
27#ifdef wx_x
28extern char *malloc();
29#endif
30#define Return(x) return x;
31
32#if defined(VMS) && !defined(strdup)
33#define strdup(s) (strcpy((char *)malloc(strlen(s)+1), s));
34#endif
35
36static size_t lex_buffer_length = 0;
37static const char *lex_buffer = NULL;
38static size_t lex_string_ptr = 0;
39static int lex_read_from_string = 0;
40
41static int my_input(void);
42static int my_unput(char);
43
44#ifdef FLEX_SCANNER
45#undef YY_INPUT
46# define YY_INPUT(buf,result,max_size) \
47 if (lex_read_from_string) \
48 { int c = my_input(); result = (c == 0) ? YY_NULL : ((buf)[0]=(c), 1); } \
49 else \
50 if ( (result = read( fileno(yyin), (char *) buf, max_size )) < 0 ) \
51 YY_FATAL_ERROR( "read() in flex scanner failed" );
52#else
53# undef unput
54# define unput(_c) my_unput(_c)
55#endif
56
57%}
58
59%%
60
61{SIGN}?{DIGIT}+ {yylval.s = strdup(yytext); Return(INTEGER);}
62
63"e" Return(EXP);
64
65{ALPHA}{ALPHADIGIT}* {yylval.s = strdup(yytext); Return(WORD);}
66
67"'"{WORDCHAR}*"'" {int len = strlen(yytext);
68 yytext[len-1] = 0;
69 yylval.s = strdup(yytext+1);
70 Return(WORD);}
71
72\"({STRINGCHAR}|\\\"|\|\\\\|\\)*\" {yylval.s = strdup(yytext); Return(STRING);}
73
74"(" Return(OPEN);
75
76")" Return(CLOSE);
77
78"," Return(COMMA);
79
80"[" Return(OPEN_SQUARE);
81
82"]" Return(CLOSE_SQUARE);
83
84"=" Return(EQUALS);
85
86"." Return(PERIOD);
87
88[ \t] ;
89
90\n ;
91
92"/*" { loop:
93#ifdef __cplusplus
94 while (yyinput() != '*');
95 switch (yyinput())
96#else
97 while (input() != '*');
98 switch (input())
99#endif
100 {
101 case '/': break;
102 case '*': unput('*');
103 default: goto loop;
104 }
105 }
106
107. Return(ERROR);
108
109%%
110
111
112#ifdef FLEX_SCANNER
113static int lex_input() {
114 return input();
115}
116#else /* BSD/AT&T lex */
117#ifndef input
118# error "Sorry, but need either flex or AT&T lex"
119#endif
120static int lex_input() {
121 return input();
122}
123/* # undef unput
124# define unput(_c) my_unput(_c)
125*/
126
127# undef input
128# define input() my_input()
129static int my_unput(char c)
130{
131 if (lex_read_from_string) {
132 /* Make sure we have something */
133 if (lex_string_ptr) {
134 if (c == '\n') yylineno--;
135 lex_string_ptr--;
136 }
137 } else {
138 yytchar= (c);if(yytchar=='\n')yylineno--;*yysptr++=yytchar;
139/* unput(c); Causes infinite recursion! */
140 }
141 return c;
142}
143
144#endif
145
146/* Public */
147void LexFromFile(FILE *fd)
148{
149 lex_read_from_string = 0;
150 yyin = fd;
151 /* Don't know why this is necessary, but otherwise
152 * lex only works _once_!
153 */
154#ifdef FLEX_SCANNER
155 yyrestart(fd);
156 yy_init = 1;
157#endif
158}
159
160void LexFromString(char *buffer)
161{
162 lex_read_from_string = 1;
163 lex_buffer = buffer;
164 lex_buffer_length = strlen(buffer);
165 lex_string_ptr = 0;
166 /* Don't know why this is necessary, but otherwise
167 * lex only works _once_!
168 */
169#ifdef FLEX_SCANNER
170 yy_init = 1;
171#endif
172}
173
174static int my_input( void )
175{
176 if (lex_read_from_string) {
177 if (lex_string_ptr == lex_buffer_length)
178 return 0;
179 else {
180 char c = lex_buffer[lex_string_ptr++];
181#ifndef FLEX_SCANNER
182 if (c == '\n') yylineno++;
183#endif
184 return c;
185 }
186 } else {
187 return lex_input();
188 }
189}
190
191void wxExprCleanUp()
192{
193 if (yy_current_buffer)
194 yy_delete_buffer(yy_current_buffer);
195}