xref: /dflybsd-src/contrib/gcc-4.7/gcc/gengtype-lex.l (revision 04febcfb30580676d3e95f58a16c5137ee478b32)
1*e4b17023SJohn Marino /* -*- indented-text -*- */
2*e4b17023SJohn Marino /* Process source files and output type information.
3*e4b17023SJohn Marino    Copyright (C) 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010
4*e4b17023SJohn Marino    Free Software Foundation, Inc.
5*e4b17023SJohn Marino 
6*e4b17023SJohn Marino This file is part of GCC.
7*e4b17023SJohn Marino 
8*e4b17023SJohn Marino GCC is free software; you can redistribute it and/or modify it under
9*e4b17023SJohn Marino the terms of the GNU General Public License as published by the Free
10*e4b17023SJohn Marino Software Foundation; either version 3, or (at your option) any later
11*e4b17023SJohn Marino version.
12*e4b17023SJohn Marino 
13*e4b17023SJohn Marino GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14*e4b17023SJohn Marino WARRANTY; without even the implied warranty of MERCHANTABILITY or
15*e4b17023SJohn Marino FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
16*e4b17023SJohn Marino for more details.
17*e4b17023SJohn Marino 
18*e4b17023SJohn Marino You should have received a copy of the GNU General Public License
19*e4b17023SJohn Marino along with GCC; see the file COPYING3.  If not see
20*e4b17023SJohn Marino <http://www.gnu.org/licenses/>.  */
21*e4b17023SJohn Marino 
22*e4b17023SJohn Marino %option noinput
23*e4b17023SJohn Marino 
24*e4b17023SJohn Marino %{
25*e4b17023SJohn Marino #ifdef GENERATOR_FILE
26*e4b17023SJohn Marino #include "bconfig.h"
27*e4b17023SJohn Marino #else
28*e4b17023SJohn Marino #include "config.h"
29*e4b17023SJohn Marino #endif
30*e4b17023SJohn Marino #include "system.h"
31*e4b17023SJohn Marino 
32*e4b17023SJohn Marino #define malloc xmalloc
33*e4b17023SJohn Marino #define realloc xrealloc
34*e4b17023SJohn Marino 
35*e4b17023SJohn Marino #include "gengtype.h"
36*e4b17023SJohn Marino 
37*e4b17023SJohn Marino #define YY_DECL int yylex (const char **yylval)
38*e4b17023SJohn Marino #define yyterminate() return EOF_TOKEN
39*e4b17023SJohn Marino 
40*e4b17023SJohn Marino struct fileloc lexer_line;
41*e4b17023SJohn Marino int lexer_toplevel_done;
42*e4b17023SJohn Marino 
43*e4b17023SJohn Marino static void
update_lineno(const char * l,size_t len)44*e4b17023SJohn Marino update_lineno (const char *l, size_t len)
45*e4b17023SJohn Marino {
46*e4b17023SJohn Marino   while (len-- > 0)
47*e4b17023SJohn Marino     if (*l++ == '\n')
48*e4b17023SJohn Marino       lexer_line.line++;
49*e4b17023SJohn Marino }
50*e4b17023SJohn Marino 
51*e4b17023SJohn Marino %}
52*e4b17023SJohn Marino 
53*e4b17023SJohn Marino ID	[[:alpha:]_][[:alnum:]_]*
54*e4b17023SJohn Marino WS	[[:space:]]+
55*e4b17023SJohn Marino HWS	[ \t\r\v\f]*
56*e4b17023SJohn Marino IWORD	short|long|(un)?signed|char|int|HOST_WIDE_INT|HOST_WIDEST_INT|bool|size_t|BOOL_BITFIELD|CPPCHAR_SIGNED_T|ino_t|dev_t|HARD_REG_SET
57*e4b17023SJohn Marino ITYPE	{IWORD}({WS}{IWORD})*
58*e4b17023SJohn Marino EOID	[^[:alnum:]_]
59*e4b17023SJohn Marino 
60*e4b17023SJohn Marino %x in_struct in_struct_comment in_comment
61*e4b17023SJohn Marino %option warn noyywrap nounput nodefault perf-report
62*e4b17023SJohn Marino %option 8bit never-interactive
63*e4b17023SJohn Marino %%
64*e4b17023SJohn Marino   /* Do this on entry to yylex():  */
65*e4b17023SJohn Marino   *yylval = 0;
66*e4b17023SJohn Marino   if (lexer_toplevel_done)
67*e4b17023SJohn Marino     {
68*e4b17023SJohn Marino       BEGIN(INITIAL);
69*e4b17023SJohn Marino       lexer_toplevel_done = 0;
70*e4b17023SJohn Marino     }
71*e4b17023SJohn Marino 
72*e4b17023SJohn Marino   /* Things we look for in skipping mode: */
73*e4b17023SJohn Marino <INITIAL>{
74*e4b17023SJohn Marino ^{HWS}typedef/{EOID} {
75*e4b17023SJohn Marino   BEGIN(in_struct);
76*e4b17023SJohn Marino   return TYPEDEF;
77*e4b17023SJohn Marino }
78*e4b17023SJohn Marino ^{HWS}struct/{EOID} {
79*e4b17023SJohn Marino   BEGIN(in_struct);
80*e4b17023SJohn Marino   return STRUCT;
81*e4b17023SJohn Marino }
82*e4b17023SJohn Marino ^{HWS}union/{EOID} {
83*e4b17023SJohn Marino   BEGIN(in_struct);
84*e4b17023SJohn Marino   return UNION;
85*e4b17023SJohn Marino }
86*e4b17023SJohn Marino ^{HWS}extern/{EOID} {
87*e4b17023SJohn Marino   BEGIN(in_struct);
88*e4b17023SJohn Marino   return EXTERN;
89*e4b17023SJohn Marino }
90*e4b17023SJohn Marino ^{HWS}static/{EOID} {
91*e4b17023SJohn Marino   BEGIN(in_struct);
92*e4b17023SJohn Marino   return STATIC;
93*e4b17023SJohn Marino }
94*e4b17023SJohn Marino 
95*e4b17023SJohn Marino ^{HWS}DEF_VEC_[OP]/{EOID} {
96*e4b17023SJohn Marino   BEGIN(in_struct);
97*e4b17023SJohn Marino   return DEFVEC_OP;
98*e4b17023SJohn Marino }
99*e4b17023SJohn Marino ^{HWS}DEF_VEC_I/{EOID} {
100*e4b17023SJohn Marino   BEGIN(in_struct);
101*e4b17023SJohn Marino   return DEFVEC_I;
102*e4b17023SJohn Marino }
103*e4b17023SJohn Marino ^{HWS}DEF_VEC_ALLOC_[IOP]/{EOID} {
104*e4b17023SJohn Marino   BEGIN(in_struct);
105*e4b17023SJohn Marino   return DEFVEC_ALLOC;
106*e4b17023SJohn Marino }
107*e4b17023SJohn Marino }
108*e4b17023SJohn Marino 
109*e4b17023SJohn Marino <in_struct>{
110*e4b17023SJohn Marino 
111*e4b17023SJohn Marino "/*"				{ BEGIN(in_struct_comment); }
112*e4b17023SJohn Marino 
113*e4b17023SJohn Marino {WS}				{ update_lineno (yytext, yyleng); }
114*e4b17023SJohn Marino \\\n				{ lexer_line.line++; }
115*e4b17023SJohn Marino 
116*e4b17023SJohn Marino "const"/{EOID}			/* don't care */
117*e4b17023SJohn Marino "GTY"/{EOID}			{ return GTY_TOKEN; }
118*e4b17023SJohn Marino "VEC"/{EOID}			{ return VEC_TOKEN; }
119*e4b17023SJohn Marino "union"/{EOID}			{ return UNION; }
120*e4b17023SJohn Marino "struct"/{EOID}			{ return STRUCT; }
121*e4b17023SJohn Marino "enum"/{EOID}			{ return ENUM; }
122*e4b17023SJohn Marino "ptr_alias"/{EOID}	  	{ return PTR_ALIAS; }
123*e4b17023SJohn Marino "nested_ptr"/{EOID}		{ return NESTED_PTR; }
124*e4b17023SJohn Marino [0-9]+				{ return NUM; }
125*e4b17023SJohn Marino "param"[0-9]*"_is"/{EOID}		{
126*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext, yyleng, yyleng+1);
127*e4b17023SJohn Marino   return PARAM_IS;
128*e4b17023SJohn Marino }
129*e4b17023SJohn Marino 
130*e4b17023SJohn Marino {IWORD}({WS}{IWORD})*/{EOID}		|
131*e4b17023SJohn Marino "ENUM_BITFIELD"{WS}?"("{WS}?{ID}{WS}?")"	{
132*e4b17023SJohn Marino   size_t len;
133*e4b17023SJohn Marino 
134*e4b17023SJohn Marino   for (len = yyleng; ISSPACE (yytext[len-1]); len--)
135*e4b17023SJohn Marino     ;
136*e4b17023SJohn Marino 
137*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext, len, len+1);
138*e4b17023SJohn Marino   update_lineno (yytext, yyleng);
139*e4b17023SJohn Marino   return SCALAR;
140*e4b17023SJohn Marino }
141*e4b17023SJohn Marino 
142*e4b17023SJohn Marino 
143*e4b17023SJohn Marino {ID}/{EOID}			{
144*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext, yyleng, yyleng+1);
145*e4b17023SJohn Marino   return ID;
146*e4b17023SJohn Marino }
147*e4b17023SJohn Marino 
148*e4b17023SJohn Marino \"([^"\\]|\\.)*\"		{
149*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext+1, yyleng-2, yyleng-1);
150*e4b17023SJohn Marino   return STRING;
151*e4b17023SJohn Marino }
152*e4b17023SJohn Marino   /* This "terminal" avoids having to parse integer constant expressions.  */
153*e4b17023SJohn Marino "["[^\[\]]*"]"			{
154*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext+1, yyleng-2, yyleng-1);
155*e4b17023SJohn Marino   return ARRAY;
156*e4b17023SJohn Marino }
157*e4b17023SJohn Marino "'"("\\".|[^\\])"'"		{
158*e4b17023SJohn Marino   *yylval = XDUPVAR (const char, yytext+1, yyleng-2, yyleng);
159*e4b17023SJohn Marino   return CHAR;
160*e4b17023SJohn Marino }
161*e4b17023SJohn Marino 
162*e4b17023SJohn Marino "..."				{ return ELLIPSIS; }
163*e4b17023SJohn Marino [(){},*:<>;=%|-]		{ return yytext[0]; }
164*e4b17023SJohn Marino 
165*e4b17023SJohn Marino    /* ignore pp-directives */
166*e4b17023SJohn Marino ^{HWS}"#"{HWS}[a-z_]+[^\n]*\n   {lexer_line.line++;}
167*e4b17023SJohn Marino 
168*e4b17023SJohn Marino .				{
169*e4b17023SJohn Marino   error_at_line (&lexer_line, "unexpected character `%s'", yytext);
170*e4b17023SJohn Marino }
171*e4b17023SJohn Marino }
172*e4b17023SJohn Marino 
173*e4b17023SJohn Marino "/*"			{ BEGIN(in_comment); }
174*e4b17023SJohn Marino \n			{ lexer_line.line++; }
175*e4b17023SJohn Marino {ID}			|
176*e4b17023SJohn Marino "'"("\\".|[^\\])"'"	|
177*e4b17023SJohn Marino [^"/\n]			/* do nothing */
178*e4b17023SJohn Marino \"([^"\\]|\\.|\\\n)*\"	{ update_lineno (yytext, yyleng); }
179*e4b17023SJohn Marino "/"/[^*]		/* do nothing */
180*e4b17023SJohn Marino 
181*e4b17023SJohn Marino <in_comment,in_struct_comment>{
182*e4b17023SJohn Marino \n		{ lexer_line.line++; }
183*e4b17023SJohn Marino [^*\n]{16}	|
184*e4b17023SJohn Marino [^*\n]		/* do nothing */
185*e4b17023SJohn Marino "*"/[^/]	/* do nothing */
186*e4b17023SJohn Marino }
187*e4b17023SJohn Marino <in_comment>"*/"	{ BEGIN(INITIAL); }
188*e4b17023SJohn Marino <in_struct_comment>"*/"	{ BEGIN(in_struct); }
189*e4b17023SJohn Marino 
190*e4b17023SJohn Marino ["/]    		|
191*e4b17023SJohn Marino <in_struct_comment,in_comment>"*"	{
192*e4b17023SJohn Marino   error_at_line (&lexer_line,
193*e4b17023SJohn Marino 		 "unterminated comment or string; unexpected EOF");
194*e4b17023SJohn Marino }
195*e4b17023SJohn Marino 
196*e4b17023SJohn Marino ^{HWS}"#"{HWS}"define"{WS}"GTY(" /* do nothing */
197*e4b17023SJohn Marino 
198*e4b17023SJohn Marino %%
199*e4b17023SJohn Marino 
200*e4b17023SJohn Marino void
201*e4b17023SJohn Marino yybegin (const char *fname)
202*e4b17023SJohn Marino {
203*e4b17023SJohn Marino   yyin = fopen (fname, "r");
204*e4b17023SJohn Marino   if (yyin == NULL)
205*e4b17023SJohn Marino     {
206*e4b17023SJohn Marino       perror (fname);
207*e4b17023SJohn Marino       exit (1);
208*e4b17023SJohn Marino     }
209*e4b17023SJohn Marino   lexer_line.file = input_file_by_name (fname);
210*e4b17023SJohn Marino   lexer_line.line = 1;
211*e4b17023SJohn Marino }
212*e4b17023SJohn Marino 
213*e4b17023SJohn Marino void
214*e4b17023SJohn Marino yyend (void)
215*e4b17023SJohn Marino {
216*e4b17023SJohn Marino   fclose (yyin);
217*e4b17023SJohn Marino }
218