cfg.lex 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905
  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. DROP "drop"|"exit"
  120. RETURN "return"
  121. BREAK "break"
  122. SEND send
  123. SEND_TCP send_tcp
  124. LOG log
  125. ERROR error
  126. ROUTE route
  127. ROUTE_FAILURE failure_route
  128. ROUTE_ONREPLY onreply_route
  129. ROUTE_BRANCH branch_route
  130. ROUTE_SEND onsend_route
  131. EXEC exec
  132. FORCE_RPORT "force_rport"|"add_rport"
  133. FORCE_TCP_ALIAS "force_tcp_alias"|"add_tcp_alias"
  134. SETFLAG setflag
  135. RESETFLAG resetflag
  136. ISFLAGSET isflagset
  137. FLAGS_DECL "flags"|"bool"
  138. SETAVPFLAG setavpflag
  139. RESETAVPFLAG resetavpflag
  140. ISAVPFLAGSET isavpflagset
  141. AVPFLAGS_DECL avpflags
  142. SET_HOST "rewritehost"|"sethost"|"seth"
  143. SET_HOSTPORT "rewritehostport"|"sethostport"|"sethp"
  144. SET_USER "rewriteuser"|"setuser"|"setu"
  145. SET_USERPASS "rewriteuserpass"|"setuserpass"|"setup"
  146. SET_PORT "rewriteport"|"setport"|"setp"
  147. SET_URI "rewriteuri"|"seturi"
  148. REVERT_URI "revert_uri"
  149. PREFIX "prefix"
  150. STRIP "strip"
  151. STRIP_TAIL "strip_tail"
  152. APPEND_BRANCH "append_branch"
  153. IF "if"
  154. ELSE "else"
  155. SET_ADV_ADDRESS "set_advertised_address"
  156. SET_ADV_PORT "set_advertised_port"
  157. FORCE_SEND_SOCKET "force_send_socket"
  158. /*ACTION LVALUES*/
  159. URIHOST "uri:host"
  160. URIPORT "uri:port"
  161. MAX_LEN "max_len"
  162. /* condition keywords */
  163. METHOD method
  164. /* hack -- the second element in first line is referable
  165. as either uri or status; it only would makes sense to
  166. call it "uri" from route{} and status from onreply_route{}
  167. */
  168. URI "uri"|"status"
  169. FROM_URI "from_uri"
  170. TO_URI "to_uri"
  171. SRCIP src_ip
  172. SRCPORT src_port
  173. DSTIP dst_ip
  174. DSTPORT dst_port
  175. SNDIP snd_ip
  176. SNDPORT snd_port
  177. SNDPROTO snd_proto|to_proto
  178. SNDAF snd_af|to_af
  179. TOIP to_ip
  180. TOPORT to_port
  181. PROTO proto
  182. AF af
  183. MYSELF myself
  184. MSGLEN "msg:len"
  185. RETCODE \$\?|\$retcode
  186. /* operators */
  187. EQUAL =
  188. EQUAL_T ==
  189. GT >
  190. LT <
  191. GTE >=
  192. LTE <=
  193. DIFF !=
  194. MATCH =~
  195. ADDEQ "+="
  196. NOT !|"not"
  197. LOG_AND "and"|"&&"
  198. BIN_AND "&"
  199. LOG_OR "or"|"||"
  200. BIN_OR "|"
  201. PLUS "+"
  202. MINUS "-"
  203. /* Attribute specification */
  204. ATTR_MARK "$"|"%"
  205. SELECT_MARK "@"
  206. ATTR_FROM "f"
  207. ATTR_TO "t"
  208. ATTR_FROMURI "fr"
  209. ATTR_TOURI "tr"
  210. ATTR_FROMUSER "fu"
  211. ATTR_TOUSER "tu"
  212. ATTR_FROMDOMAIN "fd"
  213. ATTR_TODOMAIN "td"
  214. ATTR_GLOBAL "g"
  215. /* config vars. */
  216. DEBUG debug
  217. FORK fork
  218. LOGSTDERROR log_stderror
  219. LOGFACILITY log_facility
  220. LISTEN listen
  221. ALIAS alias
  222. DNS dns
  223. REV_DNS rev_dns
  224. DNS_TRY_IPV6 dns_try_ipv6
  225. DNS_TRY_NAPTR dns_try_naptr
  226. DNS_SRV_LB dns_srv_lb|dns_srv_loadbalancing
  227. DNS_UDP_PREF dns_udp_pref|dns_udp_preference
  228. DNS_TCP_PREF dns_tcp_pref|dns_tcp_preference
  229. DNS_TLS_PREF dns_tls_pref|dns_tls_preference
  230. DNS_RETR_TIME dns_retr_time
  231. DNS_RETR_NO dns_retr_no
  232. DNS_SERVERS_NO dns_servers_no
  233. DNS_USE_SEARCH dns_use_search_list
  234. DNS_SEARCH_FMATCH dns_search_full_match
  235. /* dns cache */
  236. DNS_CACHE_INIT dns_cache_init
  237. DNS_USE_CACHE use_dns_cache
  238. DNS_USE_FAILOVER use_dns_failover
  239. DNS_CACHE_FLAGS dns_cache_flags
  240. DNS_CACHE_NEG_TTL dns_cache_negative_ttl
  241. DNS_CACHE_MIN_TTL dns_cache_min_ttl
  242. DNS_CACHE_MAX_TTL dns_cache_max_ttl
  243. DNS_CACHE_MEM dns_cache_mem
  244. DNS_CACHE_GC_INT dns_cache_gc_interval
  245. DNS_CACHE_DEL_NONEXP dns_cache_del_nonexp|dns_cache_delete_nonexpired
  246. /* blacklist */
  247. DST_BLST_INIT dst_blacklist_init
  248. USE_DST_BLST use_dst_blacklist
  249. DST_BLST_MEM dst_blacklist_mem
  250. DST_BLST_TTL dst_blacklist_expire|dst_blacklist_ttl
  251. DST_BLST_GC_INT dst_blacklist_gc_interval
  252. PORT port
  253. STAT statistics
  254. MAXBUFFER maxbuffer
  255. CHILDREN children
  256. CHECK_VIA check_via
  257. PHONE2TEL phone2tel
  258. SYN_BRANCH syn_branch
  259. MEMLOG "memlog"|"mem_log"
  260. MEMDBG "memdbg"|"mem_dbg"
  261. SIP_WARNING sip_warning
  262. SERVER_SIGNATURE server_signature
  263. REPLY_TO_VIA reply_to_via
  264. USER "user"|"uid"
  265. GROUP "group"|"gid"
  266. CHROOT "chroot"
  267. WDIR "workdir"|"wdir"
  268. MHOMED mhomed
  269. DISABLE_TCP "disable_tcp"
  270. TCP_CHILDREN "tcp_children"
  271. TCP_ACCEPT_ALIASES "tcp_accept_aliases"
  272. TCP_SEND_TIMEOUT "tcp_send_timeout"
  273. TCP_CONNECT_TIMEOUT "tcp_connect_timeout"
  274. TCP_CON_LIFETIME "tcp_connection_lifetime"
  275. TCP_POLL_METHOD "tcp_poll_method"
  276. TCP_MAX_CONNECTIONS "tcp_max_connections"
  277. TCP_SOURCE_IPV4 "tcp_source_ipv4"
  278. TCP_SOURCE_IPV6 "tcp_source_ipv6"
  279. TCP_OPT_FD_CACHE "tcp_fd_cache"
  280. TCP_OPT_BUF_WRITE "tcp_buf_write"
  281. TCP_OPT_CONN_WQ_MAX "tcp_conn_wq_max"
  282. TCP_OPT_WQ_MAX "tcp_wq_max"
  283. TCP_OPT_DEFER_ACCEPT "tcp_defer_accept"
  284. TCP_OPT_DELAYED_ACK "tcp_delayed_ack"
  285. TCP_OPT_SYNCNT "tcp_syncnt"
  286. TCP_OPT_LINGER2 "tcp_linger2"
  287. TCP_OPT_KEEPALIVE "tcp_keepalive"
  288. TCP_OPT_KEEPIDLE "tcp_keepidle"
  289. TCP_OPT_KEEPINTVL "tcp_keepintvl"
  290. TCP_OPT_KEEPCNT "tcp_keepcnt"
  291. DISABLE_TLS "disable_tls"|"tls_disable"
  292. ENABLE_TLS "enable_tls"|"tls_enable"
  293. TLSLOG "tlslog"|"tls_log"
  294. TLS_PORT_NO "tls_port_no"
  295. TLS_METHOD "tls_method"
  296. TLS_VERIFY "tls_verify"
  297. TLS_REQUIRE_CERTIFICATE "tls_require_certificate"
  298. TLS_CERTIFICATE "tls_certificate"
  299. TLS_PRIVATE_KEY "tls_private_key"
  300. TLS_CA_LIST "tls_ca_list"
  301. TLS_HANDSHAKE_TIMEOUT "tls_handshake_timeout"
  302. TLS_SEND_TIMEOUT "tls_send_timeout"
  303. ADVERTISED_ADDRESS "advertised_address"
  304. ADVERTISED_PORT "advertised_port"
  305. DISABLE_CORE "disable_core_dump"
  306. OPEN_FD_LIMIT "open_files_limit"
  307. SHM_FORCE_ALLOC "shm_force_alloc"
  308. MLOCK_PAGES "mlock_pages"
  309. REAL_TIME "real_time"
  310. RT_PRIO "rt_prio"
  311. RT_POLICY "rt_policy"
  312. RT_TIMER1_PRIO "rt_timer1_prio"|"rt_fast_timer_prio"|"rt_ftimer_prio"
  313. RT_TIMER1_POLICY "rt_timer1_policy"|"rt_ftimer_policy"
  314. RT_TIMER2_PRIO "rt_timer2_prio"|"rt_stimer_prio"
  315. RT_TIMER2_POLICY "rt_timer2_policy"|"rt_stimer_policy"
  316. MCAST_LOOPBACK "mcast_loopback"
  317. MCAST_TTL "mcast_ttl"
  318. TOS "tos"
  319. PMTU_DISCOVERY "pmtu_discovery"
  320. KILL_TIMEOUT "exit_timeout"|"ser_kill_timeout"
  321. /* stun config variables */
  322. STUN_REFRESH_INTERVAL "stun_refresh_interval"
  323. STUN_ALLOW_STUN "stun_allow_stun"
  324. STUN_ALLOW_FP "stun_allow_fp"
  325. CFG_DESCRIPTION "description"|"descr"|"desc"
  326. LOADMODULE loadmodule
  327. MODPARAM modparam
  328. /* values */
  329. YES "yes"|"true"|"on"|"enable"
  330. NO "no"|"false"|"off"|"disable"
  331. UDP "udp"|"UDP"
  332. TCP "tcp"|"TCP"
  333. TLS "tls"|"TLS"
  334. INET "inet"|"INET"
  335. INET6 "inet6"|"INET6"
  336. SSLv23 "sslv23"|"SSLv23"|"SSLV23"
  337. SSLv2 "sslv2"|"SSLv2"|"SSLV2"
  338. SSLv3 "sslv3"|"SSLv3"|"SSLV3"
  339. TLSv1 "tlsv1"|"TLSv1"|"TLSV1"
  340. LETTER [a-zA-Z]
  341. DIGIT [0-9]
  342. ALPHANUM {LETTER}|{DIGIT}|[_]
  343. ID {LETTER}{ALPHANUM}*
  344. HEX [0-9a-fA-F]
  345. HEXNUMBER 0x{HEX}+
  346. OCTNUMBER 0[0-7]+
  347. DECNUMBER 0|-?([1-9]{DIGIT}*)
  348. BINNUMBER [0-1]+b
  349. HEX4 {HEX}{1,4}
  350. IPV6ADDR ({HEX4}":"){7}{HEX4}|({HEX4}":"){1,7}(":"{HEX4}){1,7}|":"(":"{HEX4}){1,7}|({HEX4}":"){1,7}":"|"::"
  351. QUOTES \"
  352. TICK \'
  353. SLASH "/"
  354. SEMICOLON ;
  355. RPAREN \)
  356. LPAREN \(
  357. LBRACE \{
  358. RBRACE \}
  359. LBRACK \[
  360. RBRACK \]
  361. COMMA ","
  362. COLON ":"
  363. STAR \*
  364. DOT \.
  365. CR \n
  366. COM_LINE #
  367. COM_START "/\*"
  368. COM_END "\*/"
  369. EAT_ABLE [\ \t\b\r]
  370. %%
  371. <INITIAL>{EAT_ABLE} { count(); }
  372. <INITIAL>{FORWARD} {count(); yylval.strval=yytext; return FORWARD; }
  373. <INITIAL>{FORWARD_TCP} {count(); yylval.strval=yytext; return FORWARD_TCP; }
  374. <INITIAL>{FORWARD_TLS} {count(); yylval.strval=yytext; return FORWARD_TLS; }
  375. <INITIAL>{FORWARD_UDP} {count(); yylval.strval=yytext; return FORWARD_UDP; }
  376. <INITIAL>{DROP} { count(); yylval.strval=yytext; return DROP; }
  377. <INITIAL>{RETURN} { count(); yylval.strval=yytext; return RETURN; }
  378. <INITIAL>{BREAK} { count(); yylval.strval=yytext; return BREAK; }
  379. <INITIAL>{SEND} { count(); yylval.strval=yytext; return SEND; }
  380. <INITIAL>{SEND_TCP} { count(); yylval.strval=yytext; return SEND_TCP; }
  381. <INITIAL>{LOG} { count(); yylval.strval=yytext; return LOG_TOK; }
  382. <INITIAL>{ERROR} { count(); yylval.strval=yytext; return ERROR; }
  383. <INITIAL>{SETFLAG} { count(); yylval.strval=yytext; return SETFLAG; }
  384. <INITIAL>{RESETFLAG} { count(); yylval.strval=yytext; return RESETFLAG; }
  385. <INITIAL>{ISFLAGSET} { count(); yylval.strval=yytext; return ISFLAGSET; }
  386. <INITIAL>{FLAGS_DECL} { count(); yylval.strval=yytext; return FLAGS_DECL; }
  387. <INITIAL>{SETAVPFLAG} { count(); yylval.strval=yytext; return SETAVPFLAG; }
  388. <INITIAL>{RESETAVPFLAG} { count(); yylval.strval=yytext; return RESETAVPFLAG; }
  389. <INITIAL>{ISAVPFLAGSET} { count(); yylval.strval=yytext; return ISAVPFLAGSET; }
  390. <INITIAL>{AVPFLAGS_DECL} { count(); yylval.strval=yytext; return AVPFLAGS_DECL; }
  391. <INITIAL>{MSGLEN} { count(); yylval.strval=yytext; return MSGLEN; }
  392. <INITIAL>{RETCODE} { count(); yylval.strval=yytext; return RETCODE; }
  393. <INITIAL>{ROUTE} { count(); yylval.strval=yytext; return ROUTE; }
  394. <INITIAL>{ROUTE_ONREPLY} { count(); yylval.strval=yytext;
  395. return ROUTE_ONREPLY; }
  396. <INITIAL>{ROUTE_FAILURE} { count(); yylval.strval=yytext;
  397. return ROUTE_FAILURE; }
  398. <INITIAL>{ROUTE_BRANCH} { count(); yylval.strval=yytext; return ROUTE_BRANCH; }
  399. <INITIAL>{ROUTE_SEND} { count(); yylval.strval=yytext; return ROUTE_SEND; }
  400. <INITIAL>{EXEC} { count(); yylval.strval=yytext; return EXEC; }
  401. <INITIAL>{SET_HOST} { count(); yylval.strval=yytext; return SET_HOST; }
  402. <INITIAL>{SET_HOSTPORT} { count(); yylval.strval=yytext; return SET_HOSTPORT; }
  403. <INITIAL>{SET_USER} { count(); yylval.strval=yytext; return SET_USER; }
  404. <INITIAL>{SET_USERPASS} { count(); yylval.strval=yytext; return SET_USERPASS; }
  405. <INITIAL>{SET_PORT} { count(); yylval.strval=yytext; return SET_PORT; }
  406. <INITIAL>{SET_URI} { count(); yylval.strval=yytext; return SET_URI; }
  407. <INITIAL>{REVERT_URI} { count(); yylval.strval=yytext; return REVERT_URI; }
  408. <INITIAL>{PREFIX} { count(); yylval.strval=yytext; return PREFIX; }
  409. <INITIAL>{STRIP} { count(); yylval.strval=yytext; return STRIP; }
  410. <INITIAL>{STRIP_TAIL} { count(); yylval.strval=yytext; return STRIP_TAIL; }
  411. <INITIAL>{APPEND_BRANCH} { count(); yylval.strval=yytext;
  412. return APPEND_BRANCH; }
  413. <INITIAL>{FORCE_RPORT} { count(); yylval.strval=yytext; return FORCE_RPORT; }
  414. <INITIAL>{FORCE_TCP_ALIAS} { count(); yylval.strval=yytext;
  415. return FORCE_TCP_ALIAS; }
  416. <INITIAL>{IF} { count(); yylval.strval=yytext; return IF; }
  417. <INITIAL>{ELSE} { count(); yylval.strval=yytext; return ELSE; }
  418. <INITIAL>{SET_ADV_ADDRESS} { count(); yylval.strval=yytext;
  419. return SET_ADV_ADDRESS; }
  420. <INITIAL>{SET_ADV_PORT} { count(); yylval.strval=yytext;
  421. return SET_ADV_PORT; }
  422. <INITIAL>{FORCE_SEND_SOCKET} { count(); yylval.strval=yytext;
  423. return FORCE_SEND_SOCKET; }
  424. <INITIAL>{URIHOST} { count(); yylval.strval=yytext; return URIHOST; }
  425. <INITIAL>{URIPORT} { count(); yylval.strval=yytext; return URIPORT; }
  426. <INITIAL>{MAX_LEN} { count(); yylval.strval=yytext; return MAX_LEN; }
  427. <INITIAL>{METHOD} { count(); yylval.strval=yytext; return METHOD; }
  428. <INITIAL>{URI} { count(); yylval.strval=yytext; return URI; }
  429. <INITIAL>{FROM_URI} { count(); yylval.strval=yytext; return FROM_URI; }
  430. <INITIAL>{TO_URI} { count(); yylval.strval=yytext; return TO_URI; }
  431. <INITIAL>{SRCIP} { count(); yylval.strval=yytext; return SRCIP; }
  432. <INITIAL>{SRCPORT} { count(); yylval.strval=yytext; return SRCPORT; }
  433. <INITIAL>{DSTIP} { count(); yylval.strval=yytext; return DSTIP; }
  434. <INITIAL>{DSTPORT} { count(); yylval.strval=yytext; return DSTPORT; }
  435. <INITIAL>{SNDIP} { count(); yylval.strval=yytext; return SNDIP; }
  436. <INITIAL>{SNDPORT} { count(); yylval.strval=yytext; return SNDPORT; }
  437. <INITIAL>{SNDPROTO} { count(); yylval.strval=yytext; return SNDPROTO; }
  438. <INITIAL>{SNDAF} { count(); yylval.strval=yytext; return SNDAF; }
  439. <INITIAL>{TOIP} { count(); yylval.strval=yytext; return TOIP; }
  440. <INITIAL>{TOPORT} { count(); yylval.strval=yytext; return TOPORT; }
  441. <INITIAL>{PROTO} { count(); yylval.strval=yytext; return PROTO; }
  442. <INITIAL>{AF} { count(); yylval.strval=yytext; return AF; }
  443. <INITIAL>{MYSELF} { count(); yylval.strval=yytext; return MYSELF; }
  444. <INITIAL>{DEBUG} { count(); yylval.strval=yytext; return DEBUG_V; }
  445. <INITIAL>{FORK} { count(); yylval.strval=yytext; return FORK; }
  446. <INITIAL>{LOGSTDERROR} { yylval.strval=yytext; return LOGSTDERROR; }
  447. <INITIAL>{LOGFACILITY} { yylval.strval=yytext; return LOGFACILITY; }
  448. <INITIAL>{LISTEN} { count(); yylval.strval=yytext; return LISTEN; }
  449. <INITIAL>{ALIAS} { count(); yylval.strval=yytext; return ALIAS; }
  450. <INITIAL>{DNS} { count(); yylval.strval=yytext; return DNS; }
  451. <INITIAL>{REV_DNS} { count(); yylval.strval=yytext; return REV_DNS; }
  452. <INITIAL>{DNS_TRY_IPV6} { count(); yylval.strval=yytext;
  453. return DNS_TRY_IPV6; }
  454. <INITIAL>{DNS_TRY_NAPTR} { count(); yylval.strval=yytext;
  455. return DNS_TRY_NAPTR; }
  456. <INITIAL>{DNS_SRV_LB} { count(); yylval.strval=yytext;
  457. return DNS_SRV_LB; }
  458. <INITIAL>{DNS_UDP_PREF} { count(); yylval.strval=yytext;
  459. return DNS_UDP_PREF; }
  460. <INITIAL>{DNS_TCP_PREF} { count(); yylval.strval=yytext;
  461. return DNS_TCP_PREF; }
  462. <INITIAL>{DNS_TLS_PREF} { count(); yylval.strval=yytext;
  463. return DNS_TLS_PREF; }
  464. <INITIAL>{DNS_RETR_TIME} { count(); yylval.strval=yytext;
  465. return DNS_RETR_TIME; }
  466. <INITIAL>{DNS_RETR_NO} { count(); yylval.strval=yytext;
  467. return DNS_RETR_NO; }
  468. <INITIAL>{DNS_SERVERS_NO} { count(); yylval.strval=yytext;
  469. return DNS_SERVERS_NO; }
  470. <INITIAL>{DNS_USE_SEARCH} { count(); yylval.strval=yytext;
  471. return DNS_USE_SEARCH; }
  472. <INITIAL>{DNS_SEARCH_FMATCH} { count(); yylval.strval=yytext;
  473. return DNS_SEARCH_FMATCH; }
  474. <INITIAL>{DNS_CACHE_INIT} { count(); yylval.strval=yytext;
  475. return DNS_CACHE_INIT; }
  476. <INITIAL>{DNS_USE_CACHE} { count(); yylval.strval=yytext;
  477. return DNS_USE_CACHE; }
  478. <INITIAL>{DNS_USE_FAILOVER} { count(); yylval.strval=yytext;
  479. return DNS_USE_FAILOVER; }
  480. <INITIAL>{DNS_CACHE_FLAGS} { count(); yylval.strval=yytext;
  481. return DNS_CACHE_FLAGS; }
  482. <INITIAL>{DNS_CACHE_NEG_TTL} { count(); yylval.strval=yytext;
  483. return DNS_CACHE_NEG_TTL; }
  484. <INITIAL>{DNS_CACHE_MIN_TTL} { count(); yylval.strval=yytext;
  485. return DNS_CACHE_MIN_TTL; }
  486. <INITIAL>{DNS_CACHE_MAX_TTL} { count(); yylval.strval=yytext;
  487. return DNS_CACHE_MAX_TTL; }
  488. <INITIAL>{DNS_CACHE_MEM} { count(); yylval.strval=yytext;
  489. return DNS_CACHE_MEM; }
  490. <INITIAL>{DNS_CACHE_GC_INT} { count(); yylval.strval=yytext;
  491. return DNS_CACHE_GC_INT; }
  492. <INITIAL>{DNS_CACHE_DEL_NONEXP} { count(); yylval.strval=yytext;
  493. return DNS_CACHE_DEL_NONEXP; }
  494. <INITIAL>{DST_BLST_INIT} { count(); yylval.strval=yytext;
  495. return DST_BLST_INIT; }
  496. <INITIAL>{USE_DST_BLST} { count(); yylval.strval=yytext;
  497. return USE_DST_BLST; }
  498. <INITIAL>{DST_BLST_MEM} { count(); yylval.strval=yytext;
  499. return DST_BLST_MEM; }
  500. <INITIAL>{DST_BLST_TTL} { count(); yylval.strval=yytext;
  501. return DST_BLST_TTL; }
  502. <INITIAL>{DST_BLST_GC_INT} { count(); yylval.strval=yytext;
  503. return DST_BLST_GC_INT; }
  504. <INITIAL>{PORT} { count(); yylval.strval=yytext; return PORT; }
  505. <INITIAL>{STAT} { count(); yylval.strval=yytext; return STAT; }
  506. <INITIAL>{MAXBUFFER} { count(); yylval.strval=yytext; return MAXBUFFER; }
  507. <INITIAL>{CHILDREN} { count(); yylval.strval=yytext; return CHILDREN; }
  508. <INITIAL>{CHECK_VIA} { count(); yylval.strval=yytext; return CHECK_VIA; }
  509. <INITIAL>{PHONE2TEL} { count(); yylval.strval=yytext; return PHONE2TEL; }
  510. <INITIAL>{SYN_BRANCH} { count(); yylval.strval=yytext; return SYN_BRANCH; }
  511. <INITIAL>{MEMLOG} { count(); yylval.strval=yytext; return MEMLOG; }
  512. <INITIAL>{MEMDBG} { count(); yylval.strval=yytext; return MEMDBG; }
  513. <INITIAL>{SIP_WARNING} { count(); yylval.strval=yytext; return SIP_WARNING; }
  514. <INITIAL>{USER} { count(); yylval.strval=yytext; return USER; }
  515. <INITIAL>{GROUP} { count(); yylval.strval=yytext; return GROUP; }
  516. <INITIAL>{CHROOT} { count(); yylval.strval=yytext; return CHROOT; }
  517. <INITIAL>{WDIR} { count(); yylval.strval=yytext; return WDIR; }
  518. <INITIAL>{MHOMED} { count(); yylval.strval=yytext; return MHOMED; }
  519. <INITIAL>{DISABLE_TCP} { count(); yylval.strval=yytext; return DISABLE_TCP; }
  520. <INITIAL>{TCP_CHILDREN} { count(); yylval.strval=yytext; return TCP_CHILDREN; }
  521. <INITIAL>{TCP_ACCEPT_ALIASES} { count(); yylval.strval=yytext;
  522. return TCP_ACCEPT_ALIASES; }
  523. <INITIAL>{TCP_SEND_TIMEOUT} { count(); yylval.strval=yytext;
  524. return TCP_SEND_TIMEOUT; }
  525. <INITIAL>{TCP_CONNECT_TIMEOUT} { count(); yylval.strval=yytext;
  526. return TCP_CONNECT_TIMEOUT; }
  527. <INITIAL>{TCP_CON_LIFETIME} { count(); yylval.strval=yytext;
  528. return TCP_CON_LIFETIME; }
  529. <INITIAL>{TCP_POLL_METHOD} { count(); yylval.strval=yytext;
  530. return TCP_POLL_METHOD; }
  531. <INITIAL>{TCP_MAX_CONNECTIONS} { count(); yylval.strval=yytext;
  532. return TCP_MAX_CONNECTIONS; }
  533. <INITIAL>{TCP_SOURCE_IPV4} { count(); yylval.strval=yytext;
  534. return TCP_SOURCE_IPV4; }
  535. <INITIAL>{TCP_SOURCE_IPV6} { count(); yylval.strval=yytext;
  536. return TCP_SOURCE_IPV6; }
  537. <INITIAL>{TCP_OPT_FD_CACHE} { count(); yylval.strval=yytext;
  538. return TCP_OPT_FD_CACHE; }
  539. <INITIAL>{TCP_OPT_CONN_WQ_MAX} { count(); yylval.strval=yytext;
  540. return TCP_OPT_CONN_WQ_MAX; }
  541. <INITIAL>{TCP_OPT_WQ_MAX} { count(); yylval.strval=yytext;
  542. return TCP_OPT_WQ_MAX; }
  543. <INITIAL>{TCP_OPT_BUF_WRITE} { count(); yylval.strval=yytext;
  544. return TCP_OPT_BUF_WRITE; }
  545. <INITIAL>{TCP_OPT_DEFER_ACCEPT} { count(); yylval.strval=yytext;
  546. return TCP_OPT_DEFER_ACCEPT; }
  547. <INITIAL>{TCP_OPT_DELAYED_ACK} { count(); yylval.strval=yytext;
  548. return TCP_OPT_DELAYED_ACK; }
  549. <INITIAL>{TCP_OPT_SYNCNT} { count(); yylval.strval=yytext;
  550. return TCP_OPT_SYNCNT; }
  551. <INITIAL>{TCP_OPT_LINGER2} { count(); yylval.strval=yytext;
  552. return TCP_OPT_LINGER2; }
  553. <INITIAL>{TCP_OPT_KEEPALIVE} { count(); yylval.strval=yytext;
  554. return TCP_OPT_KEEPALIVE; }
  555. <INITIAL>{TCP_OPT_KEEPIDLE} { count(); yylval.strval=yytext;
  556. return TCP_OPT_KEEPIDLE; }
  557. <INITIAL>{TCP_OPT_KEEPINTVL} { count(); yylval.strval=yytext;
  558. return TCP_OPT_KEEPINTVL; }
  559. <INITIAL>{TCP_OPT_KEEPCNT} { count(); yylval.strval=yytext;
  560. return TCP_OPT_KEEPCNT; }
  561. <INITIAL>{DISABLE_TLS} { count(); yylval.strval=yytext; return DISABLE_TLS; }
  562. <INITIAL>{ENABLE_TLS} { count(); yylval.strval=yytext; return ENABLE_TLS; }
  563. <INITIAL>{TLSLOG} { count(); yylval.strval=yytext; return TLS_PORT_NO; }
  564. <INITIAL>{TLS_PORT_NO} { count(); yylval.strval=yytext; return TLS_PORT_NO; }
  565. <INITIAL>{TLS_METHOD} { count(); yylval.strval=yytext; return TLS_METHOD; }
  566. <INITIAL>{TLS_VERIFY} { count(); yylval.strval=yytext; return TLS_VERIFY; }
  567. <INITIAL>{TLS_REQUIRE_CERTIFICATE} { count(); yylval.strval=yytext;
  568. return TLS_REQUIRE_CERTIFICATE; }
  569. <INITIAL>{TLS_CERTIFICATE} { count(); yylval.strval=yytext;
  570. return TLS_CERTIFICATE; }
  571. <INITIAL>{TLS_PRIVATE_KEY} { count(); yylval.strval=yytext;
  572. return TLS_PRIVATE_KEY; }
  573. <INITIAL>{TLS_CA_LIST} { count(); yylval.strval=yytext;
  574. return TLS_CA_LIST; }
  575. <INITIAL>{TLS_HANDSHAKE_TIMEOUT} { count(); yylval.strval=yytext;
  576. return TLS_HANDSHAKE_TIMEOUT; }
  577. <INITIAL>{TLS_SEND_TIMEOUT} { count(); yylval.strval=yytext;
  578. return TLS_SEND_TIMEOUT; }
  579. <INITIAL>{SERVER_SIGNATURE} { count(); yylval.strval=yytext; return SERVER_SIGNATURE; }
  580. <INITIAL>{REPLY_TO_VIA} { count(); yylval.strval=yytext; return REPLY_TO_VIA; }
  581. <INITIAL>{ADVERTISED_ADDRESS} { count(); yylval.strval=yytext;
  582. return ADVERTISED_ADDRESS; }
  583. <INITIAL>{ADVERTISED_PORT} { count(); yylval.strval=yytext;
  584. return ADVERTISED_PORT; }
  585. <INITIAL>{DISABLE_CORE} { count(); yylval.strval=yytext;
  586. return DISABLE_CORE; }
  587. <INITIAL>{OPEN_FD_LIMIT} { count(); yylval.strval=yytext;
  588. return OPEN_FD_LIMIT; }
  589. <INITIAL>{SHM_FORCE_ALLOC} { count(); yylval.strval=yytext;
  590. return SHM_FORCE_ALLOC; }
  591. <INITIAL>{MLOCK_PAGES} { count(); yylval.strval=yytext;
  592. return MLOCK_PAGES; }
  593. <INITIAL>{REAL_TIME} { count(); yylval.strval=yytext;
  594. return REAL_TIME; }
  595. <INITIAL>{RT_PRIO} { count(); yylval.strval=yytext;
  596. return RT_PRIO; }
  597. <INITIAL>{RT_POLICY} { count(); yylval.strval=yytext;
  598. return RT_POLICY; }
  599. <INITIAL>{RT_TIMER1_PRIO} { count(); yylval.strval=yytext;
  600. return RT_TIMER1_PRIO; }
  601. <INITIAL>{RT_TIMER1_POLICY} { count(); yylval.strval=yytext;
  602. return RT_TIMER1_POLICY; }
  603. <INITIAL>{RT_TIMER2_PRIO} { count(); yylval.strval=yytext;
  604. return RT_TIMER2_PRIO; }
  605. <INITIAL>{RT_TIMER2_POLICY} { count(); yylval.strval=yytext;
  606. return RT_TIMER2_POLICY; }
  607. <INITIAL>{MCAST_LOOPBACK} { count(); yylval.strval=yytext;
  608. return MCAST_LOOPBACK; }
  609. <INITIAL>{MCAST_TTL} { count(); yylval.strval=yytext;
  610. return MCAST_TTL; }
  611. <INITIAL>{TOS} { count(); yylval.strval=yytext;
  612. return TOS; }
  613. <INITIAL>{PMTU_DISCOVERY} { count(); yylval.strval=yytext;
  614. return PMTU_DISCOVERY; }
  615. <INITIAL>{KILL_TIMEOUT} { count(); yylval.strval=yytext;
  616. return KILL_TIMEOUT; }
  617. <INITIAL>{CFG_DESCRIPTION} { count(); yylval.strval=yytext; return CFG_DESCRIPTION; }
  618. <INITIAL>{LOADMODULE} { count(); yylval.strval=yytext; return LOADMODULE; }
  619. <INITIAL>{MODPARAM} { count(); yylval.strval=yytext; return MODPARAM; }
  620. <INITIAL>{STUN_REFRESH_INTERVAL} { count(); yylval.strval=yytext; return STUN_REFRESH_INTERVAL;}
  621. <INITIAL>{STUN_ALLOW_STUN} { count(); yylval.strval=yytext; return STUN_ALLOW_STUN;}
  622. <INITIAL>{STUN_ALLOW_FP} { count(); yylval.strval=yytext; return STUN_ALLOW_FP;}
  623. <INITIAL>{EQUAL} { count(); return EQUAL; }
  624. <INITIAL>{ADDEQ} { count(); return ADDEQ; }
  625. <INITIAL>{EQUAL_T} { count(); return EQUAL_T; }
  626. <INITIAL>{GT} { count(); return GT; }
  627. <INITIAL>{LT} { count(); return LT; }
  628. <INITIAL>{GTE} { count(); return GTE; }
  629. <INITIAL>{LTE} { count(); return LTE; }
  630. <INITIAL>{DIFF} { count(); return DIFF; }
  631. <INITIAL>{MATCH} { count(); return MATCH; }
  632. <INITIAL>{NOT} { count(); return NOT; }
  633. <INITIAL>{LOG_AND} { count(); return LOG_AND; }
  634. <INITIAL>{BIN_AND} { count(); return BIN_AND; }
  635. <INITIAL>{LOG_OR} { count(); return LOG_OR; }
  636. <INITIAL>{BIN_OR} { count(); return BIN_OR; }
  637. <INITIAL>{PLUS} { count(); return PLUS; }
  638. <INITIAL>{MINUS} { count(); return MINUS; }
  639. <INITIAL>{SELECT_MARK} { count(); state = SELECT_S; BEGIN(SELECT); return SELECT_MARK; }
  640. <SELECT>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  641. yylval.strval=s_buf.s;
  642. memset(&s_buf, 0, sizeof(s_buf));
  643. return ID;
  644. }
  645. <SELECT>{DOT} { count(); return DOT; }
  646. <SELECT>{LBRACK} { count(); return LBRACK; }
  647. <SELECT>{RBRACK} { count(); return RBRACK; }
  648. <SELECT>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  649. <SELECT>{HEXNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 16); return NUMBER; }
  650. <SELECT>{OCTNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 8); return NUMBER; }
  651. <SELECT>{BINNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 2); return NUMBER; }
  652. <INITIAL>{ATTR_MARK} { count(); state = ATTR_S; BEGIN(ATTR); return ATTR_MARK; }
  653. <ATTR>{ATTR_FROM} { count(); return ATTR_FROM; }
  654. <ATTR>{ATTR_TO} { count(); return ATTR_TO; }
  655. <ATTR>{ATTR_FROMURI} { count(); return ATTR_FROMURI; }
  656. <ATTR>{ATTR_TOURI} { count(); return ATTR_TOURI; }
  657. <ATTR>{ATTR_FROMUSER} { count(); return ATTR_FROMUSER; }
  658. <ATTR>{ATTR_TOUSER} { count(); return ATTR_TOUSER; }
  659. <ATTR>{ATTR_FROMDOMAIN} { count(); return ATTR_FROMDOMAIN; }
  660. <ATTR>{ATTR_TODOMAIN} { count(); return ATTR_TODOMAIN; }
  661. <ATTR>{ATTR_GLOBAL} { count(); return ATTR_GLOBAL; }
  662. <ATTR>{DOT} { count(); return DOT; }
  663. <ATTR>{LBRACK} { count(); return LBRACK; }
  664. <ATTR>{RBRACK} { count(); return RBRACK; }
  665. <ATTR>{STAR} { count(); return STAR; }
  666. <ATTR>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  667. <ATTR>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  668. yylval.strval=s_buf.s;
  669. memset(&s_buf, 0, sizeof(s_buf));
  670. state = INITIAL_S;
  671. BEGIN(INITIAL);
  672. return ID;
  673. }
  674. <INITIAL>{IPV6ADDR} { count(); yylval.strval=yytext; return IPV6ADDR; }
  675. <INITIAL>{DECNUMBER} { count(); yylval.intval=atoi(yytext);return NUMBER; }
  676. <INITIAL>{HEXNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 16);
  677. return NUMBER; }
  678. <INITIAL>{OCTNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 8);
  679. return NUMBER; }
  680. <INITIAL>{BINNUMBER} { count(); yylval.intval=(int)strtol(yytext, 0, 2); return NUMBER; }
  681. <INITIAL>{YES} { count(); yylval.intval=1; return NUMBER; }
  682. <INITIAL>{NO} { count(); yylval.intval=0; return NUMBER; }
  683. <INITIAL>{TCP} { count(); return TCP; }
  684. <INITIAL>{UDP} { count(); return UDP; }
  685. <INITIAL>{TLS} { count(); return TLS; }
  686. <INITIAL>{INET} { count(); yylval.intval=AF_INET; return NUMBER; }
  687. <INITIAL>{INET6} { count();
  688. #ifdef USE_IPV6
  689. yylval.intval=AF_INET6;
  690. #else
  691. yylval.intval=-1; /* no match*/
  692. #endif
  693. return NUMBER; }
  694. <INITIAL>{SSLv23} { count(); yylval.strval=yytext; return SSLv23; }
  695. <INITIAL>{SSLv2} { count(); yylval.strval=yytext; return SSLv2; }
  696. <INITIAL>{SSLv3} { count(); yylval.strval=yytext; return SSLv3; }
  697. <INITIAL>{TLSv1} { count(); yylval.strval=yytext; return TLSv1; }
  698. <INITIAL>{COMMA} { count(); return COMMA; }
  699. <INITIAL>{SEMICOLON} { count(); return SEMICOLON; }
  700. <INITIAL>{COLON} { count(); return COLON; }
  701. <INITIAL>{STAR} { count(); return STAR; }
  702. <INITIAL>{RPAREN} { count(); return RPAREN; }
  703. <INITIAL>{LPAREN} { count(); return LPAREN; }
  704. <INITIAL>{LBRACE} { count(); return LBRACE; }
  705. <INITIAL>{RBRACE} { count(); return RBRACE; }
  706. <INITIAL>{LBRACK} { count(); return LBRACK; }
  707. <INITIAL>{RBRACK} { count(); return RBRACK; }
  708. <INITIAL>{SLASH} { count(); return SLASH; }
  709. <INITIAL>{DOT} { count(); return DOT; }
  710. <INITIAL>\\{CR} {count(); } /* eat the escaped CR */
  711. <INITIAL>{CR} { count();/* return CR;*/ }
  712. <INITIAL,SELECT>{QUOTES} { count(); old_initial = YY_START; old_state = state; state=STRING_S; BEGIN(STRING1); }
  713. <INITIAL>{TICK} { count(); old_initial = YY_START; old_state = state; state=STRING_S; BEGIN(STRING2); }
  714. <STRING1>{QUOTES} { count(); state=old_state; BEGIN(old_initial);
  715. yytext[yyleng-1]=0; yyleng--;
  716. addstr(&s_buf, yytext, yyleng);
  717. yylval.strval=s_buf.s;
  718. memset(&s_buf, 0, sizeof(s_buf));
  719. return STRING;
  720. }
  721. <STRING2>{TICK} { count(); state=old_state; BEGIN(old_initial);
  722. yytext[yyleng-1]=0; yyleng--;
  723. addstr(&s_buf, yytext, yyleng);
  724. yylval.strval=s_buf.s;
  725. memset(&s_buf, 0, sizeof(s_buf));
  726. return STRING;
  727. }
  728. <STRING2>.|{EAT_ABLE}|{CR} { yymore(); }
  729. <STRING1>\\n { count(); addchar(&s_buf, '\n'); }
  730. <STRING1>\\r { count(); addchar(&s_buf, '\r'); }
  731. <STRING1>\\a { count(); addchar(&s_buf, '\a'); }
  732. <STRING1>\\t { count(); addchar(&s_buf, '\t'); }
  733. <STRING1>\\{QUOTES} { count(); addchar(&s_buf, '"'); }
  734. <STRING1>\\\\ { count(); addchar(&s_buf, '\\'); }
  735. <STRING1>\\x{HEX}{1,2} { count(); addchar(&s_buf,
  736. (char)strtol(yytext+2, 0, 16)); }
  737. /* don't allow \[0-7]{1}, it will eat the backreferences from
  738. subst_uri if allowed (although everybody should use '' in subt_uri) */
  739. <STRING1>\\[0-7]{2,3} { count(); addchar(&s_buf,
  740. (char)strtol(yytext+1, 0, 8)); }
  741. <STRING1>\\{CR} { count(); } /* eat escaped CRs */
  742. <STRING1>.|{EAT_ABLE}|{CR} { addchar(&s_buf, *yytext); }
  743. <INITIAL,COMMENT>{COM_START} { count(); comment_nest++; state=COMMENT_S;
  744. BEGIN(COMMENT); }
  745. <COMMENT>{COM_END} { count(); comment_nest--;
  746. if (comment_nest==0){
  747. state=INITIAL_S;
  748. BEGIN(INITIAL);
  749. }
  750. }
  751. <COMMENT>.|{EAT_ABLE}|{CR} { count(); };
  752. <INITIAL>{COM_LINE}.*{CR} { count(); }
  753. <INITIAL>{ID} { count(); addstr(&s_buf, yytext, yyleng);
  754. yylval.strval=s_buf.s;
  755. memset(&s_buf, 0, sizeof(s_buf));
  756. return ID; }
  757. <SELECT>. { unput(yytext[0]); state = INITIAL_S; BEGIN(INITIAL); } /* Rescan the token in INITIAL state */
  758. <<EOF>> {
  759. switch(state){
  760. case STRING_S:
  761. LOG(L_CRIT, "ERROR: cfg. parser: unexpected EOF in"
  762. " unclosed string\n");
  763. if (s_buf.s){
  764. pkg_free(s_buf.s);
  765. memset(&s_buf, 0,
  766. sizeof(s_buf));
  767. }
  768. break;
  769. case COMMENT_S:
  770. LOG(L_CRIT, "ERROR: cfg. parser: unexpected EOF:"
  771. " %d comments open\n", comment_nest);
  772. break;
  773. case COMMENT_LN_S:
  774. LOG(L_CRIT, "ERROR: unexpected EOF:"
  775. "comment line open\n");
  776. break;
  777. }
  778. return 0;
  779. }
  780. %%
  781. static char* addchar(struct str_buf* dst, char c)
  782. {
  783. return addstr(dst, &c, 1);
  784. }
  785. static char* addstr(struct str_buf* dst_b, char* src, int len)
  786. {
  787. char *tmp;
  788. unsigned size;
  789. unsigned used;
  790. if (dst_b->left<(len+1)){
  791. used=(unsigned)(dst_b->crt-dst_b->s);
  792. size=used+len+1;
  793. /* round up to next multiple */
  794. size+= STR_BUF_ALLOC_UNIT-size%STR_BUF_ALLOC_UNIT;
  795. tmp=pkg_malloc(size);
  796. if (tmp==0) goto error;
  797. if (dst_b->s){
  798. memcpy(tmp, dst_b->s, used);
  799. pkg_free(dst_b->s);
  800. }
  801. dst_b->s=tmp;
  802. dst_b->crt=dst_b->s+used;
  803. dst_b->left=size-used;
  804. }
  805. memcpy(dst_b->crt, src, len);
  806. dst_b->crt+=len;
  807. *(dst_b->crt)=0;
  808. dst_b->left-=len;
  809. return dst_b->s;
  810. error:
  811. LOG(L_CRIT, "ERROR:lex:addstr: memory allocation error\n");
  812. return 0;
  813. }
  814. static void count()
  815. {
  816. int i;
  817. startcolumn=column;
  818. for (i=0; i<yyleng;i++){
  819. if (yytext[i]=='\n'){
  820. line++;
  821. column=startcolumn=1;
  822. }else if (yytext[i]=='\t'){
  823. column++;
  824. /*column+=8 -(column%8);*/
  825. }else{
  826. column++;
  827. }
  828. }
  829. }
  830. /* replacement yywrap, removes libfl dependency */
  831. int yywrap()
  832. {
  833. return 1;
  834. }