aboutsummaryrefslogtreecommitdiff
path: root/src/imap/search.rs
diff options
context:
space:
mode:
authorQuentin Dufour <quentin@deuxfleurs.fr>2024-01-05 15:26:57 +0100
committerQuentin Dufour <quentin@deuxfleurs.fr>2024-01-05 15:26:57 +0100
commitd3c156a087f3c767fc0d2376abd7c1d304161d47 (patch)
tree0c95d813be4fad70c839b81794889b327142f2a7 /src/imap/search.rs
parent35591ff0608096b32d7bab22d719a6ceb8574c2c (diff)
downloadaerogramme-d3c156a087f3c767fc0d2376abd7c1d304161d47.tar.gz
aerogramme-d3c156a087f3c767fc0d2376abd7c1d304161d47.zip
Select what to fecth for search
Diffstat (limited to 'src/imap/search.rs')
-rw-r--r--src/imap/search.rs30
1 files changed, 26 insertions, 4 deletions
diff --git a/src/imap/search.rs b/src/imap/search.rs
index bf1d30e..ef89288 100644
--- a/src/imap/search.rs
+++ b/src/imap/search.rs
@@ -69,12 +69,34 @@ impl<'a> Criteria<'a> {
}
}
- fn need_meta(&self) {
- unimplemented!();
+ /// Not really clever as we can have cases where we filter out
+ /// the email before needing to inspect its meta.
+ /// But for now we are seeking the most basic/stupid algorithm.
+ pub fn need_meta(&self) -> bool {
+ use SearchKey::*;
+ match self.0 {
+ // IMF Headers
+ Bcc(_) | Cc(_) | From(_) | Header(..) | SentBefore(_) | SentOn(_) | SentSince(_) | Subject(_) | To(_) => true,
+ // Internal Date is also stored in MailMeta
+ Before(_) | On(_) | Since(_) => true,
+ // Message size is also stored in MailMeta
+ Larger(_) | Smaller(_) => true,
+ And(and_list) => and_list.as_ref().iter().any(|sk| Criteria(sk).need_meta()),
+ Not(inner) => Criteria(inner).need_meta(),
+ Or(left, right) => Criteria(left).need_meta() || Criteria(right).need_meta(),
+ _ => false,
+ }
}
- fn need_body(&self) {
- unimplemented!();
+ pub fn need_body(&self) -> bool {
+ use SearchKey::*;
+ match self.0 {
+ Text(_) | Body(_) => true,
+ And(and_list) => and_list.as_ref().iter().any(|sk| Criteria(sk).need_body()),
+ Not(inner) => Criteria(inner).need_body(),
+ Or(left, right) => Criteria(left).need_body() || Criteria(right).need_body(),
+ _ => false,
+ }
}
}