Bug 530414 - Some /mailnews/local/src/nsLocalMailFolder.cpp cleanup; (Av2) Mostly "whitespaces", A few rewrites.

r+sr=bienvenu.
This commit is contained in:
Serge Gautherie 2010-02-08 00:49:45 +01:00
Родитель d74e23c15e
Коммит d86743fa9d
1 изменённых файлов: 112 добавлений и 88 удалений

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

@ -177,7 +177,8 @@ static PRBool
nsStringEndsWith(nsString& name, const char *ending)
{
PRInt32 len = name.Length();
if (len == 0) return PR_FALSE;
if (len == 0)
return PR_FALSE;
PRInt32 endingLen = strlen(ending);
return (len > endingLen && name.RFind(ending, PR_TRUE) == len - endingLen);
@ -279,6 +280,7 @@ nsresult nsMsgLocalMailFolder::CreateChildFromURI(const nsCString &uri, nsIMsgFo
nsMsgLocalMailFolder *newFolder = new nsMsgLocalMailFolder;
if (!newFolder)
return NS_ERROR_OUT_OF_MEMORY;
NS_ADDREF(*folder = newFolder);
newFolder->Init(uri.get());
return NS_OK;
@ -316,8 +318,8 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetManyHeadersToDownload(PRBool *retval)
*retval = PR_TRUE;
return NS_OK;
}
else
return nsMsgDBFolder::GetManyHeadersToDownload(retval);
return nsMsgDBFolder::GetManyHeadersToDownload(retval);
}
//run the url to parse the mailbox
@ -326,7 +328,8 @@ NS_IMETHODIMP nsMsgLocalMailFolder::ParseFolder(nsIMsgWindow *aMsgWindow, nsIUrl
nsresult rv;
nsCOMPtr<nsILocalFile> pathFile;
rv = GetFilePath(getter_AddRefs(pathFile));
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
nsCOMPtr<nsIMailboxService> mailboxService = do_GetService(kMailboxServiceCID, &rv);
NS_ENSURE_SUCCESS(rv, rv);
@ -337,14 +340,14 @@ NS_IMETHODIMP nsMsgLocalMailFolder::ParseFolder(nsIMsgWindow *aMsgWindow, nsIUrl
PRBool isLocked;
nsCOMPtr <nsISupports> supports = do_QueryInterface(static_cast<nsIMsgParseMailMsgState*>(parser));
GetLocked(&isLocked);
if(!isLocked)
AcquireSemaphore(supports);
else
if (isLocked)
{
NS_ASSERTION(PR_FALSE, "Could not get folder lock");
return NS_MSG_FOLDER_BUSY;
}
AcquireSemaphore(supports);
if (listener != this)
mReparseListener = listener;
@ -370,7 +373,8 @@ nsMsgLocalMailFolder::GetSubFolders(nsISimpleEnumerator **aResult)
if (!mInitialized) {
nsCOMPtr<nsILocalFile> path;
rv = GetFilePath(getter_AddRefs(path));
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
PRBool exists, directory;
path->Exists(&exists);
@ -419,13 +423,15 @@ nsMsgLocalMailFolder::GetSubFolders(nsISimpleEnumerator **aResult)
// now, discover those folders
rv = CreateSubFolders(path);
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
// must happen after CreateSubFolders, or the folders won't exist.
if (createdDefaultMailboxes && isServer)
{
rv = localMailServer->SetFlagsOnDefaultMailboxes();
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
}
/* we need to create all the folders at start-up because if a folder having subfolders is
@ -493,12 +499,15 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetDatabaseWithReparse(nsIUrlListener *aRepa
{
nsCOMPtr <nsILocalFile> pathFile;
rv = GetFilePath(getter_AddRefs(pathFile));
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
PRBool exists;
rv = pathFile->Exists(&exists);
NS_ENSURE_SUCCESS(rv,rv);
if (!exists)
return NS_ERROR_NULL_POINTER; //mDatabase will be null at this point.
nsCOMPtr<nsIMsgDBService> msgDBService = do_GetService(NS_MSGDB_SERVICE_CONTRACTID, &rv);
NS_ENSURE_SUCCESS(rv, rv);
@ -557,16 +566,16 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetDatabaseWithReparse(nsIUrlListener *aRepa
msgDBService->CreateNewDB(this, getter_AddRefs(mDatabase));
}
if(mDatabase)
if (mDatabase)
{
if(mAddListener)
if (mAddListener)
mDatabase->AddListener(this);
// if we have to regenerate the folder, run the parser url.
if (folderOpen == NS_MSG_ERROR_FOLDER_SUMMARY_MISSING ||
folderOpen == NS_MSG_ERROR_FOLDER_SUMMARY_OUT_OF_DATE)
{
if(NS_FAILED(rv = ParseFolder(aMsgWindow, aReparseUrlListener)))
if (NS_FAILED(rv = ParseFolder(aMsgWindow, aReparseUrlListener)))
{
if (rv == NS_MSG_FOLDER_BUSY)
{
@ -576,14 +585,12 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetDatabaseWithReparse(nsIUrlListener *aRepa
}
return rv;
}
else
return NS_ERROR_NOT_INITIALIZED;
}
else
{
// We have a valid database so lets extract necessary info.
UpdateSummaryTotals(PR_TRUE);
return NS_ERROR_NOT_INITIALIZED;
}
// We have a valid database so lets extract necessary info.
UpdateSummaryTotals(PR_TRUE);
}
}
NS_IF_ADDREF(*aMsgDatabase = mDatabase);
@ -601,7 +608,7 @@ nsMsgLocalMailFolder::UpdateFolder(nsIMsgWindow *aWindow)
//If we don't currently have a database, get it. Otherwise, the folder has been updated (presumably this
//changes when we download headers when opening inbox). If it's updated, send NotifyFolderLoaded.
if(!mDatabase)
if (!mDatabase)
// return of NS_ERROR_NOT_INITIALIZED means running parsing URL
rv = GetDatabaseWithReparse(this, aWindow, getter_AddRefs(mDatabase));
else
@ -648,7 +655,8 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetFolderURL(nsACString& aUrl)
nsresult rv;
nsCOMPtr<nsILocalFile> path;
rv = GetFilePath(getter_AddRefs(path));
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
rv = NS_GetURLSpecFromFile(path, aUrl);
NS_ENSURE_SUCCESS(rv, rv);
@ -700,6 +708,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::CreateStorageIfMissing(nsIUrlListener* aUrlL
if (rv == NS_MSG_FOLDER_EXISTS)
return NS_OK;
}
return rv;
}
@ -723,14 +732,15 @@ nsMsgLocalMailFolder::CreateSubfolderInternal(const nsAString& folderName,
nsIMsgFolder **aNewFolder)
{
nsresult rv = CheckIfFolderExists(folderName, this, msgWindow);
if(NS_FAILED(rv)) //we already throw an alert - no need for an assertion
// No need for an assertion: we already throw an alert.
if (NS_FAILED(rv))
return rv;
nsCOMPtr <nsILocalFile> path;
nsCOMPtr<nsIMsgFolder> child;
//Get a directory based on our current path.
rv = CreateDirectoryForFolder(getter_AddRefs(path));
if(NS_FAILED(rv))
if (NS_FAILED(rv))
return rv;
//Now we have a valid directory or we have returned.
@ -779,7 +789,7 @@ nsMsgLocalMailFolder::CreateSubfolderInternal(const nsAString& folderName,
//need to set the folder name
nsCOMPtr<nsIDBFolderInfo> folderInfo;
rv = unusedDB->GetDBFolderInfo(getter_AddRefs(folderInfo));
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
folderInfo->SetMailboxName(safeFolderName);
}
@ -793,7 +803,7 @@ nsMsgLocalMailFolder::CreateSubfolderInternal(const nsAString& folderName,
rv = NS_MSG_CANT_CREATE_FOLDER;
}
}
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
//we need to notify explicitly the flag change because it failed when we did AddSubfolder
child->OnFlagChange(mFlags);
@ -845,9 +855,8 @@ NS_IMETHODIMP nsMsgLocalMailFolder::CompactAll(nsIUrlListener *aListener,
}
nsCOMPtr <nsIMsgFolderCompactor> folderCompactor = do_CreateInstance(NS_MSGLOCALFOLDERCOMPACTOR_CONTRACTID, &rv);
NS_ENSURE_SUCCESS(rv, rv);
return folderCompactor->CompactFolders(folderArray,
nsnull,
aListener, aMsgWindow);
return folderCompactor->CompactFolders(folderArray, nsnull,
aListener, aMsgWindow);
}
NS_IMETHODIMP nsMsgLocalMailFolder::Compact(nsIUrlListener *aListener, nsIMsgWindow *aMsgWindow)
@ -953,15 +962,21 @@ nsresult nsMsgLocalMailFolder::IsChildOfTrash(PRBool *result)
thisFolder->GetParent(getter_AddRefs(parentFolder));
if (!parentFolder)
return NS_OK;
rv = parentFolder->GetIsServer(&isServer);
if (NS_FAILED(rv) || isServer) return NS_OK;
if (NS_FAILED(rv) || isServer)
return NS_OK;
rv = parentFolder->GetFlags(&parentFlags);
if (NS_FAILED(rv)) return NS_OK;
if (NS_FAILED(rv))
return NS_OK;
if (parentFlags & nsMsgFolderFlags::Trash)
{
*result = PR_TRUE;
return rv;
}
thisFolder = parentFolder;
}
return rv;
@ -981,7 +996,8 @@ NS_IMETHODIMP nsMsgLocalMailFolder::Delete()
nsCOMPtr<nsILocalFile> pathFile;
rv = GetFilePath(getter_AddRefs(pathFile));
if (NS_FAILED(rv)) return rv;
if (NS_FAILED(rv))
return rv;
nsCOMPtr <nsILocalFile> summaryFile;
rv = GetSummaryFileLocation(pathFile, getter_AddRefs(summaryFile));
@ -1001,7 +1017,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::Delete()
isDirectory = PR_FALSE;
pathFile->IsDirectory(&isDirectory);
//If this is a directory, then remove it.
return (isDirectory) ? pathFile->Remove(PR_TRUE) : NS_OK;
return isDirectory ? pathFile->Remove(PR_TRUE) : NS_OK;
}
NS_IMETHODIMP nsMsgLocalMailFolder::DeleteSubFolders(nsIArray *folders, nsIMsgWindow *msgWindow)
@ -1105,21 +1121,22 @@ NS_IMETHODIMP nsMsgLocalMailFolder::Rename(const nsAString& aNewName, nsIMsgWind
return NS_OK;
nsCOMPtr<nsILocalFile> oldPathFile;
nsCOMPtr<nsIAtom> folderRenameAtom;
nsresult rv = GetFilePath(getter_AddRefs(oldPathFile));
if (NS_FAILED(rv))
return rv;
nsCOMPtr<nsIMsgFolder> parentFolder;
rv = GetParent(getter_AddRefs(parentFolder));
if (!parentFolder)
return NS_ERROR_NULL_POINTER;
nsCOMPtr<nsISupports> parentSupport = do_QueryInterface(parentFolder);
nsCOMPtr <nsILocalFile> oldSummaryFile;
rv = GetSummaryFileLocation(oldPathFile, getter_AddRefs(oldSummaryFile));
NS_ENSURE_SUCCESS(rv, rv);
nsCOMPtr <nsILocalFile> dirFile;
nsCOMPtr <nsILocalFile> dirFile;
PRInt32 count = mSubFolders.Count();
if (count > 0)
@ -1143,41 +1160,37 @@ NS_IMETHODIMP nsMsgLocalMailFolder::Rename(const nsAString& aNewName, nsIMsgWind
if (mName.Equals(aNewName, CaseInsensitiveCompare))
#endif
{
if(msgWindow)
if (msgWindow)
rv = ThrowAlertMsg("folderExists", msgWindow);
return NS_MSG_FOLDER_EXISTS;
}
else
{
nsCOMPtr <nsILocalFile> parentPathFile;
parentFolder->GetFilePath(getter_AddRefs(parentPathFile));
NS_ENSURE_SUCCESS(rv,rv);
PRBool isDirectory = PR_FALSE;
parentPathFile->IsDirectory(&isDirectory);
if (!isDirectory)
AddDirectorySeparator(parentPathFile);
nsCOMPtr<nsILocalFile> parentPathFile;
parentFolder->GetFilePath(getter_AddRefs(parentPathFile));
NS_ENSURE_SUCCESS(rv,rv);
rv = CheckIfFolderExists(aNewName, parentFolder, msgWindow);
if (NS_FAILED(rv))
return rv;
}
PRBool isDirectory = PR_FALSE;
parentPathFile->IsDirectory(&isDirectory);
if (!isDirectory)
AddDirectorySeparator(parentPathFile);
rv = CheckIfFolderExists(aNewName, parentFolder, msgWindow);
if (NS_FAILED(rv))
return rv;
ForceDBClosed();
nsCAutoString newNameDirStr = newDiskName; //save of dir name before appending .msf
rv = oldPathFile->MoveToNative(nsnull, newDiskName);
if (NS_SUCCEEDED(rv))
{
newDiskName += SUMMARY_SUFFIX;
oldSummaryFile->MoveToNative(nsnull, newDiskName);
}
else
if (NS_FAILED(rv))
{
ThrowAlertMsg("folderRenameFailed", msgWindow);
return rv;
}
if (NS_SUCCEEDED(rv) && count > 0)
newDiskName += SUMMARY_SUFFIX;
oldSummaryFile->MoveToNative(nsnull, newDiskName);
if (count > 0)
{
// rename "*.sbd" directory
newNameDirStr += ".sbd";
@ -1218,7 +1231,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::Rename(const nsAString& aNewName, nsIMsgWind
parentFolder->NotifyItemAdded(newFolder);
}
SetFilePath(nsnull); // forget our path, since this folder object renamed itself
folderRenameAtom = do_GetAtom("RenameCompleted");
nsCOMPtr<nsIAtom> folderRenameAtom = do_GetAtom("RenameCompleted");
newFolder->NotifyFolderEvent(folderRenameAtom);
nsCOMPtr<nsIMsgFolderNotificationService> notifier(do_GetService(NS_MSGNOTIFICATIONSERVICE_CONTRACTID));
@ -1332,7 +1345,7 @@ nsresult nsMsgLocalMailFolder::OpenDatabase()
NS_IMETHODIMP
nsMsgLocalMailFolder::GetDBFolderInfoAndDB(nsIDBFolderInfo **folderInfo, nsIMsgDatabase **db)
{
if(!db || !folderInfo || !mPath || mIsServer)
if (!db || !folderInfo || !mPath || mIsServer)
return NS_ERROR_NULL_POINTER; //ducarroz: should we use NS_ERROR_INVALID_ARG?
nsresult rv;
@ -1394,8 +1407,10 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetRequiresCleanup(PRBool *requiresCleanup)
PRBool purgePrompt = m_master->GetPrefs()->GetPurgeThreshholdEnabled();
return (purgePrompt && m_expungedBytes / 1000L > purgeThreshhold);
}
return PR_FALSE;
#endif
return NS_OK;
}
@ -1434,7 +1449,7 @@ nsMsgLocalMailFolder::GetTrashFolder(nsIMsgFolder** result)
nsresult rv;
nsCOMPtr<nsIMsgFolder> rootFolder;
rv = GetRootFolder(getter_AddRefs(rootFolder));
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
rootFolder->GetFolderWithFlags(nsMsgFolderFlags::Trash, result);
if (!*result)
@ -1488,7 +1503,7 @@ nsMsgLocalMailFolder::DeleteMessages(nsIArray *messages,
{
nsCOMPtr <nsIMsgDatabase> msgDB;
rv = GetDatabaseWOReparse(getter_AddRefs(msgDB));
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
if (deleteStorage && isMove && GetDeleteFromServerOnMove())
MarkMsgsOnPop3Server(messages, POP3_DELETE);
@ -1497,7 +1512,7 @@ nsMsgLocalMailFolder::DeleteMessages(nsIArray *messages,
rv = EnableNotifications(allMessageCountNotifications, PR_FALSE, PR_TRUE /*dbBatching*/);
if (NS_SUCCEEDED(rv))
{
for(PRUint32 i = 0; i < messageCount; i++)
for (PRUint32 i = 0; i < messageCount; ++i)
{
msgSupport = do_QueryElementAt(messages, i, &rv);
if (msgSupport)
@ -1511,7 +1526,7 @@ nsMsgLocalMailFolder::DeleteMessages(nsIArray *messages,
//enable notifications because that will close the file stream
// we've been caching, mark the db as valid, and commit it.
EnableNotifications(allMessageCountNotifications, PR_TRUE, PR_TRUE /*dbBatching*/);
if(!isMove)
if (!isMove)
NotifyFolderEvent(NS_SUCCEEDED(rv) ? mDeleteOrMoveMsgCompletedAtom : mDeleteOrMoveMsgFailedAtom);
if (msgWindow && !isMove)
AutoCompact(msgWindow);
@ -1546,11 +1561,11 @@ nsMsgLocalMailFolder::InitCopyState(nsISupports* aSupport,
PRBool isLocked;
GetLocked(&isLocked);
if(!isLocked)
AcquireSemaphore(static_cast<nsIMsgLocalMailFolder*>(this));
else
if (isLocked)
return NS_MSG_FOLDER_BUSY;
AcquireSemaphore(static_cast<nsIMsgLocalMailFolder*>(this));
rv = GetFilePath(getter_AddRefs(path));
NS_ENSURE_SUCCESS(rv, rv);
@ -1748,7 +1763,7 @@ nsMsgLocalMailFolder::CopyMessages(nsIMsgFolder* srcFolder, nsIArray*
for (PRUint32 i = 0; i < numMsgs; i++)
{
nsCOMPtr<nsIMsgDBHdr> aMessage = do_QueryElementAt(messages, i, &rv);
if(NS_SUCCEEDED(rv) && aMessage)
if (NS_SUCCEEDED(rv) && aMessage)
{
nsMsgKey key;
aMessage->GetMessageKey(&key);
@ -2011,7 +2026,7 @@ nsMsgLocalMailFolder::CopyFolderLocal(nsIMsgFolder *srcFolder,
}
rv = CheckIfFolderExists(folderName, this, msgWindow);
if(NS_FAILED(rv))
if (NS_FAILED(rv))
return rv;
nsCOMPtr <nsIFile> origPath;
@ -2243,7 +2258,7 @@ nsMsgLocalMailFolder::CopyFileMessage(nsIFile* aFile,
inputStream->Close();
}
if(NS_FAILED(rv))
if (NS_FAILED(rv))
(void) OnCopyCompleted(fileSupport, PR_FALSE);
return rv;
@ -2258,7 +2273,7 @@ nsresult nsMsgLocalMailFolder::DeleteMessage(nsISupports *message,
{
nsCOMPtr <nsIMsgDBHdr> msgDBHdr(do_QueryInterface(message, &rv));
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
GetDatabase();
if (mDatabase)
@ -2286,7 +2301,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::GetNewMessages(nsIMsgWindow *aWindow, nsIUrl
nsCOMPtr<nsIMsgFolder> inbox;
nsCOMPtr<nsIMsgFolder> rootFolder;
rv = server->GetRootMsgFolder(getter_AddRefs(rootFolder));
if(NS_SUCCEEDED(rv) && rootFolder)
if (NS_SUCCEEDED(rv) && rootFolder)
{
rootFolder->GetFolderWithFlags(nsMsgFolderFlags::Inbox, getter_AddRefs(inbox));
}
@ -2401,9 +2416,9 @@ NS_IMETHODIMP nsMsgLocalMailFolder::CopyData(nsIInputStream *aIStream, PRInt32 a
nsresult rv = NS_OK;
rv = TestSemaphore(static_cast<nsIMsgLocalMailFolder*>(this), &haveSemaphore);
if(NS_FAILED(rv))
if (NS_FAILED(rv))
return rv;
if(!haveSemaphore)
if (!haveSemaphore)
return NS_MSG_FOLDER_BUSY;
if (!mCopyState)
@ -2418,6 +2433,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::CopyData(nsIInputStream *aIStream, PRInt32 a
char *newBuffer = (char *) PR_REALLOC(mCopyState->m_dataBuffer, aLength + mCopyState->m_leftOver + 4);
if (!newBuffer)
return NS_ERROR_OUT_OF_MEMORY;
mCopyState->m_dataBuffer = newBuffer;
mCopyState->m_dataBufferSize = aLength + mCopyState->m_leftOver + 3;
}
@ -2550,9 +2566,12 @@ void nsMsgLocalMailFolder::CopyPropertiesToMsgHdr(nsIMsgDBHdr *destHdr,
NS_IMETHODIMP nsMsgLocalMailFolder::EndCopy(PRBool copySucceeded)
{
if (!mCopyState)
return NS_OK;
// we are the destination folder for a move/copy
nsresult rv = copySucceeded ? NS_OK : NS_ERROR_FAILURE;
if (!mCopyState) return NS_OK;
if (!copySucceeded || mCopyState->m_writeFailed)
{
if (mCopyState->m_fileStream)
@ -2606,9 +2625,9 @@ NS_IMETHODIMP nsMsgLocalMailFolder::EndCopy(PRBool copySucceeded)
{
// CopyMessages() goes here, and CopyFileMessages() with metadata to save;
nsCOMPtr<nsIMsgDBHdr> newHdr;
if(!mCopyState->m_parseMsgState)
if (!mCopyState->m_parseMsgState)
{
if(mCopyState->m_destDB)
if (mCopyState->m_destDB)
{
rv = mCopyState->m_destDB->CopyHdrFromExistingHdr(mCopyState->m_curDstKey,
mCopyState->m_message, PR_TRUE,
@ -2740,7 +2759,7 @@ NS_IMETHODIMP nsMsgLocalMailFolder::EndCopy(PRBool copySucceeded)
this, mCopyState->m_destMessages);
}
if(!mCopyState->m_isMove)
if (!mCopyState->m_isMove)
{
if (multipleCopiesFinished)
{
@ -2981,7 +3000,7 @@ nsresult nsMsgLocalMailFolder::CopyMessagesTo(nsIArray *messages, nsTArray<nsMsg
NS_ENSURE_SUCCESS(rv, NS_ERROR_NO_INTERFACE);
rv = copyStreamListener->Init(srcFolder, copyListener, nsnull);
if(NS_FAILED(rv))
if (NS_FAILED(rv))
return rv;
if (!mCopyState->m_messageService)
@ -3038,7 +3057,7 @@ nsresult nsMsgLocalMailFolder::CopyMessageTo(nsISupports *message,
NS_ENSURE_SUCCESS(rv, NS_ERROR_NO_INTERFACE);
rv = copyStreamListener->Init(srcFolder, copyListener, nsnull);
if(NS_FAILED(rv))
if (NS_FAILED(rv))
return rv;
if (!mCopyState->m_messageService)
@ -3216,7 +3235,6 @@ NS_IMETHODIMP nsMsgLocalMailFolder::DeleteDownloadMsg(nsIMsgDBHdr *aMsgHdr, PRBo
NS_IMETHODIMP nsMsgLocalMailFolder::SelectDownloadMsg()
{
#if DOWNLOAD_NOTIFY_STYLE == DOWNLOAD_NOTIFY_LAST
if (mDownloadState >= DOWNLOAD_STATE_GOTMSG)
{
@ -3296,14 +3314,17 @@ nsMsgLocalMailFolder::GetIncomingServerType(nsCString& aServerType)
if (mType.IsEmpty())
{
nsCOMPtr<nsIURL> url = do_CreateInstance(NS_STANDARDURL_CONTRACTID, &rv);
if (NS_FAILED(rv)) return;
if (NS_FAILED(rv))
return;
rv = url->SetSpec(mURI);
if (NS_FAILED(rv)) return;
if (NS_FAILED(rv))
return;
nsCOMPtr<nsIMsgAccountManager> accountManager =
do_GetService(NS_MSGACCOUNTMANAGER_CONTRACTID, &rv);
if (NS_FAILED(rv)) return;
if (NS_FAILED(rv))
return;
nsCOMPtr<nsIMsgIncomingServer> server;
// try "none" first
@ -3382,6 +3403,7 @@ nsMsgLocalMailFolder::OnStopRunningUrl(nsIURI * aUrl, nsresult aExitCode)
mDownloadWindow = nsnull;
return nsMsgDBFolder::OnStopRunningUrl(aUrl, aExitCode);
}
nsresult rv;
if (NS_SUCCEEDED(aExitCode))
{
@ -3404,7 +3426,7 @@ nsMsgLocalMailFolder::OnStopRunningUrl(nsIURI * aUrl, nsresult aExitCode)
NS_ENSURE_SUCCESS(rv, rv);
nsCOMPtr <nsIMsgDBHdr> msgDBHdr;
rv = GetMsgDBHdrFromURI(messageuri.get(), getter_AddRefs(msgDBHdr));
if(NS_SUCCEEDED(rv))
if (NS_SUCCEEDED(rv))
{
GetDatabase();
if (mDatabase)
@ -3478,6 +3500,7 @@ nsresult nsMsgLocalMailFolder::DisplayMoveCopyStatusMsg()
mCopyState->m_undoMsgTxn->GetMsgWindow(getter_AddRefs(msgWindow));
if (!msgWindow)
return NS_OK; // not a fatal error.
msgWindow->GetStatusFeedback(getter_AddRefs(mCopyState->m_statusFeedback));
}
@ -3856,11 +3879,11 @@ nsMsgLocalMailFolder::AddMessage(const char *aMessage)
PRBool isLocked;
GetLocked(&isLocked);
if(!isLocked)
AcquireSemaphore(static_cast<nsIMsgLocalMailFolder*>(this));
else
if (isLocked)
return NS_MSG_FOLDER_BUSY;
AcquireSemaphore(static_cast<nsIMsgLocalMailFolder*>(this));
nsCOMPtr <nsIInputStream> inputStream = do_QueryInterface(outFileStream);
rv = newMailParser->Init(rootFolder, this,
path, inputStream, nsnull, PR_FALSE);
@ -3963,6 +3986,7 @@ nsresult nsMsgLocalMailFolder::ChangeKeywordForMessages(nsIArray *aMessages, con
rv = GetDatabase();
if (!mDatabase)
return rv;
// this will fail if the folder is locked.
rv = mDatabase->StartBatch();
NS_ENSURE_SUCCESS(rv, rv);
@ -3993,7 +4017,7 @@ nsresult nsMsgLocalMailFolder::ChangeKeywordForMessages(nsIArray *aMessages, con
// on the header, which the compaction code will check.
// don't return out of the for loop - otherwise, we won't call EndBatch();
for(PRUint32 i = 0; i < count; i++) // for each message
for (PRUint32 i = 0; i < count; ++i) // for each message
{
nsCOMPtr<nsIMsgDBHdr> message = do_QueryElementAt(aMessages, i, &rv);
NS_ENSURE_SUCCESS(rv, rv);