cfg.lex 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949
  1. /*
  2. * $Id$
  3. *
  4. * scanner for cfg files
  5. *
  6. * Copyright (C) 2001-2003 FhG Fokus
  7. *
  8. * This file is part of ser, a free SIP server.
  9. *
  10. * ser is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version
  14. *
  15. * For a license to use the ser software under conditions
  16. * other than those described here, or to purchase support for this
  17. * software, please contact iptel.org by e-mail at the following addresses:
  18. * [email protected]
  19. *
  20. * ser is distributed in the hope that it will be useful,
  21. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  22. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  23. * GNU General Public License for more details.
  24. *
  25. * You should have received a copy of the GNU General Public License
  26. * along with this program; if not, write to the Free Software
  27. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  28. *
  29. * History:
  30. * -------
  31. * 2003-01-29 src_port added (jiri)
  32. * 2003-01-23 mhomed added (jiri)
  33. * 2003-03-19 replaced all the mallocs/frees w/ pkg_malloc/pkg_free (andrei)
  34. * 2003-04-01 added dst_port, proto (tcp, udp, tls), af(inet, inet6) (andrei)
  35. * 2003-04-05 s/reply_route/failure_route, onreply_route introduced (jiri)
  36. * 2003-04-12 added force_rport, chdir and wdir (andrei)
  37. * 2003-04-22 strip_tail added (jiri)
  38. * 2003-07-03 tls* (disable, certificate, private_key, ca_list, verify,
  39. * require_certificate added (andrei)
  40. * 2003-07-06 more tls config. vars added: tls_method, tls_port_no (andrei)
  41. * 2003-10-02 added {,set_}advertised_{address,port} (andrei)
  42. * 2003-10-07 added hex and octal numbers support (andrei)
  43. * 2003-10-10 replaced len_gt w/ msg:len (andrei)
  44. * 2003-10-13 added fifo_dir (andrei)
  45. * 2003-10-28 added tcp_accept_aliases (andrei)
  46. * 2003-11-29 added {tcp_send, tcp_connect, tls_*}_timeout (andrei)
  47. * 2004-03-30 added DISABLE_CORE and OPEN_FD_LIMIT (andrei)
  48. * 2004-04-28 added sock_mode (replaces fifo_mode), sock_user &
  49. * sock_group (andrei)
  50. * 2004-05-03 applied multicast support patch from janakj
  51. * added MCAST_TTL (andrei)
  52. * 2004-10-08 more escapes: \", \xHH, \nnn and minor optimizations (andrei)
  53. * 2004-10-19 added FROM_URI and TO_URI (andrei)
  54. * 2004-11-30 added force_send_socket
  55. * 2005-07-08 added tcp_connection_lifetime, tcp_poll_method,
  56. * tcp_max_connections (andrei)
  57. * 2005-07-11 added dns_retr_{time,no}, dns_servers_no, dns_use_search_list,
  58. * dns_try_ipv6 (andrei)
  59. * 2005-12-11 added onsend_route, snd_{ip,port,proto,af},
  60. * to_{ip,port} (andrei)
  61. * 2005-12-12 separated drop, exit, break, return, added RETCODE (andrei)
  62. * 2005-12-19 select framework (mma)
  63. * 2006-09-11 added dns cache (use, flags, ttls, mem ,gc) & dst blacklist
  64. * options (andrei)
  65. * 2006-10-13 added STUN_ALLOW_STUN, STUN_ALLOW_FP, STUN_REFRESH_INTERVAL
  66. * (vlada)
  67. * 2007-06-07 added SHM_FORCE_ALLOC, MLOCK_PAGES, REAL_TIME, RT_PRIO,
  68. * RT_POLICY, RT_TIMER1_PRIO, RT_TIMER1_POLICY, RT_TIMER2_PRIO,
  69. * RT_TIMER2_POLICY (andrei)
  70. * 2007-06-16 added DNS_SRV_LB, DNS_TRY_NAPTR (andrei)
  71. * 2007-06-18 added DNS_{UDP,TCP,TLS}_PREF (andrei)
  72. * 2007-09-10 introduced phone2tel option which allows NOT to consider
  73. * user=phone URIs as TEL URIs (jiri)
  74. * 2007-10-10 added DNS_SEARCH_FMATCH (mma)
  75. * 2007-11-28 added TCP_OPT_{FD_CACHE, DEFER_ACCEPT, DELAYED_ACK, SYNCNT,
  76. * LINGER2, KEEPALIVE, KEEPIDLE, KEEPINTVL, KEEPCNT} (andrei)
  77. * 2008-01-24 added CFG_DESCRIPTION used by cfg_var (Miklos)
  78. */
  79. %{
  80. #include "dprint.h"
  81. #include "globals.h"
  82. #include "mem/mem.h"
  83. #include <string.h>
  84. #include <stdlib.h>
  85. #include "ip_addr.h"
  86. #include "usr_avp.h"
  87. #include "select.h"
  88. #include "cfg.tab.h"
  89. /* states */
  90. #define INITIAL_S 0
  91. #define COMMENT_S 1
  92. #define COMMENT_LN_S 2
  93. #define STRING_S 3
  94. #define ATTR_S 4
  95. #define SELECT_S 5
  96. #define STR_BUF_ALLOC_UNIT 128
  97. struct str_buf{
  98. char* s;
  99. char* crt;
  100. int left;
  101. };
  102. static int comment_nest=0;
  103. static int state=0, old_state=0, old_initial=0;
  104. static struct str_buf s_buf;
  105. int line=1;
  106. int column=1;
  107. int startcolumn=1;
  108. static char* addchar(struct str_buf *, char);
  109. static char* addstr(struct str_buf *, char*, int);
  110. static void count();
  111. %}
  112. /* start conditions */
  113. %x STRING1 STRING2 COMMENT COMMENT_LN ATTR SELECT
  114. /* action keywords */
  115. FORWARD forward
  116. FORWARD_TCP forward_tcp
  117. FORWARD_UDP forward_udp
  118. FORWARD_TLS forward_tls
  119. FORWARD_SCTP forward_sctp
  120. DROP "drop"|"exit"
  121. RETURN "return"
  122. BREAK "break"
  123. SEND send
  124. SEND_TCP send_tcp
  125. LOG log
  126. ERROR error
  127. ROUTE route
  128. ROUTE_FAILURE failure_route
  129. ROUTE_ONREPLY onreply_route
  130. ROUTE_BRANCH branch_route
  131. ROUTE_SEND onsend_route
  132. EXEC exec
  133. FORCE_RPORT "force_rport"|"add_rport"
  134. FORCE_TCP_ALIAS "force_tcp_alias"|"add_tcp_alias"
  135. UDP_MTU "udp_mtu"
  136. UDP_MTU_TRY_PROTO "udp_mtu_try_proto"
  137. SETFLAG setflag
  138. RESETFLAG resetflag
  139. ISFLAGSET isflagset
  140. FLAGS_DECL "flags"|"bool"
  141. SETAVPFLAG setavpflag
  142. RESETAVPFLAG resetavpflag
  143. ISAVPFLAGSET isavpflagset
  144. AVPFLAGS_DECL avpflags
  145. SET_HOST "rewritehost"|"sethost"|"seth"
  146. SET_HOSTPORT "rewritehostport"|"sethostport"|"sethp"
  147. SET_HOSTPORTTRANS "rewritehostporttrans"|"sethostporttrans"|"sethpt"
  148. SET_USER "rewriteuser"|"setuser"|"setu"
  149. SET_USERPASS "rewriteuserpass"|"setuserpass"|"setup"
  150. SET_PORT "rewriteport"|"setport"|"setp"
  151. SET_URI "rewriteuri"|"seturi"
  152. REVERT_URI "revert_uri"
  153. PREFIX "prefix"
  154. STRIP "strip"
  155. STRIP_TAIL "strip_tail"
  156. APPEND_BRANCH "append_branch"
  157. IF "if"
  158. ELSE "else"
  159. SET_ADV_ADDRESS "set_advertised_address"
  160. SET_ADV_PORT "set_advertised_port"
  161. FORCE_SEND_SOCKET "force_send_socket"
  162. /*ACTION LVALUES*/
  163. URIHOST "uri:host"
  164. URIPORT "uri:port"
  165. MAX_LEN "max_len"
  166. /* condition keywords */
  167. METHOD method
  168. /* hack -- the second element in first line is referable
  169. as either uri or status; it only would makes sense to
  170. call it "uri" from route{} and status from onreply_route{}
  171. */
  172. URI "uri"|"status"
  173. FROM_URI "from_uri"
  174. TO_URI "to_uri"
  175. SRCIP src_ip
  176. SRCPORT src_port
  177. DSTIP dst_ip
  178. DSTPORT dst_port
  179. SNDIP snd_ip
  180. SNDPORT snd_port
  181. SNDPROTO snd_proto|to_proto
  182. SNDAF snd_af|to_af
  183. TOIP to_ip
  184. TOPORT to_port
  185. PROTO proto
  186. AF af
  187. MYSELF myself
  188. MSGLEN "msg:len"
  189. RETCODE \$\?|\$retcode
  190. /* operators */
  191. EQUAL =
  192. EQUAL_T ==
  193. GT >
  194. LT <
  195. GTE >=
  196. LTE <=
  197. DIFF !=
  198. MATCH =~
  199. ADDEQ "+="
  200. NOT !|"not"
  201. LOG_AND "and"|"&&"
  202. BIN_AND "&"
  203. LOG_OR "or"|"||"
  204. BIN_OR "|"
  205. PLUS "+"
  206. MINUS "-"
  207. /* Attribute specification */
  208. ATTR_MARK "$"|"%"
  209. SELECT_MARK "@"
  210. ATTR_FROM "f"
  211. ATTR_TO "t"
  212. ATTR_FROMURI "fr"
  213. ATTR_TOURI "tr"
  214. ATTR_FROMUSER "fu"
  215. ATTR_TOUSER "tu"
  216. ATTR_FROMDOMAIN "fd"
  217. ATTR_TODOMAIN "td"
  218. ATTR_GLOBAL "g"
  219. /* config vars. */
  220. DEBUG debug
  221. FORK fork
  222. LOGSTDERROR log_stderror
  223. LOGFACILITY log_facility
  224. LISTEN listen
  225. ALIAS alias
  226. DNS dns
  227. REV_DNS rev_dns
  228. DNS_TRY_IPV6 dns_try_ipv6
  229. DNS_TRY_NAPTR dns_try_naptr
  230. DNS_SRV_LB dns_srv_lb|dns_srv_loadbalancing
  231. DNS_UDP_PREF dns_udp_pref|dns_udp_preference
  232. DNS_TCP_PREF dns_tcp_pref|dns_tcp_preference
  233. DNS_TLS_PREF dns_tls_pref|dns_tls_preference
  234. DNS_SCTP_PREF dns_sctp_pref|dns_sctp_preference
  235. DNS_RETR_TIME dns_retr_time
  236. DNS_RETR_NO dns_retr_no
  237. DNS_SERVERS_NO dns_servers_no
  238. DNS_USE_SEARCH dns_use_search_list
  239. DNS_SEARCH_FMATCH dns_search_full_match
  240. /* dns cache */
  241. DNS_CACHE_INIT dns_cache_init
  242. DNS_USE_CACHE use_dns_cache
  243. DNS_USE_FAILOVER use_dns_failover
  244. DNS_CACHE_FLAGS dns_cache_flags
  245. DNS_CACHE_NEG_TTL dns_cache_negative_ttl
  246. DNS_CACHE_MIN_TTL dns_cache_min_ttl
  247. DNS_CACHE_MAX_TTL dns_cache_max_ttl
  248. DNS_CACHE_MEM dns_cache_mem
  249. DNS_CACHE_GC_INT dns_cache_gc_interval
  250. DNS_CACHE_DEL_NONEXP dns_cache_del_nonexp|dns_cache_delete_nonexpired
  251. /* blacklist */
  252. DST_BLST_INIT dst_blacklist_init
  253. USE_DST_BLST use_dst_blacklist
  254. DST_BLST_MEM dst_blacklist_mem
  255. DST_BLST_TTL dst_blacklist_expire|dst_blacklist_ttl
  256. DST_BLST_GC_INT dst_blacklist_gc_interval
  257. PORT port
  258. STAT statistics
  259. MAXBUFFER maxbuffer
  260. CHILDREN children
  261. CHECK_VIA check_via
  262. PHONE2TEL phone2tel
  263. SYN_BRANCH syn_branch
  264. MEMLOG "memlog"|"mem_log"
  265. MEMDBG "memdbg"|"mem_dbg"
  266. SIP_WARNING sip_warning
  267. SERVER_SIGNATURE server_signature
  268. REPLY_TO_VIA reply_to_via
  269. USER "user"|"uid"
  270. GROUP "group"|"gid"
  271. CHROOT "chroot"
  272. WDIR "workdir"|"wdir"
  273. MHOMED mhomed
  274. DISABLE_TCP "disable_tcp"
  275. TCP_CHILDREN "tcp_children"
  276. TCP_ACCEPT_ALIASES "tcp_accept_aliases"
  277. TCP_SEND_TIMEOUT "tcp_send_timeout"
  278. TCP_CONNECT_TIMEOUT "tcp_connect_timeout"
  279. TCP_CON_LIFETIME "tcp_connection_lifetime"
  280. TCP_POLL_METHOD "tcp_poll_method"
  281. TCP_MAX_CONNECTIONS "tcp_max_connections"
  282. TCP_SOURCE_IPV4 "tcp_source_ipv4"
  283. TCP_SOURCE_IPV6 "tcp_source_ipv6"
  284. TCP_OPT_FD_CACHE "tcp_fd_cache"
  285. TCP_OPT_BUF_WRITE "tcp_buf_write"|"tcp_async"
  286. TCP_OPT_CONN_WQ_MAX "tcp_conn_wq_max"
  287. TCP_OPT_WQ_MAX "tcp_wq_max"
  288. TCP_OPT_DEFER_ACCEPT "tcp_defer_accept"
  289. TCP_OPT_DELAYED_ACK "tcp_delayed_ack"
  290. TCP_OPT_SYNCNT "tcp_syncnt"
  291. TCP_OPT_LINGER2 "tcp_linger2"
  292. TCP_OPT_KEEPALIVE "tcp_keepalive"
  293. TCP_OPT_KEEPIDLE "tcp_keepidle"
  294. TCP_OPT_KEEPINTVL "tcp_keepintvl"
  295. TCP_OPT_KEEPCNT "tcp_keepcnt"
  296. TCP_OPT_CRLF_PING "tcp_crlf_ping"
  297. DISABLE_TLS "disable_tls"|"tls_disable"
  298. ENABLE_TLS "enable_tls"|"tls_enable"
  299. TLSLOG "tlslog"|"tls_log"
  300. TLS_PORT_NO "tls_port_no"
  301. TLS_METHOD "tls_method"
  302. TLS_VERIFY "tls_verify"
  303. TLS_REQUIRE_CERTIFICATE "tls_require_certificate"
  304. TLS_CERTIFICATE "tls_certificate"
  305. TLS_PRIVATE_KEY "tls_private_key"
  306. TLS_CA_LIST "tls_ca_list"
  307. TLS_HANDSHAKE_TIMEOUT "tls_handshake_timeout"
  308. TLS_SEND_TIMEOUT "tls_send_timeout"
  309. DISABLE_SCTP "disable_sctp"
  310. ENABLE_SCTP "enable_sctp"
  311. SCTP_CHILDREN "sctp_children"
  312. SCTP_SOCKET_RCVBUF "sctp_socket_rcvbuf"|"sctp_socket_receive_buffer"
  313. SCTP_SOCKET_SNDBUF "sctp_socket_sndbuf"|"sctp_socket_send_buffer"
  314. SCTP_AUTOCLOSE "sctp_autoclose"
  315. SCTP_SEND_TTL "sctp_send_ttl"
  316. SCTP_SEND_RETRIES "sctp_send_retries"
  317. ADVERTISED_ADDRESS "advertised_address"
  318. ADVERTISED_PORT "advertised_port"
  319. DISABLE_CORE "disable_core_dump"
  320. OPEN_FD_LIMIT "open_files_limit"
  321. SHM_FORCE_ALLOC "shm_force_alloc"
  322. MLOCK_PAGES "mlock_pages"
  323. REAL_TIME "real_time"
  324. RT_PRIO "rt_prio"
  325. RT_POLICY "rt_policy"
  326. RT_TIMER1_PRIO "rt_timer1_prio"|"rt_fast_timer_prio"|"rt_ftimer_prio"
  327. RT_TIMER1_POLICY "rt_timer1_policy"|"rt_ftimer_policy"
  328. RT_TIMER2_PRIO "rt_timer2_prio"|"rt_stimer_prio"
  329. RT_TIMER2_POLICY "rt_timer2_policy"|"rt_stimer_policy"
  330. MCAST_LOOPBACK "mcast_loopback"
  331. MCAST_TTL "mcast_ttl"
  332. TOS "tos"
  333. PMTU_DISCOVERY "pmtu_discovery"
  334. KILL_TIMEOUT "exit_timeout"|"ser_kill_timeout"
  335. /* stun config variables */
  336. STUN_REFRESH_INTERVAL "stun_refresh_interval"
  337. STUN_ALLOW_STUN "stun_allow_stun"
  338. STUN_ALLOW_FP "stun_allow_fp"
  339. SERVER_ID "server_id"
  340. CFG_DESCRIPTION "description"|"descr"|"desc"
  341. LOADMODULE loadmodule
  342. LOADPATH loadpath
  343. MODPARAM modparam
  344. /* values */
  345. YES "yes"|"true"|"on"|"enable"
  346. NO "no"|"false"|"off"|"disable"
  347. UDP "udp"|"UDP"
  348. TCP "tcp"|"TCP"
  349. TLS "tls"|"TLS"
  350. SCTP "sctp"|"SCTP"
  351. INET "inet"|"INET"
  352. INET6 "inet6"|"INET6"
  353. SSLv23 "sslv23"|"SSLv23"|"SSLV23"
  354. SSLv2 "sslv2"|"SSLv2"|"SSLV2"
  355. SSLv3 "sslv3"|"SSLv3"|"SSLV3"
  356. TLSv1 "tlsv1"|"TLSv1"|"TLSV1"
  357. LETTER [a-zA-Z]
  358. DIGIT [0-9]
  359. ALPHANUM {LETTER}|{DIGIT}|[_]
  360. ID {LETTER}{ALPHANUM}*
  361. HEX [0-9a-fA-F]
  362. HEXNUMBER 0x{HEX}+
  363. OCTNUMBER 0[0-7]+
  364. DECNUMBER 0|-?([1-9]{DIGIT}*)
  365. BINNUMBER [0-1]+b
  366. HEX4 {HEX}{1,4}
  367. IPV6ADDR ({HEX4}":"){7}{HEX4}|({HEX4}":"){1,7}(":"{HEX4}){1,7}|":"(":"{HEX4}){1,7}|({HEX4}":"){1,7}":"|"::"
  368. QUOTES \"
  369. TICK \'
  370. SLASH "/"
  371. SEMICOLON ;
  372. RPAREN \)
  373. LPAREN \(
  374. LBRACE \{
  375. RBRACE \}
  376. LBRACK \[
  377. RBRACK \]
  378. COMMA ","
  379. COLON ":"
  380. STAR \*
  381. DOT \.
  382. CR \n
  383. COM_LINE #
  384. COM_START "/\*"
  385. COM_END "\*/"
  386. EAT_ABLE [\ \t\b\r]
  387. %%
  388. <INITIAL>{EAT_ABLE} { count(); }
  389. <INITIAL>{FORWARD} {count(); yylval.strval=yytext; return FORWARD; }
  390. <INITIAL>{FORWARD_TCP} {count(); yylval.strval=yytext; return FORWARD_TCP; }
  391. <INITIAL>{FORWARD_TLS} {count(); yylval.strval=yytext; return FORWARD_TLS; }
  392. <INITIAL>{FORWARD_SCTP} {count(); yylval.strval=yytext; return FORWARD_SCTP;}
  393. <INITIAL>{FORWARD_UDP} {count(); yylval.strval=yytext; return FORWARD_UDP; }
  394. <INITIAL>{DROP} { count(); yylval.strval=yytext; return DROP; }
  395. <INITIAL>{RETURN} { count(); yylval.strval=yytext; return RETURN; }
  396. <INITIAL>{BREAK} { count(); yylval.strval=yytext; return BREAK; }
  397. <INITIAL>{SEND} { count(); yylval.strval=yytext; return SEND; }
  398. <INITIAL>{SEND_TCP} { count(); yylval.strval=yytext; return SEND_TCP; }
  399. <INITIAL>{LOG} { count(); yylval.strval=yytext; return LOG_TOK; }
  400. <INITIAL>{ERROR} { count(); yylval.strval=yytext; return ERROR; }
  401. <INITIAL>{SETFLAG} { count(); yylval.strval=yytext; return SETFLAG; }
  402. <INITIAL>{RESETFLAG} { count(); yylval.strval=yytext; return RESETFLAG; }
  403. <INITIAL>{ISFLAGSET} { count(); yylval.strval=yytext; return ISFLAGSET; }
  404. <INITIAL>{FLAGS_DECL} { count(); yylval.strval=yytext; return FLAGS_DECL; }
  405. <INITIAL>{SETAVPFLAG} { count(); yylval.strval=yytext; return SETAVPFLAG; }
  406. <INITIAL>{RESETAVPFLAG} { count(); yylval.strval=yytext; return RESETAVPFLAG; }
  407. <INITIAL>{ISAVPFLAGSET} { count(); yylval.strval=yytext; return ISAVPFLAGSET; }
  408. <INITIAL>{AVPFLAGS_DECL} { count(); yylval.strval=yytext; return AVPFLAGS_DECL; }
  409. <INITIAL>{MSGLEN} { count(); yylval.strval=yytext; return MSGLEN; }
  410. <INITIAL>{RETCODE} { count(); yylval.strval=yytext; return RETCODE; }
  411. <INITIAL>{ROUTE} { count(); yylval.strval=yytext; return ROUTE; }
  412. <INITIAL>{ROUTE_ONREPLY} { count(); yylval.strval=yytext;
  413. return ROUTE_ONREPLY; }
  414. <INITIAL>{ROUTE_FAILURE} { count(); yylval.strval=yytext;
  415. return ROUTE_FAILURE; }
  416. <INITIAL>{ROUTE_BRANCH} { count(); yylval.strval=yytext; return ROUTE_BRANCH; }
  417. <INITIAL>{ROUTE_SEND} { count(); yylval.strval=yytext; return ROUTE_SEND; }
  418. <INITIAL>{EXEC} { count(); yylval.strval=yytext; return EXEC; }
  419. <INITIAL>{SET_HOST} { count(); yylval.strval=yytext; return SET_HOST; }
  420. <INITIAL>{SET_HOSTPORT} { count(); yylval.strval=yytext; return SET_HOSTPORT; }
  421. <INITIAL>{SET_HOSTPORTTRANS} { count(); yylval.strval=yytext; return SET_HOSTPORTTRANS; }
  422. <INITIAL>{SET_USER} { count(); yylval.strval=yytext; return SET_USER; }
  423. <INITIAL>{SET_USERPASS} { count(); yylval.strval=yytext; return SET_USERPASS; }
  424. <INITIAL>{SET_PORT} { count(); yylval.strval=yytext; return SET_PORT; }
  425. <INITIAL>{SET_URI} { count(); yylval.strval=yytext; return SET_URI; }
  426. <INITIAL>{REVERT_URI} { count(); yylval.strval=yytext; return REVERT_URI; }
  427. <INITIAL>{PREFIX} { count(); yylval.strval=yytext; return PREFIX; }
  428. <INITIAL>{STRIP} { count(); yylval.strval=yytext; return STRIP; }
  429. <INITIAL>{STRIP_TAIL} { count(); yylval.strval=yytext; return STRIP_TAIL; }
  430. <INITIAL>{APPEND_BRANCH} { count(); yylval.strval=yytext;
  431. return APPEND_BRANCH; }
  432. <INITIAL>{FORCE_RPORT} { count(); yylval.strval=yytext; return FORCE_RPORT; }
  433. <INITIAL>{FORCE_TCP_ALIAS} { count(); yylval.strval=yytext;
  434. return FORCE_TCP_ALIAS; }
  435. <INITIAL>{UDP_MTU} { count(); yylval.strval=yytext; return UDP_MTU; }
  436. <INITIAL>{UDP_MTU_TRY_PROTO} { count(); yylval.strval=yytext;
  437. return UDP_MTU_TRY_PROTO; }
  438. <INITIAL>{IF} { count(); yylval.strval=yytext; return IF; }
  439. <INITIAL>{ELSE} { count(); yylval.strval=yytext; return ELSE; }
  440. <INITIAL>{SET_ADV_ADDRESS} { count(); yylval.strval=yytext;
  441. return SET_ADV_ADDRESS; }
  442. <INITIAL>{SET_ADV_PORT} { count(); yylval.strval=yytext;
  443. return SET_ADV_PORT; }
  444. <INITIAL>{FORCE_SEND_SOCKET} { count(); yylval.strval=yytext;
  445. return FORCE_SEND_SOCKET; }
  446. <INITIAL>{URIHOST} { count(); yylval.strval=yytext; return URIHOST; }
  447. <INITIAL>{URIPORT} { count(); yylval.strval=yytext; return URIPORT; }
  448. <INITIAL>{MAX_LEN} { count(); yylval.strval=yytext; return MAX_LEN; }
  449. <INITIAL>{METHOD} { count(); yylval.strval=yytext; return METHOD; }
  450. <INITIAL>{URI} { count(); yylval.strval=yytext; return URI; }
  451. <INITIAL>{FROM_URI} { count(); yylval.strval=yytext; return FROM_URI; }
  452. <INITIAL>{TO_URI} { count(); yylval.strval=yytext; return TO_URI; }
  453. <INITIAL>{SRCIP} { count(); yylval.strval=yytext; return SRCIP; }
  454. <INITIAL>{SRCPORT} { count(); yylval.strval=yytext; return SRCPORT; }
  455. <INITIAL>{DSTIP} { count(); yylval.strval=yytext; return DSTIP; }
  456. <INITIAL>{DSTPORT} { count(); yylval.strval=yytext; return DSTPORT; }
  457. <INITIAL>{SNDIP} { count(); yylval.strval=yytext; return SNDIP; }
  458. <INITIAL>{SNDPORT} { count(); yylval.strval=yytext; return SNDPORT; }
  459. <INITIAL>{SNDPROTO} { count(); yylval.strval=yytext; return SNDPROTO; }
  460. <INITIAL>{SNDAF} { count(); yylval.strval=yytext; return SNDAF; }
  461. <INITIAL>{TOIP} { count(); yylval.strval=yytext; return TOIP; }
  462. <INITIAL>{TOPORT} { count(); yylval.strval=yytext; return TOPORT; }
  463. <INITIAL>{PROTO} { count(); yylval.strval=yytext; return PROTO; }
  464. <INITIAL>{AF} { count(); yylval.strval=yytext; return AF; }
  465. <INITIAL>{MYSELF} { count(); yylval.strval=yytext; return MYSELF; }
  466. <INITIAL>{DEBUG} { count(); yylval.strval=yytext; return DEBUG_V; }
  467. <INITIAL>{FORK} { count(); yylval.strval=yytext; return FORK; }
  468. <INITIAL>{LOGSTDERROR} { yylval.strval=yytext; return LOGSTDERROR; }
  469. <INITIAL>{LOGFACILITY} { yylval.strval=yytext; return LOGFACILITY; }
  470. <INITIAL>{LISTEN} { count(); yylval.strval=yytext; return LISTEN; }
  471. <INITIAL>{ALIAS} { count(); yylval.strval=yytext; return ALIAS; }
  472. <INITIAL>{DNS} { count(); yylval.strval=yytext; return DNS; }
  473. <INITIAL>{REV_DNS} { count(); yylval.strval=yytext; return REV_DNS; }
  474. <INITIAL>{DNS_TRY_IPV6} { count(); yylval.strval=yytext;
  475. return DNS_TRY_IPV6; }
  476. <INITIAL>{DNS_TRY_NAPTR} { count(); yylval.strval=yytext;
  477. return DNS_TRY_NAPTR; }
  478. <INITIAL>{DNS_SRV_LB} { count(); yylval.strval=yytext;
  479. return DNS_SRV_LB; }
  480. <INITIAL>{DNS_UDP_PREF} { count(); yylval.strval=yytext;
  481. return DNS_UDP_PREF; }
  482. <INITIAL>{DNS_TCP_PREF} { count(); yylval.strval=yytext;
  483. return DNS_TCP_PREF; }
  484. <INITIAL>{DNS_TLS_PREF} { count(); yylval.strval=yytext;
  485. return DNS_TLS_PREF; }
  486. <INITIAL>{DNS_SCTP_PREF} { count(); yylval.strval=yytext;
  487. return DNS_SCTP_PREF; }
  488. <INITIAL>{DNS_RETR_TIME} { count(); yylval.strval=yytext;
  489. return DNS_RETR_TIME; }
  490. <INITIAL>{DNS_RETR_NO} { count(); yylval.strval=yytext;
  491. return DNS_RETR_NO; }
  492. <INITIAL>{DNS_SERVERS_NO} { count(); yylval.strval=yytext;
  493. return DNS_SERVERS_NO; }
  494. <INITIAL>{DNS_USE_SEARCH} { count(); yylval.strval=yytext;
  495. return DNS_USE_SEARCH; }
  496. <INITIAL>{DNS_SEARCH_FMATCH} { count(); yylval.strval=yytext;
  497. return DNS_SEARCH_FMATCH; }
  498. <INITIAL>{DNS_CACHE_INIT} { count(); yylval.strval=yytext;
  499. return DNS_CACHE_INIT; }
  500. <INITIAL>{DNS_USE_CACHE} { count(); yylval.strval=yytext;
  501. return DNS_USE_CACHE; }
  502. <INITIAL>{DNS_USE_FAILOVER} { count(); yylval.strval=yytext;
  503. return DNS_USE_FAILOVER; }
  504. <INITIAL>{DNS_CACHE_FLAGS} { count(); yylval.strval=yytext;
  505. return DNS_CACHE_FLAGS; }
  506. <INITIAL>{DNS_CACHE_NEG_TTL} { count(); yylval.strval=yytext;
  507. return DNS_CACHE_NEG_TTL; }
  508. <INITIAL>{DNS_CACHE_MIN_TTL} { count(); yylval.strval=yytext;
  509. return DNS_CACHE_MIN_TTL; }
  510. <INITIAL>{DNS_CACHE_MAX_TTL} { count(); yylval.strval=yytext;
  511. return DNS_CACHE_MAX_TTL; }
  512. <INITIAL>{DNS_CACHE_MEM} { count(); yylval.strval=yytext;
  513. return DNS_CACHE_MEM; }
  514. <INITIAL>{DNS_CACHE_GC_INT} { count(); yylval.strval=yytext;
  515. return DNS_CACHE_GC_INT; }
  516. <INITIAL>{DNS_CACHE_DEL_NONEXP} { count(); yylval.strval=yytext;
  517. return DNS_CACHE_DEL_NONEXP; }
  518. <INITIAL>{DST_BLST_INIT} { count(); yylval.strval=yytext;
  519. return DST_BLST_INIT; }
  520. <INITIAL>{USE_DST_BLST} { count(); yylval.strval=yytext;
  521. return USE_DST_BLST; }
  522. <INITIAL>{DST_BLST_MEM} { count(); yylval.strval=yytext;
  523. return DST_BLST_MEM; }
  524. <INITIAL>{DST_BLST_TTL} { count(); yylval.strval=yytext;
  525. return DST_BLST_TTL; }
  526. <INITIAL>{DST_BLST_GC_INT} { count(); yylval.strval=yytext;
  527. return DST_BLST_GC_INT; }
  528. <INITIAL>{PORT} { count(); yylval.strval=yytext; return PORT; }
  529. <INITIAL>{STAT} { count(); yylval.strval=yytext; return STAT; }
  530. <INITIAL>{MAXBUFFER} { count(); yylval.strval=yytext; return MAXBUFFER; }
  531. <INITIAL>{CHILDREN} { count(); yylval.strval=yytext; return CHILDREN; }
  532. <INITIAL>{CHECK_VIA} { count(); yylval.strval=yytext; return CHECK_VIA; }
  533. <INITIAL>{PHONE2TEL} { count(); yylval.strval=yytext; return PHONE2TEL; }
  534. <INITIAL>{SYN_BRANCH} { count(); yylval.strval=yytext; return SYN_BRANCH; }
  535. <INITIAL>{MEMLOG} { count(); yylval.strval=yytext; return MEMLOG; }
  536. <INITIAL>{MEMDBG} { count(); yylval.strval=yytext; return MEMDBG; }
  537. <INITIAL>{SIP_WARNING} { count(); yylval.strval=yytext; return SIP_WARNING; }
  538. <INITIAL>{USER} { count(); yylval.strval=yytext; return USER; }
  539. <INITIAL>{GROUP} { count(); yylval.strval=yytext; return GROUP; }
  540. <INITIAL>{CHROOT} { count(); yylval.strval=yytext; return CHROOT; }
  541. <INITIAL>{WDIR} { count(); yylval.strval=yytext; return WDIR; }
  542. <INITIAL>{MHOMED} { count(); yylval.strval=yytext; return MHOMED; }
  543. <INITIAL>{DISABLE_TCP} { count(); yylval.strval=yytext; return DISABLE_TCP; }
  544. <INITIAL>{TCP_CHILDREN} { count(); yylval.strval=yytext; return TCP_CHILDREN; }
  545. <INITIAL>{TCP_ACCEPT_ALIASES} { count(); yylval.strval=yytext;
  546. return TCP_ACCEPT_ALIASES; }
  547. <INITIAL>{TCP_SEND_TIMEOUT} { count(); yylval.strval=yytext;
  548. return TCP_SEND_TIMEOUT; }
  549. <INITIAL>{TCP_CONNECT_TIMEOUT} { count(); yylval.strval=yytext;
  550. return TCP_CONNECT_TIMEOUT; }
  551. <INITIAL>{TCP_CON_LIFETIME} { count(); yylval.strval=yytext;
  552. return TCP_CON_LIFETIME; }
  553. <INITIAL>{TCP_POLL_METHOD} { count(); yylval.strval=yytext;
  554. return TCP_POLL_METHOD; }
  555. <INITIAL>{TCP_MAX_CONNECTIONS} { count(); yylval.strval=yytext;
  556. return TCP_MAX_CONNECTIONS; }
  557. <INITIAL>{TCP_SOURCE_IPV4} { count(); yylval.strval=yytext;
  558. return TCP_SOURCE_IPV4; }
  559. <INITIAL>{TCP_SOURCE_IPV6} { count(); yylval.strval=yytext;
  560. return TCP_SOURCE_IPV6; }
  561. <INITIAL>{TCP_OPT_FD_CACHE} { count(); yylval.strval=yytext;
  562. return TCP_OPT_FD_CACHE; }
  563. <INITIAL>{TCP_OPT_CONN_WQ_MAX} { count(); yylval.strval=yytext;
  564. return TCP_OPT_CONN_WQ_MAX; }
  565. <INITIAL>{TCP_OPT_WQ_MAX} { count(); yylval.strval=yytext;
  566. return TCP_OPT_WQ_MAX; }
  567. <INITIAL>{TCP_OPT_BUF_WRITE} { count(); yylval.strval=yytext;
  568. return TCP_OPT_BUF_WRITE; }
  569. <INITIAL>{TCP_OPT_DEFER_ACCEPT} { count(); yylval.strval=yytext;
  570. return TCP_OPT_DEFER_ACCEPT; }
  571. <INITIAL>{TCP_OPT_DELAYED_ACK} { count(); yylval.strval=yytext;
  572. return TCP_OPT_DELAYED_ACK; }
  573. <INITIAL>{TCP_OPT_SYNCNT} { count(); yylval.strval=yytext;
  574. return TCP_OPT_SYNCNT; }
  575. <INITIAL>{TCP_OPT_LINGER2} { count(); yylval.strval=yytext;
  576. return TCP_OPT_LINGER2; }
  577. <INITIAL>{TCP_OPT_KEEPALIVE} { count(); yylval.strval=yytext;
  578. return TCP_OPT_KEEPALIVE; }
  579. <INITIAL>{TCP_OPT_KEEPIDLE} { count(); yylval.strval=yytext;
  580. return TCP_OPT_KEEPIDLE; }
  581. <INITIAL>{TCP_OPT_KEEPINTVL} { count(); yylval.strval=yytext;
  582. return TCP_OPT_KEEPINTVL; }
  583. <INITIAL>{TCP_OPT_KEEPCNT} { count(); yylval.strval=yytext;
  584. return TCP_OPT_KEEPCNT; }
  585. <INITIAL>{TCP_OPT_CRLF_PING} { count(); yylval.strval=yytext;
  586. return TCP_OPT_CRLF_PING; }
  587. <INITIAL>{DISABLE_TLS} { count(); yylval.strval=yytext; return DISABLE_TLS; }
  588. <INITIAL>{ENABLE_TLS} { count(); yylval.strval=yytext; return ENABLE_TLS; }
  589. <INITIAL>{TLSLOG} { count(); yylval.strval=yytext; return TLS_PORT_NO; }
  590. <INITIAL>{TLS_PORT_NO} { count(); yylval.strval=yytext; return TLS_PORT_NO; }
  591. <INITIAL>{TLS_METHOD} { count(); yylval.strval=yytext; return TLS_METHOD; }
  592. <INITIAL>{TLS_VERIFY} { count(); yylval.strval=yytext; return TLS_VERIFY; }
  593. <INITIAL>{TLS_REQUIRE_CERTIFICATE} { count(); yylval.strval=yytext;
  594. return TLS_REQUIRE_CERTIFICATE; }
  595. <INITIAL>{TLS_CERTIFICATE} { count(); yylval.strval=yytext;
  596. return TLS_CERTIFICATE; }
  597. <INITIAL>{TLS_PRIVATE_KEY} { count(); yylval.strval=yytext;
  598. return TLS_PRIVATE_KEY; }
  599. <INITIAL>{TLS_CA_LIST} { count(); yylval.strval=yytext;
  600. return TLS_CA_LIST; }
  601. <INITIAL>{TLS_HANDSHAKE_TIMEOUT} { count(); yylval.strval=yytext;
  602. return TLS_HANDSHAKE_TIMEOUT; }
  603. <INITIAL>{TLS_SEND_TIMEOUT} { count(); yylval.strval=yytext;
  604. return TLS_SEND_TIMEOUT; }
  605. <INITIAL>{DISABLE_SCTP} { count(); yylval.strval=yytext; return DISABLE_SCTP;}
  606. <INITIAL>{ENABLE_SCTP} { count(); yylval.strval=yytext; return ENABLE_SCTP;}
  607. <INITIAL>{SCTP_CHILDREN} { count(); yylval.strval=yytext;
  608. return SCTP_CHILDREN; }
  609. <INITIAL>{SCTP_SOCKET_RCVBUF} { count(); yylval.strval=yytext;
  610. return SCTP_SOCKET_RCVBUF; }
  611. <INITIAL>{SCTP_SOCKET_SNDBUF} { count(); yylval.strval=yytext;
  612. return SCTP_SOCKET_SNDBUF; }
  613. <INITIAL>{SCTP_AUTOCLOSE} { count(); yylval.strval=yytext;
  614. return SCTP_AUTOCLOSE; }
  615. <INITIAL>{SCTP_SEND_TTL} { count(); yylval.strval=yytext;
  616. return SCTP_SEND_TTL; }
  617. <INITIAL>{SCTP_SEND_RETRIES} { count(); yylval.strval=yytext;
  618. return SCTP_SEND_RETRIES; }
  619. <INITIAL>{SERVER_SIGNATURE} { count(); yylval.strval=yytext; return SERVER_SIGNATURE; }
  620. <INITIAL>{REPLY_TO_VIA} { count(); yylval.strval=yytext; return REPLY_TO_VIA; }
  621. <INITIAL>{ADVERTISED_ADDRESS} { count(); yylval.strval=yytext;
  622. return ADVERTISED_ADDRESS; }
  623. <INITIAL>{ADVERTISED_PORT} { count(); yylval.strval=yytext;
  624. return ADVERTISED_PORT; }
  625. <INITIAL>{DISABLE_CORE} { count(); yylval.strval=yytext;
  626. return DISABLE_CORE; }
  627. <INITIAL>{OPEN_FD_LIMIT} { count(); yylval.strval=yytext;
  628. return OPEN_FD_LIMIT; }
  629. <INITIAL>{SHM_FORCE_ALLOC} { count(); yylval.strval=yytext;
  630. return SHM_FORCE_ALLOC; }
  631. <INITIAL>{MLOCK_PAGES} { count(); yylval.strval=yytext;
  632. return MLOCK_PAGES; }
  633. <INITIAL>{REAL_TIME} { count(); yylval.strval=yytext;
  634. return REAL_TIME; }
  635. <INITIAL>{RT_PRIO} { count(); yylval.strval=yytext;
  636. return RT_PRIO; }
  637. <INITIAL>{RT_POLICY} { count(); yylval.strval=yytext;
  638. return RT_POLICY; }
  639. <INITIAL>{RT_TIMER1_PRIO} { count(); yylval.strval=yytext;
  640. return RT_TIMER1_PRIO; }
  641. <INITIAL>{RT_TIMER1_POLICY} { count(); yylval.strval=yytext;
  642. return RT_TIMER1_POLICY; }
  643. <INITIAL>{RT_TIMER2_PRIO} { count(); yylval.strval=yytext;
  644. return RT_TIMER2_PRIO; }
  645. <INITIAL>{RT_TIMER2_POLICY} { count(); yylval.strval=yytext;
  646. return RT_TIMER2_POLICY; }
  647. <INITIAL>{MCAST_LOOPBACK} { count(); yylval.strval=yytext;
  648. return MCAST_LOOPBACK; }
  649. <INITIAL>{MCAST_TTL} { count(); yylval.strval=yytext;
  650. return MCAST_TTL; }
  651. <INITIAL>{TOS} { count(); yylval.strval=yytext;
  652. return TOS; }
  653. <INITIAL>{PMTU_DISCOVERY} { count(); yylval.strval=yytext;
  654. return PMTU_DISCOVERY; }
  655. <INITIAL>{KILL_TIMEOUT} { count(); yylval.strval=yytext;
  656. return KILL_TIMEOUT; }
  657. <INITIAL>{SERVER_ID} { count(); yylval.strval=yytext; return SERVER_ID;}
  658. <INITIAL>{CFG_DESCRIPTION} { count(); yylval.strval=yytext; return CFG_DESCRIPTION; }
  659. <INITIAL>{LOADMODULE} { count(); yylval.strval=yytext; return LOADMODULE; }
  660. <INITIAL>{LOADPATH} { count(); yylval.strval=yytext; return LOADPATH; }
  661. <INITIAL>{MODPARAM} { count(); yylval.strval=yytext; return MODPARAM; }
  662. <INITIAL>{STUN_REFRESH_INTERVAL} { count(); yylval.strval=yytext; return STUN_REFRESH_INTERVAL;}
  663. <INITIAL>{STUN_ALLOW_STUN} { count(); yylval.strval=yytext; return STUN_ALLOW_STUN;}
  664. <INITIAL>{STUN_ALLOW_FP} { count(); yylval.strval=yytext; return STUN_ALLOW_FP;}
  665. <INITIAL>{EQUAL} { count(); return EQUAL; }
  666. <INITIAL>{ADDEQ} { count(); return ADDEQ; }
  667. <INITIAL>{EQUAL_T} { count(); return EQUAL_T; }
  668. <INITIAL>{GT} { count(); return GT; }
  669. <INITIAL>{LT} { count(); return LT; }
  670. <INITIAL>{GTE} { count(); return GTE; }
  671. <INITIAL>{LTE} { count(); return LTE; }
  672. <INITIAL>{DIFF} { count(); return DIFF; }
  673. <INITIAL>{MATCH} { count(); return MATCH; }
  674. <INITIAL>{NOT} { count(); return NOT; }
  675. <INITIAL>{LOG_AND} { count(); return LOG_AND; }
  676. <INITIAL>{BIN_AND} { count(); return BIN_AND; }
  677. <INITIAL>{LOG_OR} { count(); return LOG_OR; }
  678. <INITIAL>{BIN_OR} { count(); return BIN_OR; }
  679. <INITIAL>{PLUS} { count(); return PLUS; }
  680. <INITIAL>{MINUS} { count(); return MINUS; }
  681. <INITIAL>{SELECT_MARK} { count(); state = SELECT_S; BEGIN(SELECT); return SELECT_MARK; }
  682. <SELECT>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  683. yylval.strval=s_buf.s;
  684. memset(&s_buf, 0, sizeof(s_buf));
  685. return ID;
  686. }
  687. <SELECT>{DOT} { count(); return DOT; }
  688. <SELECT>{LBRACK} { count(); return LBRACK; }
  689. <SELECT>{RBRACK} { count(); return RBRACK; }
  690. <SELECT>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  691. <SELECT>{HEXNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 16); return NUMBER; }
  692. <SELECT>{OCTNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 8); return NUMBER; }
  693. <SELECT>{BINNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 2); return NUMBER; }
  694. <INITIAL>{ATTR_MARK} { count(); state = ATTR_S; BEGIN(ATTR); return ATTR_MARK; }
  695. <ATTR>{ATTR_FROM} { count(); return ATTR_FROM; }
  696. <ATTR>{ATTR_TO} { count(); return ATTR_TO; }
  697. <ATTR>{ATTR_FROMURI} { count(); return ATTR_FROMURI; }
  698. <ATTR>{ATTR_TOURI} { count(); return ATTR_TOURI; }
  699. <ATTR>{ATTR_FROMUSER} { count(); return ATTR_FROMUSER; }
  700. <ATTR>{ATTR_TOUSER} { count(); return ATTR_TOUSER; }
  701. <ATTR>{ATTR_FROMDOMAIN} { count(); return ATTR_FROMDOMAIN; }
  702. <ATTR>{ATTR_TODOMAIN} { count(); return ATTR_TODOMAIN; }
  703. <ATTR>{ATTR_GLOBAL} { count(); return ATTR_GLOBAL; }
  704. <ATTR>{DOT} { count(); return DOT; }
  705. <ATTR>{LBRACK} { count(); return LBRACK; }
  706. <ATTR>{RBRACK} { count(); return RBRACK; }
  707. <ATTR>{STAR} { count(); return STAR; }
  708. <ATTR>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  709. <ATTR>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  710. yylval.strval=s_buf.s;
  711. memset(&s_buf, 0, sizeof(s_buf));
  712. state = INITIAL_S;
  713. BEGIN(INITIAL);
  714. return ID;
  715. }
  716. <INITIAL>{IPV6ADDR} { count(); yylval.strval=yytext; return IPV6ADDR; }
  717. <INITIAL>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  718. <INITIAL>{HEXNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 16);
  719. return NUMBER; }
  720. <INITIAL>{OCTNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 8);
  721. return NUMBER; }
  722. <INITIAL>{BINNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 2); return NUMBER; }
  723. <INITIAL>{YES} { count(); yylval.intval=1; return NUMBER; }
  724. <INITIAL>{NO} { count(); yylval.intval=0; return NUMBER; }
  725. <INITIAL>{TCP} { count(); return TCP; }
  726. <INITIAL>{UDP} { count(); return UDP; }
  727. <INITIAL>{TLS} { count(); return TLS; }
  728. <INITIAL>{SCTP} { count(); return SCTP; }
  729. <INITIAL>{INET} { count(); yylval.intval=AF_INET; return NUMBER; }
  730. <INITIAL>{INET6} { count();
  731. #ifdef USE_IPV6
  732. yylval.intval=AF_INET6;
  733. #else
  734. yylval.intval=-1; /* no match*/
  735. #endif
  736. return NUMBER; }
  737. <INITIAL>{SSLv23} { count(); yylval.strval=yytext; return SSLv23; }
  738. <INITIAL>{SSLv2} { count(); yylval.strval=yytext; return SSLv2; }
  739. <INITIAL>{SSLv3} { count(); yylval.strval=yytext; return SSLv3; }
  740. <INITIAL>{TLSv1} { count(); yylval.strval=yytext; return TLSv1; }
  741. <INITIAL>{COMMA} { count(); return COMMA; }
  742. <INITIAL>{SEMICOLON} { count(); return SEMICOLON; }
  743. <INITIAL>{COLON} { count(); return COLON; }
  744. <INITIAL>{STAR} { count(); return STAR; }
  745. <INITIAL>{RPAREN} { count(); return RPAREN; }
  746. <INITIAL>{LPAREN} { count(); return LPAREN; }
  747. <INITIAL>{LBRACE} { count(); return LBRACE; }
  748. <INITIAL>{RBRACE} { count(); return RBRACE; }
  749. <INITIAL>{LBRACK} { count(); return LBRACK; }
  750. <INITIAL>{RBRACK} { count(); return RBRACK; }
  751. <INITIAL>{SLASH} { count(); return SLASH; }
  752. <INITIAL>{DOT} { count(); return DOT; }
  753. <INITIAL>\\{CR} {count(); } /* eat the escaped CR */
  754. <INITIAL>{CR} { count();/* return CR;*/ }
  755. <INITIAL,SELECT>{QUOTES} { count(); old_initial = YY_START; old_state = state; state=STRING_S; BEGIN(STRING1); }
  756. <INITIAL>{TICK} { count(); old_initial = YY_START; old_state = state; state=STRING_S; BEGIN(STRING2); }
  757. <STRING1>{QUOTES} { count(); state=old_state; BEGIN(old_initial);
  758. yytext[yyleng-1]=0; yyleng--;
  759. addstr(&s_buf, yytext, yyleng);
  760. yylval.strval=s_buf.s;
  761. memset(&s_buf, 0, sizeof(s_buf));
  762. return STRING;
  763. }
  764. <STRING2>{TICK} { count(); state=old_state; BEGIN(old_initial);
  765. yytext[yyleng-1]=0; yyleng--;
  766. addstr(&s_buf, yytext, yyleng);
  767. yylval.strval=s_buf.s;
  768. memset(&s_buf, 0, sizeof(s_buf));
  769. return STRING;
  770. }
  771. <STRING2>.|{EAT_ABLE}|{CR} { yymore(); }
  772. <STRING1>\\n { count(); addchar(&s_buf, '\n'); }
  773. <STRING1>\\r { count(); addchar(&s_buf, '\r'); }
  774. <STRING1>\\a { count(); addchar(&s_buf, '\a'); }
  775. <STRING1>\\t { count(); addchar(&s_buf, '\t'); }
  776. <STRING1>\\{QUOTES} { count(); addchar(&s_buf, '"'); }
  777. <STRING1>\\\\ { count(); addchar(&s_buf, '\\'); }
  778. <STRING1>\\x{HEX}{1,2} { count(); addchar(&s_buf,
  779. (char)strtol(yytext+2, 0, 16)); }
  780. /* don't allow \[0-7]{1}, it will eat the backreferences from
  781. subst_uri if allowed (although everybody should use '' in subt_uri) */
  782. <STRING1>\\[0-7]{2,3} { count(); addchar(&s_buf,
  783. (char)strtol(yytext+1, 0, 8)); }
  784. <STRING1>\\{CR} { count(); } /* eat escaped CRs */
  785. <STRING1>.|{EAT_ABLE}|{CR} { addchar(&s_buf, *yytext); }
  786. <INITIAL,COMMENT>{COM_START} { count(); comment_nest++; state=COMMENT_S;
  787. BEGIN(COMMENT); }
  788. <COMMENT>{COM_END} { count(); comment_nest--;
  789. if (comment_nest==0){
  790. state=INITIAL_S;
  791. BEGIN(INITIAL);
  792. }
  793. }
  794. <COMMENT>.|{EAT_ABLE}|{CR} { count(); };
  795. <INITIAL>{COM_LINE}.*{CR} { count(); }
  796. <INITIAL>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  797. yylval.strval=s_buf.s;
  798. memset(&s_buf, 0, sizeof(s_buf));
  799. return ID; }
  800. <SELECT>. { unput(yytext[0]); state = INITIAL_S; BEGIN(INITIAL); } /* Rescan the token in INITIAL state */
  801. <<EOF>> {
  802. switch(state){
  803. case STRING_S:
  804. LOG(L_CRIT, "ERROR: cfg. parser: unexpected EOF in"
  805. " unclosed string\n");
  806. if (s_buf.s){
  807. pkg_free(s_buf.s);
  808. memset(&s_buf, 0,
  809. sizeof(s_buf));
  810. }
  811. break;
  812. case COMMENT_S:
  813. LOG(L_CRIT, "ERROR: cfg. parser: unexpected EOF:"
  814. " %d comments open\n", comment_nest);
  815. break;
  816. case COMMENT_LN_S:
  817. LOG(L_CRIT, "ERROR: unexpected EOF:"
  818. "comment line open\n");
  819. break;
  820. }
  821. return 0;
  822. }
  823. %%
  824. static char* addchar(struct str_buf* dst, char c)
  825. {
  826. return addstr(dst, &c, 1);
  827. }
  828. static char* addstr(struct str_buf* dst_b, char* src, int len)
  829. {
  830. char *tmp;
  831. unsigned size;
  832. unsigned used;
  833. if (dst_b->left<(len+1)){
  834. used=(unsigned)(dst_b->crt-dst_b->s);
  835. size=used+len+1;
  836. /* round up to next multiple */
  837. size+= STR_BUF_ALLOC_UNIT-size%STR_BUF_ALLOC_UNIT;
  838. tmp=pkg_malloc(size);
  839. if (tmp==0) goto error;
  840. if (dst_b->s){
  841. memcpy(tmp, dst_b->s, used);
  842. pkg_free(dst_b->s);
  843. }
  844. dst_b->s=tmp;
  845. dst_b->crt=dst_b->s+used;
  846. dst_b->left=size-used;
  847. }
  848. memcpy(dst_b->crt, src, len);
  849. dst_b->crt+=len;
  850. *(dst_b->crt)=0;
  851. dst_b->left-=len;
  852. return dst_b->s;
  853. error:
  854. LOG(L_CRIT, "ERROR:lex:addstr: memory allocation error\n");
  855. return 0;
  856. }
  857. static void count()
  858. {
  859. int i;
  860. startcolumn=column;
  861. for (i=0; i<yyleng;i++){
  862. if (yytext[i]=='\n'){
  863. line++;
  864. column=startcolumn=1;
  865. }else if (yytext[i]=='\t'){
  866. column++;
  867. /*column+=8 -(column%8);*/
  868. }else{
  869. column++;
  870. }
  871. }
  872. }
  873. /* replacement yywrap, removes libfl dependency */
  874. int yywrap()
  875. {
  876. return 1;
  877. }