add notifications for filter hits, fix totals for parent folders

This commit is contained in:
bienvenu%netscape.com 1999-07-31 18:16:24 +00:00
Родитель c7f4c61668
Коммит e8c3c353cd
4 изменённых файлов: 28 добавлений и 53 удалений

Просмотреть файл

@ -361,24 +361,7 @@ NS_IMETHODIMP nsImapMailFolder::GetSubFolders(nsIEnumerator* *result)
SetFlag(newFlags);
rv = CreateSubFolders(path);
}
else
{
UpdateSummaryTotals(PR_FALSE);
// Look for a directory for this mail folder, and recurse into it.
// e.g. if the folder is "inbox", look for "inbox.sbd".
#if 0
char *folderName = path->GetLeafName();
char *newLeafName = (char*)malloc(PL_strlen(folderName) +
PL_strlen(kDirExt) + 2);
PL_strcpy(newLeafName, folderName);
PL_strcat(newLeafName, kDirExt);
path->SetLeafName(newLeafName);
if(folderName)
nsCRT::free(folderName);
if(newLeafName)
nsCRT::free(newLeafName);
#endif
}
UpdateSummaryTotals(PR_FALSE);
if (NS_FAILED(rv)) return rv;
m_initialized = PR_TRUE; // XXX do this on failure too?
@ -947,7 +930,7 @@ nsImapMailFolder::BuildIdsAndKeyArray(nsISupportsArray* messages,
return AllocateUidStringFromKeyArray(keyArray, msgIds);
}
nsresult
/* static */ nsresult
nsImapMailFolder::AllocateUidStringFromKeyArray(nsMsgKeyArray &keyArray, nsCString &msgIds)
{
nsresult rv = NS_OK;
@ -1435,7 +1418,6 @@ NS_IMETHODIMP nsImapMailFolder::SetupHeaderParseStream(
if (!mDatabase)
GetDatabase();
#ifdef DOING_FILTERS
if (mFlags & MSG_FOLDER_FLAG_INBOX && !m_filterList)
{
NS_WITH_SERVICE(nsIMsgFilterService, filterService, kMsgFilterServiceCID, &rv);
@ -1466,7 +1448,6 @@ NS_IMETHODIMP nsImapMailFolder::SetupHeaderParseStream(
}
}
#endif
m_nextMessageByteLength = aStreamInfo->size;
if (!m_msgParser)
{
@ -1535,6 +1516,7 @@ NS_IMETHODIMP nsImapMailFolder::NormalEndHeaderParseStream(nsIImapProtocol*
newMsgHdr->SetMessageKey(m_curMsgUid);
TweakHeaderFlags(aProtocol, newMsgHdr);
m_msgMovedByFilter = PR_FALSE;
// If this is the inbox, try to apply filters.
if (mFlags & MSG_FOLDER_FLAG_INBOX)
{
@ -1542,15 +1524,14 @@ NS_IMETHODIMP nsImapMailFolder::NormalEndHeaderParseStream(nsIImapProtocol*
if (NS_SUCCEEDED(rv) && headers)
{
#ifdef DOING_FILTERS
if (m_filterList)
m_filterList->ApplyFiltersToHdr(nsMsgFilterType::InboxRule, newMsgHdr, this, mDatabase,
headers, headersSize, this);
#endif
}
}
// here we need to tweak flags from uid state..
mDatabase->AddNewHdrToDB(newMsgHdr, PR_TRUE);
if (!m_msgMovedByFilter)
mDatabase->AddNewHdrToDB(newMsgHdr, PR_TRUE);
m_msgParser->FinishHeader();
}
return NS_OK;
@ -1704,7 +1685,6 @@ NS_IMETHODIMP nsImapMailFolder::EndCopy(PRBool copySucceeded)
return rv;
}
#ifdef DOING_FILTERS
NS_IMETHODIMP nsImapMailFolder::ApplyFilterHit(nsIMsgFilter *filter, PRBool *applyMore)
{
nsMsgRuleActionType actionType;
@ -2020,8 +2000,6 @@ nsresult nsImapMailFolder::MoveIncorporatedMessage(nsIMsgDBHdr *mailHdr,
}
#endif // DOING_FILTERS
// both of these algorithms assume that key arrays and flag states are sorted by increasing key.
void nsImapMailFolder::FindKeysToDelete(const nsMsgKeyArray &existingKeys, nsMsgKeyArray &keysToDelete, nsImapFlagAndUidState *flagState)
{

Просмотреть файл

@ -314,6 +314,7 @@ public:
char *destFolder,
nsIMsgFilter *filter);
nsresult StoreImapFlags(imapMessageFlagsType flags, PRBool addFlags, nsMsgKeyArray &msgKeys);
static nsresult AllocateUidStringFromKeyArray(nsMsgKeyArray &keyArray, nsCString &msgIds);
protected:
// Helper methods
void FindKeysToAdd(const nsMsgKeyArray &existingKeys, nsMsgKeyArray
@ -358,7 +359,6 @@ protected:
nsresult BuildIdsAndKeyArray(nsISupportsArray* messages,
nsCString& msgIds, nsMsgKeyArray& keyArray);
nsresult AllocateUidStringFromKeyArray(nsMsgKeyArray &keyArray, nsCString &msgIds);
nsresult GetMessageHeader(nsIMsgDBHdr ** aMsgHdr);
nsNativeFileSpec *m_pathName;

Просмотреть файл

@ -20,7 +20,7 @@
#include "nsMsgImapCID.h"
#include "nsImapMailFolder.h"
#include "nsImapMoveCoalescer.h"
#include "nsMsgKeySet.h"
#include "nsMsgKeyArray.h"
#include "nsImapService.h"
static NS_DEFINE_CID(kCImapService, NS_IMAPSERVICE_CID);
@ -35,9 +35,9 @@ nsImapMoveCoalescer::nsImapMoveCoalescer(nsImapMailFolder *sourceFolder)
nsImapMoveCoalescer::~nsImapMoveCoalescer()
{
NS_IF_RELEASE(m_sourceFolder);
for (PRInt32 i = 0; i < m_sourceKeySets.Count(); i++)
for (PRInt32 i = 0; i < m_sourceKeyArrays.Count(); i++)
{
nsMsgKeySet *keys = (nsMsgKeySet *) m_sourceKeySets.ElementAt(i);
nsMsgKeyArray *keys = (nsMsgKeyArray *) m_sourceKeyArrays.ElementAt(i);
delete keys;
}
}
@ -49,10 +49,10 @@ nsresult nsImapMoveCoalescer::AddMove(nsIMsgFolder *folder, nsMsgKey key)
if (m_destFolders)
{
PRInt32 folderIndex = m_destFolders->IndexOf(folder);
nsMsgKeySet *keysToAdd;
nsMsgKeyArray *keysToAdd;
if (folderIndex >= 0)
{
keysToAdd = (nsMsgKeySet *) m_sourceKeySets.ElementAt(folderIndex);
keysToAdd = (nsMsgKeyArray *) m_sourceKeyArrays.ElementAt(folderIndex);
}
else
{
@ -60,11 +60,11 @@ nsresult nsImapMoveCoalescer::AddMove(nsIMsgFolder *folder, nsMsgKey key)
if (supports)
{
m_destFolders->AppendElement(supports);
keysToAdd = nsMsgKeySet::Create();
keysToAdd = new nsMsgKeyArray;
if (!keysToAdd)
return NS_ERROR_OUT_OF_MEMORY;
m_sourceKeySets.AppendElement(keysToAdd);
m_sourceKeyArrays.AppendElement(keysToAdd);
}
}
if (keysToAdd)
@ -92,25 +92,22 @@ nsresult nsImapMoveCoalescer::PlaybackMoves(nsIEventQueue *eventQueue)
NS_WITH_SERVICE(nsIImapService, imapService, kCImapService, &rv);
if (NS_SUCCEEDED(rv) && imapService)
{
nsMsgKeySet *keysToAdd = (nsMsgKeySet *) m_sourceKeySets.ElementAt(i);
nsMsgKeyArray *keysToAdd = (nsMsgKeyArray *) m_sourceKeyArrays.ElementAt(i);
if (keysToAdd)
{
char *messageIds = keysToAdd->Output();
if (messageIds)
{
nsCOMPtr <nsISupports> sourceSupports = do_QueryInterface((nsIMsgImapMailFolder *) m_sourceFolder, &rv);
nsCOMPtr <nsIUrlListener> urlListener(do_QueryInterface(sourceSupports));
rv = imapService->OnlineMessageCopy(eventQueue,
m_sourceFolder, messageIds,
destFolder, PR_TRUE, PR_TRUE,
urlListener, nsnull, nsnull);
delete [] messageIds;
}
else
{
rv = NS_ERROR_OUT_OF_MEMORY;
break;
}
nsCString messageIds;
nsImapMailFolder::AllocateUidStringFromKeyArray(*keysToAdd, messageIds);
destFolder->SetNumNewMessages(keysToAdd->GetSize());
destFolder->SetBiffState(nsMsgBiffState_NewMail);
nsCOMPtr <nsISupports> sourceSupports = do_QueryInterface((nsIMsgImapMailFolder *) m_sourceFolder, &rv);
nsCOMPtr <nsIUrlListener> urlListener(do_QueryInterface(sourceSupports));
rv = imapService->OnlineMessageCopy(eventQueue,
m_sourceFolder, messageIds.GetBuffer(),
destFolder, PR_TRUE, PR_TRUE,
urlListener, nsnull, nsnull);
}
}
}

Просмотреть файл

@ -43,7 +43,7 @@ public:
nsresult PlaybackMoves(nsIEventQueue *eventQueue);
protected:
// m_sourceKeySets and m_destFolders are parallel arrays.
nsVoidArray m_sourceKeySets;
nsVoidArray m_sourceKeyArrays;
nsCOMPtr <nsISupportsArray> m_destFolders;
nsImapMailFolder *m_sourceFolder;
};