From ca201c8dfe50c99d77cf150e398e339f9b1e41d0 Mon Sep 17 00:00:00 2001 From: David Edler Date: Tue, 24 May 2022 21:14:23 +0200 Subject: [PATCH] improve performance for searching with lots of threads --- .../app/libraries/MailSo/Mail/MailClient.php | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/snappymail/v/0.0.0/app/libraries/MailSo/Mail/MailClient.php b/snappymail/v/0.0.0/app/libraries/MailSo/Mail/MailClient.php index 7eeba720d..3fbec55da 100644 --- a/snappymail/v/0.0.0/app/libraries/MailSo/Mail/MailClient.php +++ b/snappymail/v/0.0.0/app/libraries/MailSo/Mail/MailClient.php @@ -918,15 +918,14 @@ class MailClient $aSearchedUids = $this->GetUids($oParams->oCacher, $sSearch, $oMessageCollection->FolderName, $oMessageCollection->FolderHash); if ($bUseThreads && !$oParams->iThreadUid) { - $aUids = \array_filter($aUids, function($iUid) use ($aSearchedUids, $aAllThreads) { - if (\in_array($iUid, $aSearchedUids)) { - return true; - } - foreach ($aAllThreads as $aMap) { - if (\in_array($iUid, $aMap) && \array_intersect($aSearchedUids, $aMap)) { - return true; + $matchingThreadUids = []; + foreach ($aAllThreads as $aMap) { + if (\array_intersect($aSearchedUids, $aMap)) { + $matchingThreadUids = \array_merge($matchingThreadUids, $aMap); } - } + } + $aUids = \array_filter($aUids, function($iUid) use ($aSearchedUids, $matchingThreadUids) { + return \in_array($iUid, $aSearchedUids) || \in_array($iUid, $matchingThreadUids); }); } else { $aUids = \array_filter($aUids, function($iUid) use ($aSearchedUids) {