Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Move Selected Emails to another Mailbox FolderDownloads 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.
load ./chilkat.dll # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set imap [new_CkImap] # Connect to an IMAP server. # Use TLS CkImap_put_Ssl $imap 1 CkImap_put_Port $imap 993 set success [CkImap_Connect $imap "imap.someMailServer.com"] if {$success != 1} then { puts [CkImap_lastErrorText $imap] delete_CkImap $imap exit } # Login set success [CkImap_Login $imap "myLogin" "myPassword"] if {$success != 1} then { puts [CkImap_lastErrorText $imap] delete_CkImap $imap exit } # Select an IMAP mailbox set success [CkImap_SelectMailbox $imap "Inbox"] if {$success != 1} then { puts [CkImap_lastErrorText $imap] delete_CkImap $imap exit } # 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 1. CkImap_put_PeekMode $imap 1 # 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. set numEmails [CkImap_get_NumMessages $imap] set mset [new_CkMessageSet] # Indicate that mset contains sequence numbers, not UIDs. CkMessageSet_put_HasUids $mset 0 # 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. set i 0 while {$i < $numEmails} { # Fetch the email by sequence number. # email is a CkEmail set email [CkImap_FetchSingle $imap [expr $i + 1] 0] if {[CkImap_get_LastMethodSuccess $imap] != 1} then { puts [CkImap_lastErrorText $imap] delete_CkImap $imap delete_CkMessageSet $mset exit } # If it is decided to move the email, add the sequence number to mset, like this: CkMessageSet_InsertId $mset [expr $i + 1] delete_CkEmail $email } # If there are emails in mset to be moved, then do it.. if {[CkMessageSet_get_Count $mset] > 0} then { set destFolder "Inbox/SomeOtherFolder" # Assuming your IMAP server supports the feature that allows for messages to be moved to another folder... set success [CkImap_MoveMessages $imap $mset $destFolder] if {$success != 1} then { puts [CkImap_lastErrorText $imap] delete_CkImap $imap delete_CkMessageSet $mset exit } } # Disconnect from the IMAP server. set success [CkImap_Disconnect $imap] delete_CkImap $imap delete_CkMessageSet $mset |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.