Windows2003-3790/inetcore/published/inc/msoeapi.idl
2020-09-30 16:53:55 +02:00

613 lines
36 KiB
Plaintext

//+-------------------------------------------------------------------------
//
// Copyright (C) Microsoft Corporation, 1997-1998
//
// File: oestore.idl
//
// Contents: Outlook Express API
//
// History: 11-Oct-1997 SteveBailey Created
//
//--------------------------------------------------------------------------
import "ocidl.idl";
import "objidl.idl";
cpp_quote("#ifndef OE5_BETA2")
import "mimeole.idl";
cpp_quote("#endif")
//+-------------------------------------------------------------------------
// Interfaces
//--------------------------------------------------------------------------
interface IOutlookExpress;
cpp_quote("#ifndef OE5_BETA2")
interface IStoreNamespace;
interface IStoreFolder;
cpp_quote("#endif")
interface IOEMenuExtension;
interface IOEExtension;
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// GUID Definitions")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#pragma comment(lib,\"uuid.lib\")")
cpp_quote("")
cpp_quote("// {3338DF69-4660-11d1-8A8D-00C04FB951F3}")
cpp_quote("DEFINE_GUID(CLSID_OutlookExpress, 0x3338df69, 0x4660, 0x11d1, 0x8a, 0x8d, 0x0, 0xc0, 0x4f, 0xb9, 0x51, 0xf3);")
cpp_quote("")
cpp_quote("// {0006F01A-0000-0000-C000-0000000046}")
cpp_quote("DEFINE_GUID(CLSID_Envelope, 0x0006F01A, 0x0000, 0x0000, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x46);")
cpp_quote("")
cpp_quote("// {3338DF6A-4660-11d1-8A8D-00C04FB951F3}")
cpp_quote("DEFINE_GUID(IID_IOutlookExpress, 0x3338df6a, 0x4660, 0x11d1, 0x8a, 0x8d, 0x00, 0xc0, 0x4f, 0xb9, 0x51, 0xf3);")
cpp_quote("")
cpp_quote("#ifndef OE5_BETA2")
cpp_quote("// {E70C92A9-4BFD-11d1-8A95-00C04FB951F3}")
cpp_quote("DEFINE_GUID(CLSID_StoreNamespace, 0xe70c92a9, 0x4bfd, 0x11d1, 0x8a, 0x95, 0x0, 0xc0, 0x4f, 0xb9, 0x51, 0xf3);")
cpp_quote("")
cpp_quote("// {E70C92AA-4BFD-11d1-8A95-00C04FB951F3}")
cpp_quote("DEFINE_GUID(IID_IStoreNamespace, 0xe70c92aa, 0x4bfd, 0x11d1, 0x8a, 0x95, 0x0, 0xc0, 0x4f, 0xb9, 0x51, 0xf3);")
cpp_quote("")
cpp_quote("// {E70C92AC-4BFD-11d1-8A95-00C04FB951F3}")
cpp_quote("DEFINE_GUID(IID_IStoreFolder, 0xe70c92ac, 0x4bfd, 0x11d1, 0x8a, 0x95, 0x0, 0xc0, 0x4f, 0xb9, 0x51, 0xf3);")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// Errors Definition Macros")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#ifndef FACILITY_INTERNET")
cpp_quote("#define FACILITY_INTERNET 12")
cpp_quote("#endif")
cpp_quote("#ifndef HR_E")
cpp_quote("#define HR_E(n) MAKE_SCODE(SEVERITY_ERROR, FACILITY_INTERNET, n)")
cpp_quote("#endif")
cpp_quote("#ifndef HR_S")
cpp_quote("#define HR_S(n) MAKE_SCODE(SEVERITY_SUCCESS, FACILITY_INTERNET, n)")
cpp_quote("#endif")
cpp_quote("#ifndef HR_CODE")
cpp_quote("#define HR_CODE(hr) (INT)(hr & 0xffff)")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// MSOEAPI Failure Return Values")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#define MSOEAPI_E_FILE_NOT_FOUND HR_E(0xCF65)")
cpp_quote("#define MSOEAPI_E_STORE_INITIALIZE HR_E(0xCF66)")
cpp_quote("#define MSOEAPI_E_INVALID_STRUCT_SIZE HR_E(0xCF67)")
cpp_quote("#define MSOEAPI_E_CANT_LOAD_MSOERT HR_E(0xCF68)")
cpp_quote("#define MSOEAPI_E_CANT_LOAD_INETCOMM HR_E(0xCF69)")
cpp_quote("#define MSOEAPI_E_CANT_LOAD_MSOEACCT HR_E(0xCF70)")
cpp_quote("#define MSOEAPI_E_CANT_MSOERT_BADVER HR_E(0xCF71)")
cpp_quote("#define MSOEAPI_E_CANT_INETCOMM_BADVER HR_E(0xCF72)")
cpp_quote("#define MSOEAPI_E_CANT_MSOEACCT_BADVER HR_E(0xCF73)")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// String Definition Macros")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#ifdef __cplusplus")
cpp_quote("#define EXTERN_C extern \"C\"")
cpp_quote("#else")
cpp_quote("#define EXTERN_C extern")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("#ifndef STRCONSTA")
cpp_quote("#ifdef DEFINE_STRCONST")
cpp_quote("#define STRCONSTA(x,y) EXTERN_C const char x[] = y")
cpp_quote("#define STRCONSTW(x,y) EXTERN_C const WCHAR x[] = L##y")
cpp_quote("#else")
cpp_quote("#define STRCONSTA(x,y) EXTERN_C const char x[]")
cpp_quote("#define STRCONSTW(x,y) EXTERN_C const WCHAR x[]")
cpp_quote("#endif STRCONSTA")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// Strings")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("STRCONSTA(STR_MSOEAPI_INSTANCECLASS, \"OutlookExpressHiddenWindow\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_IPSERVERCLASS, \"OutlookExpressInProccessServer\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_INSTANCEMUTEX, \"OutlookExpress_InstanceMutex_101897\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_DLLNAME, \"MSOE.DLL\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_START, \"CoStartOutlookExpress\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_SHUTDOWN, \"CoShutdownOutlookExpress\");")
cpp_quote("STRCONSTA(STR_MSOEAPI_CREATE, \"CoCreateOutlookExpress\");")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// Function Typedefs")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("typedef HRESULT (APIENTRY *PFNSTART)(DWORD dwFlags, LPCSTR pszCmdLine, INT nCmdShow);")
cpp_quote("typedef HRESULT (APIENTRY *PFNSHUTDOWN)(DWORD dwReserved);")
cpp_quote("typedef HRESULT (APIENTRY *PFNCREATE)(IUnknown *pUnkOuter, IUnknown **ppUnknown);")
cpp_quote("")
//+-------------------------------------------------------------------------
// Constants
//--------------------------------------------------------------------------
const DWORD MSOEAPI_ACDM_CMDLINE = 1;
const DWORD MSOEAPI_ACDM_NOTIFY = 2;
const DWORD MSOEAPI_ACDM_ODBNOTIFY = 3;
const DWORD MSOEAPI_ACDM_STGNOTIFY = 4;
//+-------------------------------------------------------------------------
// DECLARE_HANDLE Macro
//--------------------------------------------------------------------------
#ifndef DECLARE_HANDLE
#define DECLARE_HANDLE(name) \
struct name##__ { DWORD unused; }; \
typedef struct name##__ _far* name
#endif
//+-------------------------------------------------------------------------
// HENUMSTORE
//--------------------------------------------------------------------------
cpp_quote("#ifndef OE5_BETA2")
DECLARE_HANDLE(HENUMSTORE);
typedef HENUMSTORE *LPHENUMSTORE;
cpp_quote("#endif // OE5_BETA2")
//+-------------------------------------------------------------------------
//
// Copyright (C) Microsoft Corporation, 1995-1998.
//
// Contents: IOutlookExpress
//
// History: 11-Oct-1997 SteveBailey Created
//
//--------------------------------------------------------------------------
cpp_quote("#ifndef __LPOUTLOOKEXPRESS_DEFINED")
cpp_quote("#define __LPOUTLOOKEXPRESS_DEFINED")
[
object,
uuid(3338DF6A-4660-11d1-8A8D-00C04FB951F3),
pointer_default(unique)
]
interface IOutlookExpress : IUnknown
{
typedef IOutlookExpress *LPOUTLOOKEXPRESS;
//+---------------------------------------------------------------------
// Flags used in IOutlookExpress::Start
//----------------------------------------------------------------------
cpp_quote("#define MSOEAPI_START_SHOWSPLASH 0x00000001")
cpp_quote("#define MSOEAPI_START_MESSAGEPUMP 0x00000002")
cpp_quote("#define MSOEAPI_START_ALLOWCOMPACTION 0x00000004")
cpp_quote("#define MSOEAPI_START_INSTANCEMUTEX 0x00000008")
cpp_quote("#define MSOEAPI_START_SHOWERRORS 0x00000010")
cpp_quote("#define MSOEAPI_START_APPWINDOW 0x00000020")
cpp_quote("#define MSOEAPI_START_DEFAULTIDENTITY 0x00000040")
//+---------------------------------------------------------------------
// MSOEAPI_START_APPLICATION
//----------------------------------------------------------------------
cpp_quote("#define MSOEAPI_START_APPLICATION \\")
cpp_quote(" (MSOEAPI_START_SHOWSPLASH | \\")
cpp_quote(" MSOEAPI_START_SHOWERRORS | \\")
cpp_quote(" MSOEAPI_START_MESSAGEPUMP | \\")
cpp_quote(" MSOEAPI_START_ALLOWCOMPACTION | \\")
cpp_quote(" MSOEAPI_START_INSTANCEMUTEX | \\")
cpp_quote(" MSOEAPI_START_APPWINDOW)")
//+---------------------------------------------------------------------
// MSOEAPI_START_COMOBJECT
//----------------------------------------------------------------------
cpp_quote("#define MSOEAPI_START_COMOBJECT \\")
cpp_quote(" MSOEAPI_START_SHOWERRORS")
//+---------------------------------------------------------------------
// Methods
//----------------------------------------------------------------------
HRESULT Start(
[in] DWORD dwFlags,
[in] LPCSTR pszCmdLine,
[in] INT nCmdShow);
}
cpp_quote("#endif")
cpp_quote("#ifndef OE5_BETA2")
//+-------------------------------------------------------------------------
//
// Copyright (C) Microsoft Corporation, 1995-1998.
//
// Contents: IStoreNamespace
//
// History: 11-Oct-1997 SteveBailey Created
//
//--------------------------------------------------------------------------
cpp_quote("#ifndef __LPSTORENAMESPACE_DEFINED")
cpp_quote("#define __LPSTORENAMESPACE_DEFINED")
[
object,
uuid(E70C92AA-4BFD-11d1-8A95-00C04FB951F3),
pointer_default(unique)
]
interface IStoreNamespace : IUnknown
{
typedef IStoreNamespace *LPSTORENAMESPACE;
//+---------------------------------------------------------------------
// STOREFOLDERID - folderIds are persistable
//----------------------------------------------------------------------
typedef DWORD STOREFOLDERID;
typedef STOREFOLDERID *LPSTOREFOLDERID;
//+---------------------------------------------------------------------
// Some Special FOLDER Values
//----------------------------------------------------------------------
const DWORD FOLDERID_ROOT = 0;
const DWORD FOLDERID_INVALID = 0xffffffff;
//+---------------------------------------------------------------------
// MESSAGEID
//----------------------------------------------------------------------
typedef DWORD MESSAGEID;
typedef MESSAGEID *LPMESSAGEID;
//+---------------------------------------------------------------------
// Some Special MESSAGEID values
//----------------------------------------------------------------------
const DWORD MESSAGEID_INVALID = 0xffffffff;
const DWORD MESSAGEID_FIRST = 0xffffffff;
//+---------------------------------------------------------------------
// Consts
//----------------------------------------------------------------------
const DWORD CCHMAX_FOLDER_NAME = 256;
//+---------------------------------------------------------------------
// Notification Messages
//----------------------------------------------------------------------
cpp_quote("#define WM_FOLDERNOTIFY (WM_USER + 1600) // IStoreNamespace Notification - lparam=LPFOLDERNOTIFYEX, client must call CoTaskMemFree(lParam)")
cpp_quote("#define WM_NEWMSGS (WM_USER + 1650) // IStoreFolder Notification: wParam=MESSAGEID, lParam=Reserved")
cpp_quote("#define WM_DELETEMSGS (WM_USER + 1651) // IStoreFolder Notification: wParam=prgdwMsgId, lParam=cMsgs")
cpp_quote("#define WM_DELETEFOLDER (WM_USER + 1652) // IStoreFolder Notification: wParam=STOREFOLDERID or HFOLDER")
// If wParam is equal to 0xffffffff then that means that all messages in the folder
// were either marked as read (WM_MARKEDASREAD) or unread (WM_MARKEDASUNREAD)
cpp_quote("#define WM_MARKEDASREAD (WM_USER + 1653) // IStoreFolder Notification: wParamprgdwMsgId, lParam=cMsgs")
cpp_quote("#define WM_MARKEDASUNREAD (WM_USER + 1654) // IStoreFolder Notification: wParamprgdwMsgId, lParam=cMsgs")
//+---------------------------------------------------------------------
// FOLDERNOTIFYTYPE
//----------------------------------------------------------------------
typedef enum tagFOLDERNOTIFYTYPE {
NEW_FOLDER = 1,
DELETE_FOLDER,
RENAME_FOLDER,
MOVE_FOLDER,
UNREAD_CHANGE,
IMAPFLAG_CHANGE,
UPDATEFLAG_CHANGE,
FOLDER_PROPS_CHANGED
} FOLDERNOTIFYTYPE;
//+---------------------------------------------------------------------
// FOLDERNOTIFYEX
//----------------------------------------------------------------------
typedef struct tagFOLDERNOTIFYEX {
FOLDERNOTIFYTYPE type;
STOREFOLDERID idFolderOld; // not used for CREATEFOLDER and DELETEFOLDER
STOREFOLDERID idFolderNew;
} FOLDERNOTIFYEX, *LPFOLDERNOTIFYEX;
//+---------------------------------------------------------------------
// MESSAGEIDLIST - A list of message ids (DWORDs)
//----------------------------------------------------------------------
typedef struct tagMESSAGEIDLIST {
DWORD cbSize; // Sizeof this structure
DWORD cMsgs; // Number of elements in prghMessage
LPMESSAGEID prgdwMsgId; // Array of handles to messages
} MESSAGEIDLIST, *LPMESSAGEIDLIST;
//+---------------------------------------------------------------------
// SPECIALFOLDER - How to identify a special folder
//----------------------------------------------------------------------
typedef enum tagSPECIALFOLDER {
FOLDER_NOTSPECIAL = -1, // Not a special folder
FOLDER_INBOX, // Default receive folder
FOLDER_OUTBOX, // Default send folder
FOLDER_SENT, // Things that have been sent
FOLDER_DELETED, // Things that have been deleted
FOLDER_DRAFT, // Things that are in progress
FOLDER_MAX // Don't use
} SPECIALFOLDER;
//+---------------------------------------------------------------------
// FOLDERPROPS - Properties of a folder
//----------------------------------------------------------------------
typedef struct tagFOLDERPROPS {
DWORD cbSize; // Size of this structure
STOREFOLDERID dwFolderId; // Handle of this folder
INT cSubFolders; // Number of sub-folders
SPECIALFOLDER sfType; // Special folder type
DWORD cUnread; // Number of un-read messages
DWORD cMessage; // Total # of messages
CHAR szName[CCHMAX_FOLDER_NAME]; // The Folder Name
} FOLDERPROPS, *LPFOLDERPROPS;
//+---------------------------------------------------------------------
// Methods
//----------------------------------------------------------------------
HRESULT Initialize( // Initialize the object
[in] HWND hwndOwner, // Window owner for things like compaction dialog
[in] DWORD dwReserved); // Reserved for future use
HRESULT GetDirectory( // Get the location of the store (filepath)
[in,out,size_is(cchMaxPath)] LPSTR pszPath, // Buffer to put path of store into
[in] DWORD cchMaxPath); // in: byte count size of pszPath, out: char count size of pszPath
HRESULT OpenSpecialFolder(
[in] SPECIALFOLDER sfType, // Special folder type
[in] DWORD dwReserved, // Reserved for future use
[out] IStoreFolder **ppFolder); // Pointer to an IStoreFolder
HRESULT OpenFolder(
[in] STOREFOLDERID dwFolderId, // Folder to open
[in] DWORD dwReserved, // Reserved for future use
[out] IStoreFolder **ppFolder); // Pointer to an IStoreFolder
HRESULT CreateFolder(
[in] STOREFOLDERID dwParentId, // Parent of the new folder, can use FOLDERID_ROOT
[in] LPCSTR pszName, // Name of new folder, must be less than MAX_FOLDER_NAME
[in] DWORD dwReserved, // Reserved for future use
[out] LPSTOREFOLDERID pdwFolderId); // Handle to the new folder
HRESULT RenameFolder(
[in] STOREFOLDERID dwFolderId, // Folder to rename
[in] DWORD dwReserved, // Reserved for future use
[in] LPCSTR pszNewName); // New folder name, must be less than MAX_FOLDER_NAME
HRESULT MoveFolder(
[in] STOREFOLDERID dwFolderId, // Folder to move
[in] STOREFOLDERID dwParentId, // FolderId of the new Parent
[in] DWORD dwReserved); // Reserved for future use
HRESULT DeleteFolder(
[in] STOREFOLDERID dwFolderId, // Folder to delete
[in] DWORD dwReserved); // Reserved for future use
HRESULT GetFolderProps(
[in] STOREFOLDERID dwFolderId, // FolderId to get info for
[in] DWORD dwReserved, // Reserved for future use
[in,out] LPFOLDERPROPS pProps); // in: set cbSize, out: Holds folder information
cpp_quote("// CLocalStore::CopyMoveMessages flags - dwFlags == 0 is copy")
cpp_quote("#define CMF_MOVE 0x0001 // msgs deleted from src fldr after copy")
cpp_quote("#define CMF_DELETE 0x0002 // same as CMF_MOVE but uses delete string for status")
HRESULT CopyMoveMessages(
[in] IStoreFolder *pSource, // Source store folder
[in] IStoreFolder *pDest, // Destination Store Folder
[in] LPMESSAGEIDLIST pMsgIdList, // List of MESSAGEIDs to move/copy
[in] DWORD dwFlags, // CMF_xxx Flags
[in] DWORD dwFlagsRemove, // MSG_xxx Flags to remove from copied/moved messages
[in] IProgressNotify *pProgress); // Store progress callback (client implements)
HRESULT RegisterNotification(
[in] DWORD dwReserved, // Reserved for future use
[in] HWND hwnd); // Handle to window to send notifications
HRESULT UnregisterNotification(
[in] DWORD dwReserved, // Reserved for future use
[in] HWND hwnd); // Handle to window to un-register for notifications
HRESULT CompactAll( // Compacts all folders in the store
[in] DWORD dwReserved); // Reserved for future use
HRESULT GetFirstSubFolder( // Enumerate sub folders
[in] STOREFOLDERID dwFolderId, // Pass FOLDERID_ROOT to enum root folders
[in,out] LPFOLDERPROPS pProps, // If function succeeds, contents are valid
[out] LPHENUMSTORE phEnum); // Use in call to GetNextSubFolder, and then GetSubFolderClose
HRESULT GetNextSubFolder( // Get the next subfolder, returns S_FALSE if no more folders
[in] HENUMSTORE hEnum, // Handle received from GetFirstSubFolder
[in,out] LPFOLDERPROPS pProps); // If function returns S_OK, contains folder properties
HRESULT GetSubFolderClose( // Closes the handle associated with a folder enumeration
[in] HENUMSTORE hEnum); // Handle received from GetFirstSubFolder
}
cpp_quote("#endif")
//+-------------------------------------------------------------------------
//
// Copyright (C) Microsoft Corporation, 1995-1998.
//
// Contents: IStoreFolder
//
// History: 11-Oct-1997 SteveBailey Created
//
//--------------------------------------------------------------------------
cpp_quote("#ifndef __LPSTOREFOLDER_DEFINED")
cpp_quote("#define __LPSTOREFOLDER_DEFINED")
[
object,
uuid(E70C92AC-4BFD-11d1-8A95-00C04FB951F3),
pointer_default(unique)
]
interface IStoreFolder : IUnknown
{
typedef IStoreFolder *LPSTOREFOLDER;
//+---------------------------------------------------------------------
// Message State Flags used in MESSAGEINFO::dwState
//----------------------------------------------------------------------
cpp_quote("#define MSG_DELETED 0x0001 // The message has been deleted, compaction will remove it")
cpp_quote("#define MSG_UNREAD 0x0002 // The message is marked as un-read")
cpp_quote("#define MSG_SUBMITTED 0x0004 // For messages waiting to be sent: OUTBOX ONLY")
cpp_quote("#define MSG_UNSENT 0x0008 // For msgs-in-progress saved to a folder")
cpp_quote("#define MSG_RECEIVED 0x0010 // For messages that came from a server")
cpp_quote("#define MSG_NEWSMSG 0x0020 // For news messages")
cpp_quote("#define MSG_NOSECUI 0x0040 // For messages where the user wants to die")
cpp_quote("#define MSG_VOICEMAIL 0x0080 // The message has the X-Voicemail header set...")
cpp_quote("#define MSG_REPLIED 0x0100 // The message has been replied to")
cpp_quote("#define MSG_FORWARDED 0x0200 // The message has been forwarded to")
cpp_quote("#define MSG_RCPTSENT 0x0400 // S/MIME Receipt has been sent")
cpp_quote("#define MSG_FLAGGED 0x0800 // The message is currently flags")
cpp_quote("#define MSG_LAST 0x0200 // ** Keep this puppy updated!! **")
cpp_quote("#define MSG_EXTERNAL_FLAGS 0x00fe")
cpp_quote("#define MSG_FLAGS 0x000f")
//+---------------------------------------------------------------------
// MESSAGEPROPS
//----------------------------------------------------------------------
typedef struct tagMESSAGEPROPS {
DWORD cbSize; // Size of this structure
DWORD dwReserved; // Reserved don't use
MESSAGEID dwMessageId; // Handle to this message
DWORD dwLanguage; // Codepage of this message
DWORD dwState; // MSG_xxx Flags
// Things you don't get when MSGPROPS_FAST
DWORD cbMessage; // Size of the message
IMSGPRIORITY priority; // Message Priority
FILETIME ftReceived; // When the message was received
FILETIME ftSent; // When the message was sent
LPSTR pszSubject; // The subject of the message
LPSTR pszDisplayTo; // The display to line of the message
LPSTR pszDisplayFrom; // The display from line of the message
LPSTR pszNormalSubject; // The normalized subject of the message
DWORD dwFlags; // IMF_xxx Flags defined in mimeole.idl
IStream *pStmOffsetTable; // Use with IMimeMessage::LoadOffsetTable
} MESSAGEPROPS, *LPMESSAGEPROPS;
//+---------------------------------------------------------------------
// HBATCHLOCK
//----------------------------------------------------------------------
DECLARE_HANDLE(HBATCHLOCK);
typedef HBATCHLOCK *LPHBATCHLOCK;
//+---------------------------------------------------------------------
// Method
//----------------------------------------------------------------------
HRESULT GetFolderProps( // Get folder info for this folder
[in] DWORD dwReserved, // Reserved for future use
[in,out] LPFOLDERPROPS pProps); // in: set cbSize, out: contains folder information
cpp_quote("#define MSGPROPS_FAST 0x00000001 // See MESSAGEPROPS structure, improved performance")
HRESULT GetMessageProps(
[in] MESSAGEID dwMessageId, // Message Identifier
[in] DWORD dwFlags, // GETMSGINFO_xxx Flags
[in,out] LPMESSAGEPROPS pProps); // Message Info - set cbSize before calling
HRESULT FreeMessageProps( // Handles the case where pMsgInfo->dwMask has MIP_BYREF
[in,out] LPMESSAGEPROPS pProps); // Pointer to MESSAGEINFO structure to free
HRESULT DeleteMessages(
[in] LPMESSAGEIDLIST pMsgIdList, // List of HMESSAGEs
[in] DWORD dwReserved, // Reserved for future use
[in] IProgressNotify *pProgress); // Progress information
HRESULT SetLanguage(
[in] DWORD dwLanguage, // MLANG Codepage ID of message
[in] DWORD dwReserved, // Reserved for future use
[in] LPMESSAGEIDLIST pMsgIdList); // List of HMESSAGEs to apply new language to
HRESULT MarkMessagesAsRead(
[in] BOOL fRead, // Mark as Read or Unread
[in] DWORD dwReserved, // Reserved for future use
[in] LPMESSAGEIDLIST pMsgIdList); // List of HMESSAGEs to mark as (un)read
HRESULT SetFlags( // Modify the flags of a message
[in] LPMESSAGEIDLIST pMsgIdList, // Array of messages to modify flags for
[in] DWORD dwState, // MSG_xxx Flags to set on pMsgIdList
[in] DWORD dwStatemask, // ?????
[out] LPDWORD prgdwNewFlags); // Array of new message state flags that match pMsgIdList array
HRESULT OpenMessage( // Open a message (get a stream or a message object)
[in] MESSAGEID dwMessageId, // Handle to the message to open
[in] REFIID riid, // IID_IStream or IID_IMimeMessage stream is readonly
[out,iid_is(riid)] LPVOID *ppvObject); // The object, you must ->Release it
HRESULT SaveMessage( // Add a new entry to a folder.
[in] REFIID riid, // IID_IStream or IID_IMimeMessage
[in,iid_is(riid)] LPVOID pvObject, // Pointer to a stream or mime message
[in] DWORD dwMsgFlags, // MSG_xxx Flags
[out] LPMESSAGEID pdwMessageId); // Handle to the new message
HRESULT BatchLock( // Lock to prepare for a batch operation
[in] DWORD dwReserved, // Reserved for future use
[out] LPHBATCHLOCK phBatchLock); // Handle to newly created lock
HRESULT BatchFlush( // Flush the current batch operation
[in] DWORD dwReserved, // Reserved for future use
[in] HBATCHLOCK hBatchLock); // Folder lock obtained from BatchLock
HRESULT BatchUnlock( // Unlocks a batched operation
[in] DWORD dwReserved, // Reserved for future use
[in] HBATCHLOCK hBatchLock); // Handle to lock obtained from BatchLock
HRESULT CreateStream( // Create a new stream in a folder
[in] HBATCHLOCK hBatchLock, // Handle to a folder lock, optional if doing a one-of
[in] DWORD dwReserved, // Reserved for future use
[out] IStream **ppStream, // Pointer to new stream can be used for read/write
[out] LPMESSAGEID pdwMessageId); // Handle to the new message
cpp_quote("#define COMMITSTREAM_REVERT 0x00000001 // Don't add this stream/message to the folder")
HRESULT CommitStream( // Commit/Revert a stream created with CreateStream
[in] HBATCHLOCK hBatchLock, // Folder lock obtained from BatchLock
[in] DWORD dwFlags, // COMMITSTREAM_xxx Flags
[in] DWORD dwMsgFlags, // MSG_xxx Flags
[in] IStream *pStream, // Stream obtained from CreateStream
[in] MESSAGEID dwMessageId, // dwMessageId obtained from CreateStream
[in] IMimeMessage *pMessage); // Message to commit, if not passed in, pStream will be pared.
HRESULT RegisterNotification(
[in] DWORD dwReserved, // Reserved for future use
[in] HWND hwnd); // Handle to window to send notifications
HRESULT UnregisterNotification(
[in] DWORD dwReserved, // Reserved for future use
[in] HWND hwnd); // Handle to window to un-register for notifications
HRESULT Compact( // Compacts this folder
[in] DWORD dwReserved); // Reserved for future use
HRESULT GetFirstMessage( // Get the first message in a folder
[in] DWORD dwFlags, // MSGPROPS_xxx Flags
[in] DWORD dwMsgFlags, // MSG_xxx Flags to enumerate on, pass 0 for none
[in] MESSAGEID dwMsgIdFirst, // MessageId to start enumerating at, Use MESSAGEID_FIRST
[in,out] LPMESSAGEPROPS pProps, // When function returns S_OK, contains message properties
[out] LPHENUMSTORE phEnum); // Upon successful return, contains handle to enumeration
HRESULT GetNextMessage( // Get the next message in the enumeration
[in] HENUMSTORE hEnum, // Handle to the enumeration received in GetFirstMessage
[in] DWORD dwFlags, // MSGPROPS_xxx Flags
[in,out] LPMESSAGEPROPS pProps); // When function returns S_OK, contains message properties
HRESULT GetMessageClose(
[in] HENUMSTORE hEnum); // Handle to the enumeration received in GetFirstMessage
}
cpp_quote("#endif")
cpp_quote("#endif // OE5_BETA2")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// Outlook Express Exported C API Functions")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#ifdef __cplusplus")
cpp_quote("extern \"C\" {")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// API Name Decoration")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("#if !defined(_MSOEAPI_)")
cpp_quote("#define MSOEAPI DECLSPEC_IMPORT HRESULT WINAPI")
cpp_quote("#define MSOEAPI_(_type_) DECLSPEC_IMPORT _type_ WINAPI")
cpp_quote("#else")
cpp_quote("#define MSOEAPI HRESULT WINAPI")
cpp_quote("#define MSOEAPI_(_type_) _type_ WINAPI")
cpp_quote("#endif")
cpp_quote("")
cpp_quote("//+-------------------------------------------------------------------------")
cpp_quote("// Prototypes")
cpp_quote("//--------------------------------------------------------------------------")
cpp_quote("MSOEAPI CoStartOutlookExpress(")
cpp_quote(" /* IN */ DWORD dwFlags,")
cpp_quote(" /* IN */ LPCSTR pszCmdLine,")
cpp_quote(" /* IN */ INT nCmdShow);")
cpp_quote("")
cpp_quote("MSOEAPI CoCreateOutlookExpress(")
cpp_quote(" /* IN */ IUnknown *pUnkOuter,")
cpp_quote(" /* OUT */ IUnknown **ppUnknown);")
cpp_quote("")
cpp_quote("#ifdef __cplusplus")
cpp_quote("}")
cpp_quote("#endif")