gecko-dev/lib/libmsg/msgdlqml.h

134 строки
4.3 KiB
C
Исходник Обычный вид История

1998-06-23 02:39:40 +04:00
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/NPL/
1998-06-23 02:39:40 +04:00
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
1998-06-23 02:39:40 +04:00
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is Netscape
1998-06-23 02:39:40 +04:00
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All
* Rights Reserved.
*
* Contributor(s):
1998-06-23 02:39:40 +04:00
*/
#ifndef MSG_DELIVER_QUEUED_MAIL_H
#define MSG_DELIVER_QUEUED_MAIL_H
class MSG_DeliverQueuedMailState
{
public:
MSG_DeliverQueuedMailState(const char *folderPath, MSG_Pane *pane);
virtual ~MSG_DeliverQueuedMailState();
void SetContext(MWContext *context) {m_context = context;}
int DeliverMoreQueued(URL_Struct* url);
int CloseDeliverQueuedSock(URL_Struct* url);
int DeliverDone();
/* IMAP online Sent Folder support */
void AppendToIMAPSentFolder();
void ImapAppendAddBccHeadersIfNeeded(URL_Struct *url);
void CreateIMAPSentFolder();
static void PostCreateIMAPSentFolder(URL_Struct *url,
int status,
MWContext *context);
static void PostAppendToIMAPSentFolder(URL_Struct *url,
int status,
MWContext *context);
static void PostListIMAPSentFolder(URL_Struct *url,
int status,
MWContext *context);
static void PostLiteSelectExitFunction(URL_Struct *url,
int status,
MWContext *context);
protected:
int DeliverQueuedMessage ();
int DeliverAsNews();
int DeliverAsMail();
int DoFcc();
int32 HackHeaders();
int32 DeliverQueuedLine(char *line, uint32 length);
static void msg_deliver_queued_message_as_news_exit(URL_Struct *url,
int status,
MWContext *context);
static void msg_deliver_queued_message_as_mail_exit(URL_Struct *url,
int status,
MWContext *context);
void DeliverAsMailExit(URL_Struct *url, int status);
void DeliverAsNewsExit(URL_Struct *url, int status);
void Error(const char *error_msg);
protected:
MSG_Pane *m_pane;
MWContext *m_context;
char *m_folderName; /* The full path of the queue folder. */
char *m_tmpName; /* The full path of the tmp file. */
XP_File m_infile; /* The queue file we're parsing. */
XP_File m_outfile; /* A tmp file for each message in turn. */
char *m_bcc, *m_to, *m_newsgroups, *m_fcc; /* The parsed mail and news recipients */
char *m_newshost; /* Optional host on which the groups reside. */
uint16 m_flags; /* Flags from the X-Mozilla-Status header */
int m_status;
XP_Bool m_done;
XP_Bool m_awaitingDelivery; /* This is set while we are waiting for
another URL to finish - it is used to
make intervening calls to
MSG_FinishDeliverQueued() to no-op.
*/
XP_Bool m_deliveryFailed; /* Set when delivery of one message failed,
but we want to continue on with the next.
*/
int m_deliveryFailureCount; /* So that we can tell whether it's ok to
zero the file at the end.
*/
int m_bogusMessageCount; /* If there are messages in the queue file
which oughtn't be there, this counts them.
*/
int32 m_unreadMessages; /* As we walk through the folder, we regenerate */
int32 m_totalMessages; /* the summary info. */
XP_Bool m_inhead;
uint32 m_position;
uint32 m_headersPosition;
uint32 m_flagsPosition;
char *m_obuffer;
uint32 m_obufferSize;
char *m_ibuffer;
uint32 m_ibufferSize;
uint32 m_ibufferFP;
char *m_headers;
uint32 m_headersSize;
uint32 m_headersFP;
/* Thermo stuff
*/
int32 m_msgNumber; /* The ordinal of the message in the file
(not counting expunged messages.) */
int32 m_folderSize; /* How big the queue folder is. */
int32 m_bytesRead; /* How many bytes into the file we are. */
/* IMAP online Sent Folder support */
MSG_FolderInfoMail *m_localFolderInfo;
MSG_IMAPFolderInfoMail *m_imapFolderInfo;
IDArray m_msgKeys;
};
#endif