+\"[^\"]*\" |
+\'[^\']*\' {
+ char *in = xstrndup(yytext+1, yyleng-2);
+ escapes(in, in);
+ yylval.sval = in;
+ SETSTATE(0);
+ return STRING;
+ }
+
+<NAME>[^=;:, \t\r\n]+ {
+ char *in = xstrdup(yytext);
+ escapes(in, in);
+ yylval.sval = in;
+ SETSTATE(0);
+ return STRING;
+ }
+
+set { return SET; }
+logfile { return LOGFILE; }
+idfile { return IDFILE; }
+pidfile { return PIDFILE; }
+daemon { return DAEMON; }
+syslog { return SYSLOG; }
+invisible { return INVISIBLE; }
+showdots { return SHOWDOTS; }
+postmaster { return POSTMASTER; }
+bouncemail { return BOUNCEMAIL; }
+spambounce { return SPAMBOUNCE; }
+softbounce { return SOFTBOUNCE; }
+warnings { return WARNINGS; }
+tracepolls { return TRACEPOLLS; }
+
+defaults { return DEFAULTS; }
+server { return POLL; }
+poll { return POLL; }
+skip { return SKIP; }
+via { return VIA; }
+aka { return AKA; }
+local(domains)? { return LOCALDOMAINS; }
+proto(col)? { return PROTOCOL; }
+service { return SERVICE; }
+port { return PORT; }
+interval { return INTERVAL; }
+preauth(enticate)? { SETSTATE(AUTH); return AUTHENTICATE; }
+auth(enticate)? { SETSTATE(AUTH); return AUTHENTICATE; }
+any { SETSTATE(0); yylval.proto = A_ANY; return AUTHTYPE;}
+gssapi { SETSTATE(0); yylval.proto = A_GSSAPI; return AUTHTYPE;}
+kerberos(_v)?4 { SETSTATE(0); yylval.proto = A_KERBEROS_V4; return AUTHTYPE;}
+kerberos(_v)?5 { SETSTATE(0); yylval.proto = A_KERBEROS_V5; return AUTHTYPE;}
+kerberos { SETSTATE(0); yylval.proto = A_KERBEROS_V4; return AUTHTYPE;}
+ssh { SETSTATE(0); yylval.proto = A_SSH; return AUTHTYPE;}
+external { SETSTATE(0); yylval.proto = A_EXTERNAL; return AUTHTYPE;}
+(otp|opie) { SETSTATE(0); yylval.proto = A_OTP; return AUTHTYPE;}
+cram(-md5)? { SETSTATE(0); yylval.proto = A_CRAM_MD5; return AUTHTYPE;}
+msn { SETSTATE(0); yylval.proto = A_MSN; return AUTHTYPE;}
+ntlm { SETSTATE(0); yylval.proto = A_NTLM; return AUTHTYPE;}
+<AUTH>password { SETSTATE(0); yylval.proto = A_PASSWORD; return AUTHTYPE;}
+timeout { return TIMEOUT;}
+envelope { return ENVELOPE; }
+qvirtual { return QVIRTUAL; }
+principal { return PRINCIPAL; }
+esmtpname { return ESMTPNAME; }
+esmtppassword { return ESMTPPASSWORD; }
+bad-header { return BADHEADER; }
+accept { return ACCEPT; }
+reject { return REJECT_; }
+
+user(name)? {SETSTATE(NAME); return USERNAME; }
+<INITIAL,NAME>pass(word)? {SETSTATE(NAME); return PASSWORD; }
+folder(s)? { return FOLDER; }
+smtp(host)? { return SMTPHOST; }
+fetchdomains { return FETCHDOMAINS; }
+smtpaddress { return SMTPADDRESS; }
+smtpname { return SMTPNAME; }
+antispam { return SPAMRESPONSE; }
+mda { return MDA; }
+bsmtp { return BSMTP; }
+lmtp { return LMTP; }
+pre(connect)? { return PRECONNECT; }
+post(connect)? { return POSTCONNECT; }
+interface { return INTERFACE; }
+monitor { return MONITOR; }
+plugin { return PLUGIN; }
+plugout { return PLUGOUT; }
+batchlimit { return BATCHLIMIT; }
+fetchlimit { return FETCHLIMIT; }
+fetchsizelimit { return FETCHSIZELIMIT; }
+fastuidl { return FASTUIDL; }
+expunge { return EXPUNGE; }
+properties { return PROPERTIES; }
+
+is { SETSTATE(NAME); return IS; }
+here { return HERE; }
+there { return THERE; }
+to { SETSTATE(NAME); return TO; }
+= { SETSTATE(NAME); return MAP; }