Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(CkPython) Async Task ChainDemonstrates how to combine a sequence of asynchronous tasks into a single task chain to be run in a background thread.
import sys import chilkat # All Chilkat classes can be unlocked at once at the beginning of a program # by calling UnlockBundle. It requires a Bundle unlock code. chilkatGlob = chilkat.CkGlobal() success = chilkatGlob.UnlockBundle("Anything for 30-day trial.") if (success != True): print(chilkatGlob.lastErrorText()) sys.exit() mailman = chilkat.CkMailMan() # Set the POP3 server's hostname mailman.put_MailHost("pop.someMailServer.com") # Set the POP3 login/password and any other requirements.. mailman.put_PopUsername("myLogin") mailman.put_PopPassword("myPassword") mailman.put_PopSsl(True) mailman.put_MailPort(995) # Connect to the POP3 server: success = mailman.Pop3BeginSession() if (not success): print(mailman.lastErrorText()) sys.exit() # Get the number of messages in the mailbox. numMessages = mailman.GetMailboxCount() if (numMessages == 0): print("No email messages in the POP3 mailbox.") sys.exit() taskChain = chilkat.CkTaskChain() # Create async task objects to fetch each email message # by its sequence number for i in range(1,(numMessages)-1): # task is a CkTask task = mailman.FetchByMsgnumAsync(i) if (mailman.get_LastMethodSuccess() == False): print(mailman.lastErrorText()) sys.exit() # Append each task to the task chain. success = taskChain.Append(task) if (not success): print(taskChain.lastErrorText()) sys.exit() # At this point, no tasks have actually started running. # All we've done so far is to create tasks for the work that will be done # when the task chain is run. # Start the task chain running in a background thread. # Each task is run one after the other (on the same background thread) until all tasks have completed. # The task chain will stop at the first task that fails. taskChain.put_StopOnFailedTask(True) success = taskChain.Run() if (not success): print(taskChain.lastErrorText()) sys.exit() # The application is now free to do anything else # while the emails are being downloaded # For this example, we'll simply sleep and periodically # check to see if the taskchain if finished. while taskChain.get_Finished() != True : # Sleep 100 ms. taskChain.SleepMs(100) # A finished task chain could be one that was canceled, aborted, or truly finished. # If the task chain "completed", then it ran to completion. A "completed" task will # have a StatusInt equal to 7. If the task finished, but was not completed, then it must've # been aborted or canceled: if (taskChain.get_StatusInt() != 7): print("Task did not complete.") print("task chain status: " + taskChain.status()) sys.exit() email = chilkat.CkEmail() numTasks = taskChain.get_NumTasks() taskIdx = 0 while (taskIdx < numTasks) : # task is a CkTask task = taskChain.GetTask(taskIdx) # Load the email object with email downloaded by this task. success = email.LoadTaskResult(task) if (not success): print("Failed to load email object for task.") else: print(email.ck_from() + "; " + email.subject()) taskIdx = taskIdx + 1 |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.