Sample code for 30+ languages & platforms
Unicode C

Async Upload (Append) Email to an IMAP Mailbox

Use the AppendMailAsync method call to append an email to an IMAP mailbox.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkImapW.h>
#include <C_CkEmailW.h>
#include <C_CkTaskW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkImapW imap;
    HCkEmailW email;
    HCkTaskW task;

    success = FALSE;

    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    imap = CkImapW_Create();

    // Connect to an IMAP server.
    // Use TLS
    CkImapW_putSsl(imap,TRUE);
    CkImapW_putPort(imap,993);
    success = CkImapW_Connect(imap,L"MY-IMAP-DOMAIN");
    if (success != TRUE) {
        wprintf(L"%s\n",CkImapW_lastErrorText(imap));
        CkImapW_Dispose(imap);
        return;
    }

    // Login
    success = CkImapW_Login(imap,L"MY-IMAP-LOGIN",L"MY-IMAP-PASSWORD");
    if (success != TRUE) {
        wprintf(L"%s\n",CkImapW_lastErrorText(imap));
        CkImapW_Dispose(imap);
        return;
    }

    // Create a simple email with 2 recipients.
    email = CkEmailW_Create();
    CkEmailW_putFrom(email,L"support@chilkatsoft.com");
    CkEmailW_AddTo(email,L"Chilkat Sales",L"sales@chilkatsoft.com");
    CkEmailW_AddTo(email,L"Chilkat GMail",L"chilkat.support@gmail.com");
    CkEmailW_putBody(email,L"This is a test email.");
    CkEmailW_putSubject(email,L"This is a test email.");

    // Imagine we've sent this email via SMTP, and now we want to 
    // save the email to our "Sent" mailbox.  On GMail, the mailbox name
    // for sent email is "[Gmail]/Sent Mail".

    // Call the async version of the AppendMail method to return a task object.
    task = CkImapW_AppendMailAsync(imap,L"[Gmail]/Sent Mail",email);
    if (CkImapW_getLastMethodSuccess(imap) != TRUE) {
        wprintf(L"%s\n",CkImapW_lastErrorText(imap));
        CkImapW_Dispose(imap);
        CkEmailW_Dispose(email);
        return;
    }

    // Schedule the task for running on the thread pool.  This changes the task's state
    // from Inert to Live.  The task is now running...
    success = CkTaskW_Run(task);
    if (success != TRUE) {
        wprintf(L"%s\n",CkTaskW_lastErrorText(task));
        CkTaskW_Dispose(task);
        CkImapW_Dispose(imap);
        CkEmailW_Dispose(email);
        return;
    }

    // -------------------------------------------------------------------------------
    // The following is a general note that applies to all programming languages:
    // -------------------------------------------------------------------------------
    // Your application can keep a reference to the task object and periodically check back later to see if it's finished.
    // If your programming language is one that supports callbacks, then the TaskCompleted callback can
    // be setup to be called when the task completes.  (See the "Async" category on example-code.com for more information.)
    // 
    // NOTE: This is very important:  A TaskCompleted callback runs in the background thread.  
    // (All callbacks from an async task, such as AbortCheck, PercentDone, ProgressInfo, etc. are in the background thread.) 
    // An application that uses TaskCompleted must be very careful.  
    // For example, user interface elements (such as labels, text boxes, etc.) may not be directly
    // accessible from a background thread, and could crash the application if directly accessed.  Also, attempting to debug
    // code running in a background thread from an IDE, especially an older IDE (such as VB6) is likely to crash the IDE.


    CkImapW_Dispose(imap);
    CkEmailW_Dispose(email);

    }