Sample code for 30+ languages & platforms
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

VB.NET
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