Remove the olsr-specific duplicated types
[olsrd.git] / src / cfgparser / oscan.lex
1 %{
2
3 /*
4  * The olsr.org Optimized Link-State Routing daemon(olsrd)
5  * Copyright (c) 2004, Andreas Tonnesen(andreto@olsr.org)
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without 
9  * modification, are permitted provided that the following conditions 
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright 
13  *   notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above copyright 
15  *   notice, this list of conditions and the following disclaimer in 
16  *   the documentation and/or other materials provided with the 
17  *   distribution.
18  * * Neither the name of olsr.org, olsrd nor the names of its 
19  *   contributors may be used to endorse or promote products derived 
20  *   from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
33  * POSSIBILITY OF SUCH DAMAGE.
34  *
35  * Visit http://www.olsr.org for more information.
36  *
37  * If you find this software useful feel free to make a donation
38  * to the project. For more information see the website or contact
39  * the copyright holders.
40  *
41  */
42
43
44 #define YYSTYPE struct conf_token *
45
46 #include <stdio.h>
47 #include <stdlib.h>
48 #include <string.h>
49 #include <sys/types.h>
50 #include <sys/socket.h>
51 #include <netinet/in.h>
52 #include <arpa/inet.h>
53
54 #include "olsrd_conf.h"
55
56 #include "oparse.h"
57  
58 /* Prototypes */
59 int yyget_lineno(void);
60 FILE * yyget_in(void);
61 FILE* yyget_out(void);
62 int yyget_leng(void);
63 char *yyget_text(void);
64 void yyset_lineno(int);
65 void yyset_in(FILE *);
66 void yyset_out(FILE *);
67 int yyget_debug(void);
68 void yyset_debug(int);
69 int yylex_destroy(void);
70 int yylex(void);
71
72 static struct conf_token *get_conf_token(void);
73 static struct conf_token *get_string_token(const char * const s, const size_t n);
74 static struct conf_token *get_integer_token(const char * const s);
75 static struct conf_token *get_floating_token(const char * const s);
76 static struct conf_token *get_boolean_token(const bool b);
77
78 static struct conf_token *get_conf_token(void)
79 {
80     struct conf_token *t = calloc(1, sizeof(struct conf_token));
81     if (t == NULL) {
82         fprintf(stderr, "Cannot allocate %d bytes for an configuration token.\n", (int)sizeof(struct conf_token));
83     }
84     return t;
85 }
86
87 static struct conf_token *get_string_token(const char * const s, const size_t n)
88 {
89     struct conf_token *rv = get_conf_token();
90     if (rv != NULL) {
91         rv->string = malloc(n + 1);
92         if (rv->string == NULL) {
93           fprintf(stderr, "Cannot allocate %lu bytes for string token data.\n", (unsigned long)(n+1)); /* size_t on 64bit */
94             free(rv);
95             return NULL;
96         }
97         memcpy(rv->string, s, n);
98         rv->string[n] = '\0';
99     }
100     return rv;
101 }
102
103 static struct conf_token *_get_integer_token(int32_t i)
104 {
105     struct conf_token *rv = get_conf_token();
106     if (rv != NULL) {
107         rv->integer = i;
108     }
109     return rv;
110 }
111
112 static struct conf_token *get_integer_token(const char * const s)
113 {
114     return _get_integer_token(strtol(s, NULL, 0));
115 }
116
117 static struct conf_token *get_floating_token(const char * const s)
118 {
119     struct conf_token *rv = get_conf_token();
120     if (rv != NULL) {
121         rv->floating = 0.0;
122         sscanf(s, "%f", &rv->floating);
123     }
124     return rv;
125 }
126
127 static struct conf_token *get_boolean_token(const bool b)
128 {
129     struct conf_token *rv = get_conf_token();
130     if (rv != NULL) {
131         rv->boolean = b;
132     }
133     return rv;
134 }
135
136 %}
137
138 %option never-interactive
139 %option noalways-interactive
140 %option nomain
141 %option nostack
142 %option noyywrap
143
144 DECDIGIT [0-9]
145 FLOAT {DECDIGIT}+\.{DECDIGIT}+
146 HEX8 [a-fA-F0-9]
147 QUAD {DECDIGIT}{1,3}
148
149 IPV4ADDR {QUAD}\.{QUAD}\.{QUAD}\.{QUAD}
150
151 HEX16 {HEX8}{1,4}
152
153 IP6PAT2 ({HEX16}:){1}:({HEX16}:){0,5}{HEX16}
154 IP6PAT3 ({HEX16}:){2}:({HEX16}:){0,4}{HEX16}
155 IP6PAT4 ({HEX16}:){3}:({HEX16}:){0,3}{HEX16}
156 IP6PAT5 ({HEX16}:){4}:({HEX16}:){0,2}{HEX16}
157 IP6PAT6 ({HEX16}:){5}:({HEX16}:){0,1}{HEX16}
158 IP6PAT7 ({HEX16}:){6}:({HEX16})
159 IP6PAT1 ({HEX16}:){7}{HEX16}
160 IP6PAT8 ({HEX16}:){1,7}:
161 IP6PAT9 ::
162
163 IPV6ADDR {IP6PAT1}|{IP6PAT2}|{IP6PAT3}|{IP6PAT4}|{IP6PAT5}|{IP6PAT6}|{IP6PAT7}|{IP6PAT8}|{IP6PAT9}
164
165 %%
166
167 \s*"#".*\n {
168     current_line++;
169     return TOK_COMMENT;
170 }
171
172 \/ {
173     yylval = NULL;
174     return TOK_SLASH;
175 }
176
177 \{ {
178     yylval = NULL;
179     return TOK_OPEN;
180 }
181
182 \} {
183     yylval = NULL;
184     return TOK_CLOSE;
185 }
186
187 \"[^\"]*\" {
188     yylval = get_string_token(yytext + 1, yyleng - 2);
189     if (yylval == NULL) {
190         yyterminate();
191     }
192     return TOK_STRING;
193 }
194
195 0x{HEX8}+ {
196     yylval = get_integer_token(yytext);
197     return TOK_INTEGER;
198 }
199
200 {FLOAT} {
201     yylval = get_floating_token(yytext);
202     return TOK_FLOAT;
203 }
204
205 {IPV4ADDR} {
206     yylval = get_string_token(yytext, yyleng + 1);
207     if (yylval == NULL) {
208         yyterminate();
209     }
210     return TOK_IP4_ADDR;
211 }
212 {IPV6ADDR} {
213     yylval = get_string_token(yytext, yyleng + 1);
214     if (yylval == NULL) {
215         yyterminate();
216     }
217     return TOK_IP6_ADDR;
218 }
219
220 "default" {
221     yylval = NULL;
222     return TOK_DEFAULT;
223 }
224
225 {DECDIGIT}+ {
226     yylval = get_integer_token(yytext);
227     return TOK_INTEGER;
228 }
229
230
231 "yes" {
232     yylval = get_boolean_token(true);
233     return TOK_BOOLEAN;
234 }
235
236 "no" {
237     yylval = get_boolean_token(false);
238     return TOK_BOOLEAN;
239 }
240
241 "auto" {
242     yylval = _get_integer_token(OLSR_IP6T_AUTO);
243     return TOK_IP6TYPE;
244 }
245
246 "site-local" {
247     yylval = _get_integer_token(OLSR_IP6T_SITELOCAL);
248     return TOK_IP6TYPE;
249 }
250
251 "unique-local" {
252     yylval = _get_integer_token(OLSR_IP6T_UNIQUELOCAL);
253     return TOK_IP6TYPE;
254 }
255
256 "global" {
257     yylval = _get_integer_token(OLSR_IP6T_GLOBAL);
258     return TOK_IP6TYPE;
259 }
260
261 "Host" {
262     yylval = NULL;
263     return TOK_HOSTLABEL;
264 }
265
266 "Net" {
267     yylval = NULL;
268     return TOK_NETLABEL;
269 }
270
271 "MaxConnections" {
272     yylval = NULL;
273     return TOK_MAXIPC;
274 }
275
276 "DebugLevel" {
277     yylval = NULL;
278     return TOK_DEBUGLEVEL;
279 }
280
281 "IpVersion" {
282     yylval = NULL;
283     return TOK_IPVERSION;
284 }
285
286 "NicChgsPollInt" {
287     yylval = NULL;
288     return TOK_NICCHGSPOLLRT;
289 }
290
291 "Hna4" {
292     yylval = NULL;
293     return TOK_HNA4;
294 }
295
296 "Hna6" {
297     yylval = NULL;
298     return TOK_HNA6;
299 }
300
301 "LoadPlugin" {
302     yylval = NULL;
303     return TOK_PLUGIN;
304 }
305
306 "PlParam" {
307     yylval = NULL;
308     return TOK_PLPARAM;
309 }
310
311 "Interface" {
312     yylval = NULL;
313     return TOK_INTERFACE;
314 }
315
316 "AllowNoInt" {
317     yylval = NULL;
318     return TOK_NOINT;
319 }
320
321 "TosValue" {
322     yylval = NULL;
323     return TOK_TOS;
324 }
325
326 "RtTable" {
327   yylval = NULL;
328   return TOK_RTTABLE;
329 }
330
331 "RtTableDefault" {
332   yylval = NULL;
333   return TOK_RTTABLE_DEFAULT;
334 }
335
336 "Willingness" {
337     yylval = NULL;
338     return TOK_WILLINGNESS;
339 }
340
341 "IpcConnect" {
342     yylval = NULL;
343     return TOK_IPCCON;
344 }
345
346 "FIBMetric" {
347     yylval = NULL;
348     return TOK_FIBMETRIC;
349 }
350
351 "UseHysteresis" {
352     yylval = NULL;
353     return TOK_USEHYST;
354 }
355
356 "HystScaling" {
357     yylval = NULL;
358     return TOK_HYSTSCALE;
359 }
360
361 "HystThrHigh" {
362     yylval = NULL;
363     return TOK_HYSTUPPER;
364 }
365
366 "HystThrLow" {
367     yylval = NULL;
368     return TOK_HYSTLOWER;
369 }
370
371 "Pollrate" {
372     yylval = NULL;
373     return TOK_POLLRATE;
374 }
375
376
377 "TcRedundancy" {
378     yylval = NULL;
379     return TOK_TCREDUNDANCY;
380 }
381
382 "MprCoverage" {
383     yylval = NULL;
384     return TOK_MPRCOVERAGE;
385 }
386
387 "LinkQualityLevel" {
388     yylval = NULL;
389     return TOK_LQ_LEVEL;
390 }
391
392 "LinkQualityFishEye" {
393     yylval = NULL;
394     return TOK_LQ_FISH;
395 }
396
397 "LinkQualityDijkstraLimit" {
398     yylval = NULL;
399     return TOK_LQ_DLIMIT;
400 }
401
402 "LinkQualityAging" {
403     yylval = NULL;
404     return TOK_LQ_AGING;
405 }
406
407 "LinkQualityAlgorithm" {
408     yylval = NULL;
409     return TOK_LQ_PLUGIN;
410 }
411
412 "LinkQualityWinSize" {
413     yylval = NULL;
414     return TOK_LQ_WSIZE;
415 }
416
417 "NatThreshold" {
418     yylval = NULL;
419     return TOK_LQ_NAT_THRESH;
420 }
421
422 "LinkQualityMult" {
423     yylval = NULL;
424     return TOK_LQ_MULT;
425 }
426
427 "ClearScreen" {
428     yylval = NULL;
429     return TOK_CLEAR_SCREEN;
430 }
431
432 "Weight" {
433     yylval = NULL;
434     return TOK_IFWEIGHT;
435 }
436
437 "Ip4Broadcast" {
438     yylval = NULL;
439     return TOK_IP4BROADCAST;
440 }
441 "Ip6AddrType" {
442     yylval = NULL;
443     return TOK_IP6ADDRTYPE;
444 }
445 "Ip6MulticastSite" {
446     yylval = NULL;
447     return TOK_IP6MULTISITE;
448 }
449 "Ip6MulticastGlobal" {
450     yylval = NULL;
451     return TOK_IP6MULTIGLOBAL;
452 }
453 "HelloInterval" {
454     yylval = NULL;
455     return TOK_HELLOINT;
456 }
457 "HelloValidityTime" {
458     yylval = NULL;
459     return TOK_HELLOVAL;
460 }
461 "TcInterval" {
462     yylval = NULL;
463     return TOK_TCINT;
464 }
465 "TcValidityTime" {
466     yylval = NULL;
467     return TOK_TCVAL;
468 }
469 "MidInterval" {
470     yylval = NULL;
471     return TOK_MIDINT;
472 }
473 "MidValidityTime" {
474     yylval = NULL;
475     return TOK_MIDVAL;
476 }
477 "HnaInterval" {
478     yylval = NULL;
479     return TOK_HNAINT;
480 }
481 "HnaValidityTime" {
482     yylval = NULL;
483     return TOK_HNAVAL;
484 }
485 "AutoDetectChanges" {
486     yylval = NULL;
487     return TOK_AUTODETCHG;
488 }
489
490
491 \n|\r\n {
492     current_line++;
493 }
494
495 \ |\t
496
497 . {
498   /* Do nothing */
499   //fprintf(stderr, "Failed to parse line %d of configuration file.\n",
500   //      current_line);
501   //yyterminate();
502   //yy_fatal_error("Parsing failed.\n");
503
504   /* To avoid compiler warning (stupid...) */
505   if(0)
506     yyunput(0, NULL);
507 }
508
509 %%