This function, an extension of MailNext, retrieves the next of a specified type of mail entry from the message store and operates in a multiple hierarchy folder environment.
Header file: | Msgstor2.h |
Platforms: | H/PC 3.0 |
Windows CE versions: | 2.10 and later |
BOOL MailNextEx (HANDLE hMail, MailMsg* pmm, FID fid, FID fidTarget,
BOOL fDoAll);
MailGetEx does not allocate any memory for the message body.
If neither of these flags is set, this function retrieves only the message header and allocates memory from the private heap.
TRUE indicates success. FALSE indicates failure. To get extended error information, call the function MailError or MailErrorMsg.
The flags of MailMsg must be set prior to each call to this function. This is because each call to MailFirstEx, MailGetEx, or this function returns the flags of the message as it is stored in the database.
Once this function has retrieved a message, you can modify the values returned in MailMsg. However, changing the values of MailMsg does not affect the message store until a call to the function MailUpdateEx reinserts MailMsg into the message store.
When using this function to search a folder for a message, treat any message that has the MAIL_STATUS_MOVE or MAIL_STATUS_COPY flag set as being located in the pfidTarget folder. This folder may differ from that indicated by fid, because a client can attempt to move or copy a message from one folder to another while the client is not connected to a mail server. If this happens, the OS sets the MAIL_STATUS_MOVE or MAIL_STATUS_COPY flag in MailMsg. MailUpdateEx saves the target folder, along with MailMsg, in the store. When the device connects to the mail server, the Inbox client performs the move or copy on the server, then uses MailUpdateEx to clear the existing flag from MailMsg and to set the value of fid to the new target folder.
To free memory allocated by this function, use the function MailFree.