Android™
Android™
Async Task Chain
See more Async Examples
Demonstrates how to combine a sequence of asynchronous tasks into a single task chain to be run in a background thread.Chilkat Android™ Downloads
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;
import android.app.Activity;
import com.chilkatsoft.*;
import android.widget.TextView;
import android.os.Bundle;
public class SimpleActivity extends Activity {
private static final String TAG = "Chilkat";
// Called when the activity is first created.
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
boolean success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
success = false;
CkMailMan mailman = new CkMailMan();
// Set the POP3 server's hostname
mailman.put_MailHost("pop.example.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 (!success) {
Log.i(TAG, mailman.lastErrorText());
return;
}
// Get the number of messages in the mailbox.
int numMessages = mailman.GetMailboxCount();
if (numMessages == 0) {
Log.i(TAG, "No email messages in the POP3 mailbox.");
return;
}
CkTaskChain taskChain = new CkTaskChain();
// Create async task objects to fetch each email message
// by its sequence number
int i;
CkTask task;
for (i = 1; i <= numMessages; i++) {
task = mailman.FetchByMsgnumAsync(i);
if (mailman.get_LastMethodSuccess() == false) {
Log.i(TAG, mailman.lastErrorText());
return;
}
// Append each task to the task chain.
success = taskChain.Append(task);
if (!success) {
Log.i(TAG, taskChain.lastErrorText());
return;
}
}
// 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 (!success) {
Log.i(TAG, taskChain.lastErrorText());
return;
}
// 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) {
Log.i(TAG, "Task did not complete.");
Log.i(TAG, "task chain status: " + taskChain.status());
return;
}
CkEmail email = new CkEmail();
int numTasks = taskChain.get_NumTasks();
int taskIdx = 0;
while ((taskIdx < numTasks)) {
task = taskChain.GetTask(taskIdx);
// Load the email object with email downloaded by this task.
success = email.LoadTaskResult(task);
if (!success) {
Log.i(TAG, "Failed to load email object for task.");
}
else {
Log.i(TAG, email.ck_from() + "; " + email.subject());
}
taskIdx = taskIdx + 1;
}
}
static {
System.loadLibrary("chilkat");
// Note: If the incorrect library name is passed to System.loadLibrary,
// then you will see the following error message at application startup:
//"The application <your-application-name> has stopped unexpectedly. Please try again."
}
}