From bdee1f6bfaa0017877e5d5284c2d5e41f67e847a Mon Sep 17 00:00:00 2001 From: Eric Wong Date: Tue, 16 Jun 2020 07:04:26 +0000 Subject: imap: *SEARCH: fix CHARSET handling We no longer pass an arrayref to search_common() or parse_query(), so handle the CHARSET directive in the Parse::RecDescent-generated parser directly. --- lib/PublicInbox/IMAPsearchqp.pm | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'lib/PublicInbox/IMAPsearchqp.pm') diff --git a/lib/PublicInbox/IMAPsearchqp.pm b/lib/PublicInbox/IMAPsearchqp.pm index fba3bacc..c9b442cb 100644 --- a/lib/PublicInbox/IMAPsearchqp.pm +++ b/lib/PublicInbox/IMAPsearchqp.pm @@ -165,7 +165,7 @@ sub msn_set { my $prd = Parse::RecDescent->new(<<'EOG'); { my $q = $PublicInbox::IMAPsearchqp::q; } -search_key : search_key1(s) { $return = $q } +search_key : CHARSET(?) search_key1(s) { $return = $q } search_key1 : "ALL" | "RECENT" | "UNSEEN" | "NEW" | OR_search_keys | NOT_search_key @@ -188,6 +188,10 @@ search_key1 : "ALL" | "RECENT" | "UNSEEN" | "NEW" | sub_query | +charset : /\S+/ +CHARSET : 'CHARSET' charset +{ $item{charset} =~ /\A(?:UTF-8|US-ASCII)\z/ ? 1 : die('NO [BADCHARSET]'); } + SENTSINCE_date : 'SENTSINCE' date { $q->SENTSINCE(\%item) } SENTON_date : 'SENTON' date { $q->SENTON(\%item) } SENTBEFORE_date : 'SENTBEFORE' date { $q->SENTBEFORE(\%item) } @@ -253,7 +257,7 @@ sub parse { %$q = (sql => \$sql, imap => $imap); # imap = PublicInbox::IMAP obj # $::RD_TRACE = 1; my $res = eval { $prd->search_key(uc($query)) }; - return $@ if $@ && $@ =~ /\ABAD /; + return $@ if $@ && $@ =~ /\A(?:BAD|NO) /; return 'BAD unexpected result' if !$res || $res != $q; if (exists $q->{sql}) { delete $q->{xap}; -- cgit v1.2.3-24-ge0c7