ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/svn/ircd-hybrid/trunk/src/conf_lexer.l
Revision: 5805
Committed: Tue Apr 21 21:49:58 2015 UTC (8 years, 11 months ago) by michael
File size: 19701 byte(s)
Log Message:
- Removed glines
- Added kline_min_cidr, kline_min_cidr6, dline_min_cidr and
  dline_min_cidr6 configuration options

File Contents

# Content
1 /*
2 * ircd-hybrid: an advanced, lightweight Internet Relay Chat Daemon (ircd)
3 *
4 * Copyright (c) 2000-2015 ircd-hybrid development team
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
19 * USA
20 */
21
22 /*! \file ircd_lexer.l
23 * \brief Scans the ircd configuration file for tokens.
24 * \version $Id$
25 */
26
27 %option case-insensitive
28 %option noyywrap
29 %option nounput
30 %option never-interactive
31
32 %{
33 #include "stdinc.h"
34 #include "irc_string.h"
35 #include "conf.h"
36 #include "conf_parser.h" /* autogenerated header file */
37 #include "log.h"
38
39 #undef YY_INPUT
40 #define YY_FATAL_ERROR(msg) conf_yy_fatal_error(msg)
41 #define YY_INPUT(buf,result,max_size) \
42 if (!(result = conf_yy_input(buf, max_size))) \
43 YY_FATAL_ERROR("input in flex scanner failed");
44 #define MAX_INCLUDE_DEPTH 10
45
46
47 unsigned int lineno = 1;
48 char linebuf[IRCD_BUFSIZE];
49 char conffilebuf[IRCD_BUFSIZE];
50
51 static int include_stack_ptr = 0;
52 static YY_BUFFER_STATE include_stack[MAX_INCLUDE_DEPTH];
53 static unsigned int lineno_stack[MAX_INCLUDE_DEPTH];
54 static FILE *inc_fbfile_in[MAX_INCLUDE_DEPTH];
55 static char conffile_stack[MAX_INCLUDE_DEPTH][IRCD_BUFSIZE];
56 static void ccomment(void);
57 static void cinclude(void);
58 static int ieof(void);
59
60 static int
61 conf_yy_input(char *lbuf, unsigned int max_size)
62 {
63 return !fgets(lbuf, max_size, conf_parser_ctx.conf_file) ? 0 : strlen(lbuf);
64 }
65
66 static int
67 conf_yy_fatal_error(const char *msg)
68 {
69 return 0;
70 }
71
72 %}
73
74 WS [[:blank:]]*
75 DIGIT [[:digit:]]+
76 COMMENT ("//"|"#").*
77 qstring \"[^\"\n]*[\"\n]
78 include \.include{WS}(\<.*\>|\".*\")
79
80 %%
81 {include} { cinclude(); }
82 "/*" { ccomment(); }
83 \n.* { strlcpy(linebuf, yytext + 1, sizeof(linebuf)); ++lineno; yyless(1); }
84 {WS} ;
85 {COMMENT} ;
86 {DIGIT} { yylval.number = atoi(yytext); return NUMBER; }
87 {qstring} { if (yytext[yyleng - 2] == '\\')
88 {
89 yyless(yyleng - 1); /* Return last quote */
90 yymore(); /* Append next string */
91 }
92 else
93 {
94 yylval.string = yytext + 1;
95
96 if (yylval.string[yyleng - 2] != '"')
97 ilog(LOG_TYPE_IRCD, "Unterminated character string");
98 else
99 {
100 unsigned int i = 0, j = 0;
101
102 yylval.string[yyleng - 2] = '\0'; /* Remove close quote */
103
104 for (; yylval.string[i] != '\0'; ++i, ++j)
105 {
106 if (yylval.string[i] != '\\')
107 yylval.string[j] = yylval.string[i];
108 else
109 {
110 ++i;
111
112 if (yylval.string[i] == '\0') /* XXX: should not happen */
113 {
114 ilog(LOG_TYPE_IRCD, "Unterminated character string");
115 break;
116 }
117
118 yylval.string[j] = yylval.string[i];
119 }
120 }
121
122 yylval.string[j] = '\0';
123 return QSTRING;
124 }
125 }
126 }
127
128 accept_password { return ACCEPT_PASSWORD; }
129 admin { return ADMIN; }
130 administrator { return ADMIN; }
131 aftype { return AFTYPE; }
132 all { return T_ALL; }
133 anti_nick_flood { return ANTI_NICK_FLOOD; }
134 anti_spam_exit_message_time { return ANTI_SPAM_EXIT_MESSAGE_TIME; }
135 auth { return IRCD_AUTH; }
136 autoconn { return AUTOCONN; }
137 away_count { return AWAY_COUNT; }
138 away_time { return AWAY_TIME; }
139 bots { return T_BOTS; }
140 caller_id_wait { return CALLER_ID_WAIT; }
141 callerid { return T_CALLERID; }
142 can_flood { return CAN_FLOOD; }
143 cconn { return T_CCONN; }
144 channel { return CHANNEL; }
145 cidr_bitlen_ipv4 { return CIDR_BITLEN_IPV4; }
146 cidr_bitlen_ipv6 { return CIDR_BITLEN_IPV6; }
147 class { return CLASS; }
148 cluster { return T_CLUSTER; }
149 command { return T_COMMAND; }
150 connect { return CONNECT; }
151 connectfreq { return CONNECTFREQ; }
152 cycle_on_host_change { return CYCLE_ON_HOST_CHANGE; }
153 deaf { return T_DEAF; }
154 debug { return T_DEBUG; }
155 default_floodcount { return DEFAULT_FLOODCOUNT; }
156 default_join_flood_count { return DEFAULT_JOIN_FLOOD_COUNT; }
157 default_join_flood_time { return DEFAULT_JOIN_FLOOD_TIME; }
158 default_max_clients { return DEFAULT_MAX_CLIENTS; }
159 default_split_server_count { return DEFAULT_SPLIT_SERVER_COUNT; }
160 default_split_user_count { return DEFAULT_SPLIT_USER_COUNT; }
161 deny { return DENY; }
162 description { return DESCRIPTION; }
163 die { return DIE; }
164 disable_auth { return DISABLE_AUTH; }
165 disable_fake_channels { return DISABLE_FAKE_CHANNELS; }
166 disable_remote_commands { return DISABLE_REMOTE_COMMANDS; }
167 dline { return T_DLINE; }
168 dline_min_cidr { return DLINE_MIN_CIDR; }
169 dline_min_cidr6 { return DLINE_MIN_CIDR6; }
170 dots_in_ident { return DOTS_IN_IDENT; }
171 email { return EMAIL; }
172 encrypted { return ENCRYPTED; }
173 exceed_limit { return EXCEED_LIMIT; }
174 exempt { return EXEMPT; }
175 external { return T_EXTERNAL; }
176 failed_oper_notice { return FAILED_OPER_NOTICE; }
177 farconnect { return T_FARCONNECT; }
178 file { return T_FILE; }
179 flags { return IRCD_FLAGS; }
180 flatten_links { return FLATTEN_LINKS; }
181 full { return T_FULL; }
182 gecos { return GECOS; }
183 general { return GENERAL; }
184 kline_min_cidr { return KLINE_MIN_CIDR; }
185 kline_min_cidr6 { return KLINE_MIN_CIDR6; }
186 globops { return T_GLOBOPS; }
187 have_ident { return NEED_IDENT; }
188 havent_read_conf { return HAVENT_READ_CONF; }
189 hidden { return HIDDEN; }
190 hidden_name { return HIDDEN_NAME; }
191 hidechans { return HIDE_CHANS; }
192 hideidle { return HIDE_IDLE; }
193 hide_idle_from_opers { return HIDE_IDLE_FROM_OPERS; }
194 hide_server_ips { return HIDE_SERVER_IPS; }
195 hide_servers { return HIDE_SERVERS; }
196 hide_services { return HIDE_SERVICES; }
197 host { return HOST; }
198 hub { return HUB; }
199 hub_mask { return HUB_MASK; }
200 ignore_bogus_ts { return IGNORE_BOGUS_TS; }
201 invisible { return T_INVISIBLE; }
202 invisible_on_connect { return INVISIBLE_ON_CONNECT; }
203 invite_client_count { return INVITE_CLIENT_COUNT; }
204 invite_client_time { return INVITE_CLIENT_TIME; }
205 ip { return IP; }
206 ipv4 { return T_IPV4; }
207 ipv6 { return T_IPV6; }
208 kill { return KILL; }
209 kill_chase_time_limit { return KILL_CHASE_TIME_LIMIT; }
210 kline { return KLINE; }
211 kline_exempt { return KLINE_EXEMPT; }
212 knock_client_count { return KNOCK_CLIENT_COUNT; }
213 knock_client_time { return KNOCK_CLIENT_TIME; }
214 knock_delay_channel { return KNOCK_DELAY_CHANNEL; }
215 leaf_mask { return LEAF_MASK; }
216 links_delay { return LINKS_DELAY; }
217 listen { return LISTEN; }
218 locops { return T_LOCOPS; }
219 log { return T_LOG; }
220 mask { return MASK; }
221 masked { return TMASKED; }
222 max_accept { return MAX_ACCEPT; }
223 max_bans { return MAX_BANS; }
224 max_channels { return MAX_CHANNELS; }
225 max_global { return MAX_GLOBAL; }
226 max_ident { return MAX_IDENT; }
227 max_idle { return MAX_IDLE; }
228 max_local { return MAX_LOCAL; }
229 max_nick_changes { return MAX_NICK_CHANGES; }
230 max_nick_length { return MAX_NICK_LENGTH; }
231 max_nick_time { return MAX_NICK_TIME; }
232 max_number { return MAX_NUMBER; }
233 max_targets { return MAX_TARGETS; }
234 max_topic_length { return MAX_TOPIC_LENGTH; }
235 max_watch { return MAX_WATCH; }
236 min_idle { return MIN_IDLE; }
237 min_nonwildcard { return MIN_NONWILDCARD; }
238 min_nonwildcard_simple { return MIN_NONWILDCARD_SIMPLE; }
239 module { return MODULE; }
240 modules { return MODULES; }
241 motd { return MOTD; }
242 name { return NAME; }
243 nchange { return T_NCHANGE; }
244 need_ident { return NEED_IDENT; }
245 need_password { return NEED_PASSWORD; }
246 network_desc { return NETWORK_DESC; }
247 network_name { return NETWORK_NAME; }
248 nick { return NICK; }
249 no_create_on_split { return NO_CREATE_ON_SPLIT; }
250 no_join_on_split { return NO_JOIN_ON_SPLIT; }
251 no_oper_flood { return NO_OPER_FLOOD; }
252 no_tilde { return NO_TILDE; }
253 nononreg { return T_NONONREG; }
254 number_per_cidr { return NUMBER_PER_CIDR; }
255 number_per_ip { return NUMBER_PER_IP; }
256 oper { return OPERATOR; }
257 oper_only_umodes { return OPER_ONLY_UMODES; }
258 oper_pass_resv { return OPER_PASS_RESV; }
259 oper_umodes { return OPER_UMODES; }
260 operator { return OPERATOR; }
261 opers_bypass_callerid { return OPERS_BYPASS_CALLERID; }
262 opme { return T_OPME; }
263 pace_wait { return PACE_WAIT; }
264 pace_wait_simple { return PACE_WAIT_SIMPLE; }
265 passwd { return PASSWORD; }
266 password { return PASSWORD; }
267 path { return PATH; }
268 ping_cookie { return PING_COOKIE; }
269 ping_time { return PING_TIME; }
270 port { return PORT; }
271 prepend { return T_PREPEND; }
272 pseudo { return T_PSEUDO; }
273 quarantine { return RESV; }
274 random_idle { return RANDOM_IDLE; }
275 reason { return REASON; }
276 recvq { return T_RECVQ; }
277 redirport { return REDIRPORT; }
278 redirserv { return REDIRSERV; }
279 rehash { return REHASH; }
280 rej { return T_REJ; }
281 remote { return REMOTE; }
282 remoteban { return REMOTEBAN; }
283 restart { return T_RESTART; }
284 resv { return RESV; }
285 resv_exempt { return RESV_EXEMPT; }
286 rsa_private_key_file { return RSA_PRIVATE_KEY_FILE; }
287 rsa_public_key_file { return RSA_PUBLIC_KEY_FILE; }
288 send_password { return SEND_PASSWORD; }
289 sendq { return SENDQ; }
290 server { return T_SERVER; }
291 serverhide { return SERVERHIDE; }
292 serverinfo { return SERVERINFO; }
293 service { return T_SERVICE; }
294 servnotice { return T_SERVNOTICE; }
295 set { return T_SET; }
296 shared { return T_SHARED; }
297 short_motd { return SHORT_MOTD; }
298 sid { return IRCD_SID; }
299 size { return T_SIZE; }
300 skill { return T_SKILL; }
301 softcallerid { return T_SOFTCALLERID; }
302 spoof { return SPOOF; }
303 spoof_notice { return SPOOF_NOTICE; }
304 spy { return T_SPY; }
305 squit { return SQUIT; }
306 ssl { return T_SSL; }
307 ssl_certificate_file { return SSL_CERTIFICATE_FILE; }
308 ssl_certificate_fingerprint { return SSL_CERTIFICATE_FINGERPRINT; }
309 ssl_cipher_list { return T_SSL_CIPHER_LIST; }
310 ssl_connection_required { return SSL_CONNECTION_REQUIRED; }
311 ssl_dh_elliptic_curve { return SSL_DH_ELLIPTIC_CURVE; }
312 ssl_dh_param_file { return SSL_DH_PARAM_FILE; }
313 ssl_message_digest_algorithm { return SSL_MESSAGE_DIGEST_ALGORITHM; }
314 stats_e_disabled { return STATS_E_DISABLED; }
315 stats_i_oper_only { return STATS_I_OPER_ONLY; }
316 stats_k_oper_only { return STATS_K_OPER_ONLY; }
317 stats_m_oper_only { return STATS_M_OPER_ONLY; }
318 stats_o_oper_only { return STATS_O_OPER_ONLY; }
319 stats_P_oper_only { return STATS_P_OPER_ONLY; }
320 stats_u_oper_only { return STATS_U_OPER_ONLY; }
321 target { return T_TARGET; }
322 throttle_count { return THROTTLE_COUNT; }
323 throttle_time { return THROTTLE_TIME; }
324 tkline_expire_notices { return TKLINE_EXPIRE_NOTICES; }
325 ts_max_delta { return TS_MAX_DELTA; }
326 ts_warn_delta { return TS_WARN_DELTA; }
327 type { return TYPE; }
328 umodes { return T_UMODES; }
329 unauth { return T_UNAUTH; }
330 undline { return T_UNDLINE; }
331 unkline { return UNKLINE; }
332 unlimited { return T_UNLIMITED; }
333 unresv { return T_UNRESV; }
334 unxline { return T_UNXLINE; }
335 use_logging { return USE_LOGGING; }
336 user { return USER; }
337 vhost { return VHOST; }
338 vhost6 { return VHOST6; }
339 wallop { return T_WALLOP; }
340 wallops { return T_WALLOPS; }
341 warn_no_connect_block { return WARN_NO_CONNECT_BLOCK; }
342 webirc { return T_WEBIRC; }
343 whois { return WHOIS; }
344 xline { return XLINE; }
345
346 yes { yylval.number = 1; return TBOOL; }
347 no { yylval.number = 0; return TBOOL; }
348
349 years { return YEARS; }
350 year { return YEARS; }
351 months { return MONTHS; }
352 month { return MONTHS; }
353 weeks { return WEEKS; }
354 week { return WEEKS; }
355 days { return DAYS; }
356 day { return DAYS; }
357 hours { return HOURS; }
358 hour { return HOURS; }
359 minutes { return MINUTES; }
360 minute { return MINUTES; }
361 seconds { return SECONDS; }
362 second { return SECONDS; }
363
364 bytes { return BYTES; }
365 byte { return BYTES; }
366 kilobytes { return KBYTES; }
367 kilobyte { return KBYTES; }
368 kbytes { return KBYTES; }
369 kbyte { return KBYTES; }
370 kb { return KBYTES; }
371 megabytes { return MBYTES; }
372 megabyte { return MBYTES; }
373 mbytes { return MBYTES; }
374 mbyte { return MBYTES; }
375 mb { return MBYTES; }
376 \.\. { return TWODOTS; }
377
378 . { return yytext[0]; }
379 <<EOF>> { if (ieof()) yyterminate(); }
380
381 %%
382
383 /* C-comment ignoring routine -kre*/
384 static void
385 ccomment(void)
386 {
387 int c = 0;
388
389 /* log(L_NOTICE, "got comment"); */
390 while (1)
391 {
392 while ((c = input()) != '*' && c != EOF)
393 if (c == '\n')
394 ++lineno;
395
396 if (c == '*')
397 {
398 while ((c = input()) == '*')
399 /* Nothing */ ;
400 if (c == '/')
401 break;
402 else if (c == '\n')
403 ++lineno;
404 }
405
406 if (c == EOF)
407 {
408 YY_FATAL_ERROR("EOF in comment");
409 /* XXX hack alert this disables
410 * the stupid unused function warning
411 * gcc generates
412 */
413 if (1 == 0)
414 yy_fatal_error("EOF in comment");
415 break;
416 }
417 }
418 }
419
420 /* C-style .includes. This function will properly swap input conf buffers,
421 * and lineno -kre */
422 static void
423 cinclude(void)
424 {
425 char *p = NULL;
426
427 if ((p = strchr(yytext, '<')) == NULL)
428 *strchr(p = strchr(yytext, '"') + 1, '"') = '\0';
429 else
430 *strchr(++p, '>') = '\0';
431
432 /* log(L_NOTICE, "got include %s!", c); */
433
434 /* do stacking and co. */
435 if (include_stack_ptr >= MAX_INCLUDE_DEPTH)
436 ilog(LOG_TYPE_IRCD, "Includes nested too deep in %s", p);
437 else
438 {
439 FILE *tmp_fbfile_in = NULL;
440 char filenamebuf[IRCD_BUFSIZE];
441
442 if (*p == '/') /* if it is an absolute path */
443 snprintf(filenamebuf, sizeof(filenamebuf), "%s", p);
444 else
445 snprintf(filenamebuf, sizeof(filenamebuf), "%s/%s", ETCPATH, p);
446
447 tmp_fbfile_in = fopen(filenamebuf, "r");
448
449 if (tmp_fbfile_in == NULL)
450 {
451 ilog(LOG_TYPE_IRCD, "Unable to read configuration file '%s': %s",
452 filenamebuf, strerror(errno));
453 return;
454 }
455
456 lineno_stack[include_stack_ptr] = lineno;
457 lineno = 1;
458 inc_fbfile_in[include_stack_ptr] = conf_parser_ctx.conf_file;
459 strlcpy(conffile_stack[include_stack_ptr], conffilebuf, IRCD_BUFSIZE);
460 include_stack[include_stack_ptr++] = YY_CURRENT_BUFFER;
461 conf_parser_ctx.conf_file = tmp_fbfile_in;
462 snprintf(conffilebuf, sizeof(conffilebuf), "%s", filenamebuf);
463 yy_switch_to_buffer(yy_create_buffer(yyin, YY_BUF_SIZE));
464 }
465 }
466
467 /* This is function that will be called on EOF in conf file. It will
468 * apropriately close conf if it not main conf and swap input buffers -kre
469 * */
470 static int
471 ieof(void)
472 {
473 /* log(L_NOTICE, "return from include stack!"); */
474 if (include_stack_ptr)
475 fclose(conf_parser_ctx.conf_file);
476 if (--include_stack_ptr < 0)
477 {
478 /* log(L_NOTICE, "terminating lexer"); */
479 /* We will now exit the lexer - restore init values if we get /rehash
480 * later and reenter lexer -kre */
481 include_stack_ptr = 0;
482 lineno = 1;
483 return 1;
484 }
485
486 /* switch buffer */
487 /* log(L_NOTICE, "deleting include_stack_ptr=%d", include_stack_ptr); */
488 yy_delete_buffer(YY_CURRENT_BUFFER);
489 lineno = lineno_stack[include_stack_ptr];
490 conf_parser_ctx.conf_file = inc_fbfile_in[include_stack_ptr];
491 strlcpy(conffilebuf, conffile_stack[include_stack_ptr], sizeof(conffilebuf));
492 yy_switch_to_buffer(include_stack[include_stack_ptr]);
493
494 return 0;
495 }

Properties

Name Value
svn:eol-style native
svn:keywords Id Revision