Sample code for 30+ languages & platforms
Delphi DLL

Move Selected Emails to another Mailbox Folder

See more IMAP Examples

Downloads emails one by one in a selected mailbox, decides which emails are to be moved, and then moves the set of messages to another mailbox folder.

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Imap, Email, MessageSet;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
imap: HCkImap;
numEmails: Integer;
mset: HCkMessageSet;
email: HCkEmail;
i: Integer;
destFolder: PWideChar;

begin
success := False;

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

imap := CkImap_Create();

// Connect to an IMAP server.
// Use TLS
CkImap_putSsl(imap,True);
CkImap_putPort(imap,993);
success := CkImap_Connect(imap,'imap.example.com');
if (success = False) then
  begin
    Memo1.Lines.Add(CkImap__lastErrorText(imap));
    Exit;
  end;

// Login
success := CkImap_Login(imap,'myLogin','myPassword');
if (success = False) then
  begin
    Memo1.Lines.Add(CkImap__lastErrorText(imap));
    Exit;
  end;

// Select an IMAP mailbox
success := CkImap_SelectMailbox(imap,'Inbox');
if (success = False) then
  begin
    Memo1.Lines.Add(CkImap__lastErrorText(imap));
    Exit;
  end;

// Normally, when an email is downloaded, its "Seen" flag is automatically set.
// We don't want our program to be interfering with the "Seen" flags.
// To do this, set the PeekMode to True.
CkImap_putPeekMode(imap,True);

// After selecting the mailbox, the NumMessages property
// will contain the number of emails in the mailbox.
// When sequence numbers (not UIDs) are used to reference emails,
// they range from 1 to N, where N is the number of messages in the mailbox.
// This example will download the headers by sequence numbers.
numEmails := CkImap_getNumMessages(imap);

mset := CkMessageSet_Create();

// Indicate that mset contains sequence numbers, not UIDs.
CkMessageSet_putHasUids(mset,False);

// Fetch each email and decide for each if it is to be moved
// to a particular other mailbox.  If so, we'll add the sequence number to
// the mset, and then move all emails in the mset to the other mailbox.
email := CkEmail_Create();
i := 0;
while i < numEmails do
  begin
    // Fetch the email by sequence number.
    success := CkImap_FetchEmail(imap,False,i + 1,False,email);
    if (success = False) then
      begin
        Memo1.Lines.Add(CkImap__lastErrorText(imap));
        Exit;
      end;

    // If it is decided to move the email, add the sequence number to mset, like this:
    CkMessageSet_InsertId(mset,i + 1);

  end;

// If there are emails in mset to be moved, then do it..
if (CkMessageSet_getCount(mset) > 0) then
  begin
    destFolder := 'Inbox/SomeOtherFolder';
    // Assuming your IMAP server supports the feature that allows for messages to be moved to another folder...
    success := CkImap_MoveMessages(imap,mset,destFolder);
    if (success = False) then
      begin
        Memo1.Lines.Add(CkImap__lastErrorText(imap));
        Exit;
      end;

  end;

// Disconnect from the IMAP server.
success := CkImap_Disconnect(imap);

CkImap_Dispose(imap);
CkMessageSet_Dispose(mset);
CkEmail_Dispose(email);

end;