1999-04-21 20:17:23 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Netscape Public License
|
|
|
|
* Version 1.0 (the "NPL"); you may not use this file except in
|
|
|
|
* compliance with the NPL. You may obtain a copy of the NPL at
|
|
|
|
* http://www.mozilla.org/NPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the NPL is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* NPL.
|
|
|
|
*
|
|
|
|
* The Initial Developer of this code under the NPL is Netscape
|
|
|
|
* Communications Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1999 Netscape Communications Corporation. All Rights
|
|
|
|
* Reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "nsMsgUtils.h"
|
|
|
|
#include "nsString.h"
|
|
|
|
#include "nsFileSpec.h"
|
|
|
|
#include "nsIServiceManager.h"
|
1999-04-29 01:37:40 +00:00
|
|
|
#include "nsCOMPtr.h"
|
1999-06-02 01:03:41 +00:00
|
|
|
#include "nsString.h"
|
1999-04-21 20:17:23 +00:00
|
|
|
|
|
|
|
nsresult GetMessageServiceProgIDForURI(const char *uri, nsString &progID)
|
|
|
|
{
|
|
|
|
|
|
|
|
nsresult rv = NS_OK;
|
|
|
|
//Find protocol
|
|
|
|
nsString uriStr = uri;
|
|
|
|
PRInt32 pos = uriStr.Find(':');
|
|
|
|
if(pos == -1)
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
nsString protocol;
|
|
|
|
uriStr.Left(protocol, pos);
|
|
|
|
|
|
|
|
//Build message service progid
|
|
|
|
progID = "component://netscape/messenger/messageservice;type=";
|
|
|
|
progID += protocol;
|
|
|
|
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
nsresult GetMessageServiceFromURI(const char *uri, nsIMsgMessageService **messageService)
|
|
|
|
{
|
|
|
|
|
1999-06-04 22:07:26 +00:00
|
|
|
nsAutoString progID (eOneByte);
|
1999-04-21 20:17:23 +00:00
|
|
|
nsresult rv;
|
|
|
|
|
|
|
|
rv = GetMessageServiceProgIDForURI(uri, progID);
|
|
|
|
|
|
|
|
if(NS_SUCCEEDED(rv))
|
|
|
|
{
|
1999-06-04 22:07:26 +00:00
|
|
|
rv = nsServiceManager::GetService(progID.GetBuffer(), nsIMsgMessageService::GetIID(),
|
1999-04-21 20:17:23 +00:00
|
|
|
(nsISupports**)messageService, nsnull);
|
|
|
|
}
|
|
|
|
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
nsresult ReleaseMessageServiceFromURI(const char *uri, nsIMsgMessageService *messageService)
|
|
|
|
{
|
1999-06-04 22:07:26 +00:00
|
|
|
nsAutoString progID (eOneByte);
|
1999-04-21 20:17:23 +00:00
|
|
|
nsresult rv;
|
|
|
|
|
|
|
|
rv = GetMessageServiceProgIDForURI(uri, progID);
|
|
|
|
if(NS_SUCCEEDED(rv))
|
1999-06-04 22:07:26 +00:00
|
|
|
rv = nsServiceManager::ReleaseService(progID.GetBuffer(), messageService);
|
1999-04-21 20:17:23 +00:00
|
|
|
return rv;
|
|
|
|
}
|
1999-04-24 20:37:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
NS_IMPL_ISUPPORTS(nsMessageFromMsgHdrEnumerator, nsIEnumerator::GetIID())
|
|
|
|
|
|
|
|
nsMessageFromMsgHdrEnumerator::nsMessageFromMsgHdrEnumerator(nsIEnumerator *srcEnumerator,
|
|
|
|
nsIMsgFolder *folder)
|
|
|
|
{
|
|
|
|
NS_INIT_REFCNT();
|
|
|
|
|
1999-05-04 22:34:35 +00:00
|
|
|
mSrcEnumerator = dont_QueryInterface(srcEnumerator);
|
|
|
|
mFolder = dont_QueryInterface(folder);
|
1999-04-24 20:37:00 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
nsMessageFromMsgHdrEnumerator::~nsMessageFromMsgHdrEnumerator()
|
|
|
|
{
|
1999-05-04 22:34:35 +00:00
|
|
|
//member variables are nsCOMPtr's
|
1999-04-24 20:37:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP nsMessageFromMsgHdrEnumerator::First(void)
|
|
|
|
{
|
|
|
|
return mSrcEnumerator->First();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP nsMessageFromMsgHdrEnumerator::Next(void)
|
|
|
|
{
|
|
|
|
return mSrcEnumerator->Next();
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP nsMessageFromMsgHdrEnumerator::CurrentItem(nsISupports **aItem)
|
|
|
|
{
|
1999-04-29 01:37:40 +00:00
|
|
|
nsCOMPtr<nsISupports> currentItem;
|
|
|
|
nsCOMPtr<nsIMsgDBHdr> msgDBHdr;
|
|
|
|
nsCOMPtr<nsIMessage> message;
|
1999-04-24 20:37:00 +00:00
|
|
|
nsresult rv;
|
|
|
|
|
1999-04-29 01:37:40 +00:00
|
|
|
rv = mSrcEnumerator->CurrentItem(getter_AddRefs(currentItem));
|
1999-04-24 20:37:00 +00:00
|
|
|
if(NS_SUCCEEDED(rv))
|
1999-04-29 01:37:40 +00:00
|
|
|
{
|
|
|
|
msgDBHdr = do_QueryInterface(currentItem, &rv);
|
|
|
|
}
|
1999-04-24 20:37:00 +00:00
|
|
|
|
|
|
|
if(NS_SUCCEEDED(rv))
|
1999-04-29 01:37:40 +00:00
|
|
|
{
|
|
|
|
rv = mFolder->CreateMessageFromMsgDBHdr(msgDBHdr, getter_AddRefs(message));
|
|
|
|
}
|
1999-04-24 20:37:00 +00:00
|
|
|
|
|
|
|
if(NS_SUCCEEDED(rv))
|
1999-04-29 01:37:40 +00:00
|
|
|
{
|
1999-04-24 20:37:00 +00:00
|
|
|
*aItem = message;
|
1999-04-29 01:37:40 +00:00
|
|
|
NS_ADDREF(*aItem);
|
|
|
|
}
|
1999-04-24 20:37:00 +00:00
|
|
|
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP nsMessageFromMsgHdrEnumerator::IsDone(void)
|
|
|
|
{
|
|
|
|
return mSrcEnumerator->IsDone();
|
|
|
|
}
|
|
|
|
|
|
|
|
nsresult NS_NewMessageFromMsgHdrEnumerator(nsIEnumerator *srcEnumerator,
|
|
|
|
nsIMsgFolder *folder,
|
|
|
|
nsMessageFromMsgHdrEnumerator **messageEnumerator)
|
|
|
|
{
|
|
|
|
if(!messageEnumerator)
|
|
|
|
return NS_ERROR_NULL_POINTER;
|
|
|
|
|
|
|
|
*messageEnumerator = new nsMessageFromMsgHdrEnumerator(srcEnumerator, folder);
|
|
|
|
|
|
|
|
if(!messageEnumerator)
|
|
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
NS_ADDREF(*messageEnumerator);
|
|
|
|
return NS_OK;
|
|
|
|
|
1999-05-10 21:06:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Where should this live? It's a utility used to convert a string priority, e.g., "High, Low, Normal" to an enum.
|
|
|
|
// Perhaps we should have an interface that groups together all these utilities...
|
|
|
|
nsresult NS_MsgGetPriorityFromString(const char *priority, nsMsgPriority *outPriority)
|
|
|
|
{
|
|
|
|
if (!outPriority)
|
|
|
|
return NS_ERROR_NULL_POINTER;
|
|
|
|
|
|
|
|
nsMsgPriority retPriority = nsMsgPriorityNormal;
|
|
|
|
|
|
|
|
if (PL_strcasestr(priority, "Normal") != NULL)
|
|
|
|
retPriority = nsMsgPriorityNormal;
|
|
|
|
else if (PL_strcasestr(priority, "Lowest") != NULL)
|
|
|
|
retPriority = nsMsgPriorityLowest;
|
|
|
|
else if (PL_strcasestr(priority, "Highest") != NULL)
|
|
|
|
retPriority = nsMsgPriorityHighest;
|
|
|
|
else if (PL_strcasestr(priority, "High") != NULL ||
|
|
|
|
PL_strcasestr(priority, "Urgent") != NULL)
|
|
|
|
retPriority = nsMsgPriorityHigh;
|
|
|
|
else if (PL_strcasestr(priority, "Low") != NULL ||
|
|
|
|
PL_strcasestr(priority, "Non-urgent") != NULL)
|
|
|
|
retPriority = nsMsgPriorityLow;
|
|
|
|
else if (PL_strcasestr(priority, "1") != NULL)
|
|
|
|
retPriority = nsMsgPriorityHighest;
|
|
|
|
else if (PL_strcasestr(priority, "2") != NULL)
|
|
|
|
retPriority = nsMsgPriorityHigh;
|
|
|
|
else if (PL_strcasestr(priority, "3") != NULL)
|
|
|
|
retPriority = nsMsgPriorityNormal;
|
|
|
|
else if (PL_strcasestr(priority, "4") != NULL)
|
|
|
|
retPriority = nsMsgPriorityLow;
|
|
|
|
else if (PL_strcasestr(priority, "5") != NULL)
|
|
|
|
retPriority = nsMsgPriorityLowest;
|
|
|
|
else
|
|
|
|
retPriority = nsMsgPriorityNormal;
|
|
|
|
*outPriority = retPriority;
|
|
|
|
return NS_OK;
|
|
|
|
//return nsMsgNoPriority;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-05-12 03:16:20 +00:00
|
|
|
nsresult NS_MsgGetUntranslatedPriorityName (nsMsgPriority p, nsString2 *outName)
|
|
|
|
{
|
|
|
|
if (!outName)
|
|
|
|
return NS_ERROR_NULL_POINTER;
|
|
|
|
switch (p)
|
|
|
|
{
|
|
|
|
case nsMsgPriorityNotSet:
|
|
|
|
case nsMsgPriorityNone:
|
|
|
|
*outName = "None";
|
|
|
|
break;
|
|
|
|
case nsMsgPriorityLowest:
|
|
|
|
*outName = "Lowest";
|
|
|
|
break;
|
|
|
|
case nsMsgPriorityLow:
|
|
|
|
*outName = "Low";
|
|
|
|
break;
|
|
|
|
case nsMsgPriorityNormal:
|
|
|
|
*outName = "Normal";
|
|
|
|
break;
|
|
|
|
case nsMsgPriorityHigh:
|
|
|
|
*outName = "High";
|
|
|
|
break;
|
|
|
|
case nsMsgPriorityHighest:
|
|
|
|
*outName = "Highest";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
NS_ASSERTION(PR_FALSE, "invalid priority value");
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-06-08 05:08:31 +00:00
|
|
|
/* this used to be XP_StringHash2 from xp_hash.c */
|
|
|
|
/* phong's linear congruential hash */
|
|
|
|
static PRUint32 StringHash(const char *ubuf)
|
|
|
|
{
|
|
|
|
unsigned char * buf = (unsigned char*) ubuf;
|
|
|
|
PRUint32 h=1;
|
|
|
|
while(*buf) {
|
|
|
|
h = 0x63c63cd9*h + 0x9c39c33d + (int32)*buf;
|
|
|
|
buf++;
|
|
|
|
}
|
|
|
|
return h;
|
|
|
|
}
|
|
|
|
|
|
|
|
nsresult NS_MsgHashIfNecessary(nsString &name)
|
|
|
|
{
|
|
|
|
#if defined(XP_WIN16) || defined(XP_OS2)
|
|
|
|
const PRUint32 MAX_LEN = 8;
|
|
|
|
#elif defined(XP_MAC)
|
1999-06-08 18:33:30 +00:00
|
|
|
const PRUint32 MAX_LEN = 25;
|
1999-06-29 09:19:14 +00:00
|
|
|
#elif defined(XP_UNIX) || defined(XP_PC) || defined(XP_BEOS)
|
1999-06-08 05:08:31 +00:00
|
|
|
const PRUint32 MAX_LEN = 55;
|
|
|
|
#else
|
|
|
|
#error need_to_define_your_max_filename_length
|
|
|
|
#endif
|
|
|
|
nsAutoString str(name, eOneByte);
|
|
|
|
|
1999-06-08 21:25:39 +00:00
|
|
|
#ifdef DEBUG_sspitzer_
|
1999-06-08 05:08:31 +00:00
|
|
|
printf("in: %s\n",str.GetBuffer());
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Given a name, use either that name, if it fits on our
|
|
|
|
// filesystem, or a hashified version of it, if the name is too
|
|
|
|
// long to fit.
|
|
|
|
char hashedname[MAX_LEN + 1];
|
|
|
|
PRBool needshash = PL_strlen(str.GetBuffer()) > MAX_LEN;
|
|
|
|
#if defined(XP_WIN16) || defined(XP_OS2)
|
|
|
|
if (!needshash) {
|
|
|
|
needshash = PL_strchr(str.GetBuffer(), '.') != NULL ||
|
|
|
|
PL_strchr(str.GetBuffer(), ':') != NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
PL_strncpy(hashedname, str.GetBuffer(), MAX_LEN + 1);
|
|
|
|
if (needshash) {
|
|
|
|
PR_snprintf(hashedname + MAX_LEN - 8, 9, "%08lx",
|
|
|
|
(unsigned long) StringHash(str.GetBuffer()));
|
|
|
|
}
|
|
|
|
name = hashedname;
|
1999-06-08 21:25:39 +00:00
|
|
|
#ifdef DEBUG_sspitzer_
|
1999-06-08 05:08:31 +00:00
|
|
|
printf("out: %s\n",hashedname);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|