VB.NET
VB.NET
Async Progress Info Log
See more Async Examples
Demonstrates checking for progress info updates when running a task asynchronously.Chilkat VB.NET Downloads
Dim success As Boolean = False
' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
success = False
' The mailman object is used for sending and receiving email.
Dim mailman As New Chilkat.MailMan
' Set the SMTP server and any required settings.
mailman.SmtpHost = "smtp.mymailserver.com"
mailman.SmtpUsername = "myLogin"
mailman.SmtpPassword = "myPassword"
mailman.StartTLS = True
' Create a new email object
Dim email As New Chilkat.Email
email.Subject = "This is a test"
email.Body = "This is a test"
email.From = "Chilkat Support <support@chilkatsoft.com>"
success = email.AddTo("Chilkat Admin","admin@chilkatsoft.com")
' Call the async version of the SendEmail method to return a task object.
' The task object is loaded, but is in the Inert state -- meaning it is
' not yet scheduled to run on Chilkat's background thread pool.
Dim task As Chilkat.Task = mailman.SendEmailAsync(email)
If (mailman.LastMethodSuccess = False) Then
Debug.WriteLine(mailman.LastErrorText)
Exit Sub
End If
' Before starting the task, tell it to keep an in-memory log of what would've been
' ProgressInfo event callbacks.
task.KeepProgressLog = True
' Schedule the task for running on the thread pool. This changes the task's state
' from Inert to Live.
success = task.Run()
If (success <> True) Then
Debug.WriteLine(task.LastErrorText)
Exit Sub
End If
' The application is now free to do anything else
' while the email is being sent.
' For this example, we'll simply sleep and periodically
' check to see if the SendEmail if finished. While checking
' however, we'll report on the progress.
Dim curPctDone As Integer = 0
Dim name As String
Dim value As String
While task.Finished <> True
If (task.PercentDone <> curPctDone) Then
curPctDone = task.PercentDone
Debug.WriteLine(curPctDone & " percent done")
End If
' Check the progress info log.
' Emit any log entries..
While (task.ProgressLogSize > 0)
' Get the 1st entry, emit it, and then remove it..
name = task.ProgressInfoName(0)
value = task.ProgressInfoValue(0)
Debug.WriteLine(name & ": " & value)
task.RemoveProgressInfo(0)
End While
' Sleep 100 ms.
task.SleepMs(100)
End While
' Just in case there are any remaining entries...
While (task.ProgressLogSize > 0)
' Get the 1st entry, emit it, and then remove it..
name = task.ProgressInfoName(0)
value = task.ProgressInfoValue(0)
Debug.WriteLine(name & ": " & value)
task.RemoveProgressInfo(0)
End While
' A finished task could be one that was canceled, aborted, or truly finished.
' If the task was "canceled", it was canceled prior to actually starting. This could
' happen if the task was canceled while waiting in a thread pool queue to be scheduled by Chilkat's
' background thread pool scheduler.
' If the task was "aborted", it indicates that it was canceled while running in a background thread.
' The ResultErrorText will likely indicate that the task was aborted.
' If the task "completed", then it ran to completion, but the actual success/failure of the method
' is determined by the result obtained via a GetResult* method. (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 (task.StatusInt <> 7) Then
Debug.WriteLine("Task did not complete.")
Debug.WriteLine("task status: " & task.Status)
Exit Sub
End If
' The SendEmail method returns a boolean. Therefore, after the task is finished,
' we can get the boolean result by calling GetResultBool. This is the return value had
' we called SendEmail synchronously.
success = task.GetResultBool()
If (success <> True) Then
' The task's ResultErrorText contains what would have been in the LastErrorText property had
' the SendEmail method been called synchronously.
Debug.WriteLine(task.ResultErrorText)
Else
Debug.WriteLine("Email sent asynchronously.")
End If
success = mailman.CloseSmtpConnection()
If (success <> True) Then
Debug.WriteLine("Connection to SMTP server not closed cleanly.")
End If