AI 148256: Finish cleaning up the concurrency bugs in FolderMessageList.
At this point, *all* MessageListener callbacks should have their work routed through the handler for deeper processing (especially anything that affects the lists) to be in the UI thread only. Also fixed a minor regression introduced in CL 148096 (on configurations with a single account, the inbox was not automatically preopening - this affected desktop shortcuts as well.) BUG=1812798 Automated import of CL 148256
This commit is contained in:
parent
1e2ca965e7
commit
62c4a62985
@ -153,7 +153,6 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
class FolderMessageListHandler extends Handler {
|
||||
private static final int MSG_PROGRESS = 2;
|
||||
private static final int MSG_DATA_CHANGED = 3;
|
||||
private static final int MSG_EXPAND_GROUP = 5;
|
||||
private static final int MSG_FOLDER_LOADING = 7;
|
||||
private static final int MSG_REMOVE_MESSAGE = 11;
|
||||
private static final int MSG_SYNC_MESSAGES = 13;
|
||||
@ -162,6 +161,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
private static final int MSG_NEW_MESSAGE = 19;
|
||||
private static final int MSG_REMOVE_MESSAGE_UID = 20;
|
||||
private static final int MSG_MESSAGE_UID_CHANGED = 21;
|
||||
private static final int MSG_LIST_FOLDERS_FINISHED = 22;
|
||||
|
||||
@Override
|
||||
public void handleMessage(android.os.Message msg) {
|
||||
@ -172,9 +172,6 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
case MSG_DATA_CHANGED:
|
||||
mAdapter.notifyDataSetChanged();
|
||||
break;
|
||||
case MSG_EXPAND_GROUP:
|
||||
mListView.expandGroup(msg.arg1);
|
||||
break;
|
||||
/*
|
||||
* The following functions modify the state of the adapter's underlying list and
|
||||
* must be run here, in the main thread, so that notifyDataSetChanged is run
|
||||
@ -196,8 +193,12 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
break;
|
||||
}
|
||||
case MSG_SYNC_MESSAGES: {
|
||||
FolderInfoHolder folder = (FolderInfoHolder) ((Object[]) msg.obj)[0];
|
||||
String folderName = (String) ((Object[]) msg.obj)[0];
|
||||
Message[] messages = (Message[]) ((Object[]) msg.obj)[1];
|
||||
FolderInfoHolder folder = mAdapter.getFolder(folderName);
|
||||
if (folder == null) {
|
||||
return;
|
||||
}
|
||||
folder.messages.clear();
|
||||
for (Message message : messages) {
|
||||
mAdapter.addOrUpdateMessage(folder, message, false, false);
|
||||
@ -209,9 +210,17 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
case MSG_FOLDER_STATUS: {
|
||||
String folderName = (String) ((Object[]) msg.obj)[0];
|
||||
String status = (String) ((Object[]) msg.obj)[1];
|
||||
int forceRefresh = msg.arg1;
|
||||
FolderInfoHolder folder = mAdapter.getFolder(folderName);
|
||||
if (folder != null) {
|
||||
folder.status = status;
|
||||
if (forceRefresh != 0) {
|
||||
/*
|
||||
* Reset the last checked time to 0 so that the next expand will
|
||||
* attempt to refresh this folder.
|
||||
*/
|
||||
folder.lastChecked = 0;
|
||||
}
|
||||
mAdapter.notifyDataSetChanged();
|
||||
}
|
||||
break;
|
||||
@ -248,14 +257,18 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
}
|
||||
break;
|
||||
}
|
||||
case MSG_LIST_FOLDERS_FINISHED: {
|
||||
mAdapter.doListFoldersFinished();
|
||||
break;
|
||||
}
|
||||
|
||||
default:
|
||||
super.handleMessage(msg);
|
||||
}
|
||||
}
|
||||
|
||||
public void synchronizeMessages(FolderInfoHolder folder, Message[] messages) {
|
||||
android.os.Message msg = new android.os.Message();
|
||||
public void synchronizeMessages(String folder, Message[] messages) {
|
||||
android.os.Message msg = android.os.Message.obtain();
|
||||
msg.what = MSG_SYNC_MESSAGES;
|
||||
msg.obj = new Object[] { folder, messages };
|
||||
sendMessage(msg);
|
||||
@ -287,17 +300,11 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
sendEmptyMessage(MSG_DATA_CHANGED);
|
||||
}
|
||||
|
||||
public void expandGroup(int groupPosition) {
|
||||
android.os.Message msg = new android.os.Message();
|
||||
msg.what = MSG_EXPAND_GROUP;
|
||||
msg.arg1 = groupPosition;
|
||||
sendMessage(msg);
|
||||
}
|
||||
|
||||
public void folderStatus(String folder, String status) {
|
||||
public void folderStatus(String folder, String status, boolean forceRefresh) {
|
||||
android.os.Message msg = new android.os.Message();
|
||||
msg.what = MSG_FOLDER_STATUS;
|
||||
msg.obj = new String[] { folder, status };
|
||||
msg.arg1 = forceRefresh ? 1 : 0;
|
||||
sendMessage(msg);
|
||||
}
|
||||
|
||||
@ -328,6 +335,10 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
msg.obj = new Object[] { folder, oldUid, newUid };
|
||||
sendMessage(msg);
|
||||
}
|
||||
|
||||
public void listFoldersFinished() {
|
||||
sendEmptyMessage(MSG_LIST_FOLDERS_FINISHED);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -822,13 +833,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
return;
|
||||
}
|
||||
mHandler.progress(false);
|
||||
if (mInitialFolder != null) {
|
||||
int groupPosition = getFolderPosition(mInitialFolder);
|
||||
mInitialFolder = null;
|
||||
if (groupPosition != -1) {
|
||||
mHandler.expandGroup(groupPosition);
|
||||
}
|
||||
}
|
||||
mHandler.listFoldersFinished();
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -871,7 +876,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
if (!account.equals(mAccount)) {
|
||||
return;
|
||||
}
|
||||
synchronizeMessages(folder, messages);
|
||||
mHandler.synchronizeMessages(folder, messages);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -883,7 +888,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
}
|
||||
mHandler.progress(true);
|
||||
mHandler.folderLoading(folder, true);
|
||||
mHandler.folderStatus(folder, null);
|
||||
mHandler.folderStatus(folder, null, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -897,7 +902,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
}
|
||||
mHandler.progress(false);
|
||||
mHandler.folderLoading(folder, false);
|
||||
mHandler.folderStatus(folder, null);
|
||||
mHandler.folderStatus(folder, null, false);
|
||||
onRefresh(false);
|
||||
}
|
||||
|
||||
@ -932,15 +937,7 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
break;
|
||||
}
|
||||
}
|
||||
mHandler.folderStatus(folder, getString(id));
|
||||
FolderInfoHolder holder = getFolder(folder);
|
||||
if (holder != null) {
|
||||
/*
|
||||
* Reset the last checked time to 0 so that the next expand will attempt to
|
||||
* refresh this folder.
|
||||
*/
|
||||
holder.lastChecked = 0;
|
||||
}
|
||||
mHandler.folderStatus(folder, getString(id), true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -1064,6 +1061,20 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
}
|
||||
mRefreshRemote = false;
|
||||
}
|
||||
|
||||
/**
|
||||
* This code is invoked (in the UI thread) when listFoldersFinished() happens. It
|
||||
* implements the UI policy of opening the requested folder (if any).
|
||||
*/
|
||||
public void doListFoldersFinished() {
|
||||
if (mInitialFolder != null) {
|
||||
int groupPosition = getFolderPosition(mInitialFolder);
|
||||
mInitialFolder = null;
|
||||
if (groupPosition != -1) {
|
||||
mListView.expandGroup(groupPosition);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void removeMessage(String folder, String messageUid) {
|
||||
FolderInfoHolder f = getFolder(folder);
|
||||
@ -1077,14 +1088,6 @@ public class FolderMessageList extends ExpandableListActivity {
|
||||
mHandler.removeMessage(f, m);
|
||||
}
|
||||
|
||||
public void synchronizeMessages(String folder, Message[] messages) {
|
||||
FolderInfoHolder f = getFolder(folder);
|
||||
if (f == null) {
|
||||
return;
|
||||
}
|
||||
mHandler.synchronizeMessages(f, messages);
|
||||
}
|
||||
|
||||
public void addOrUpdateMessage(String folder, Message message) {
|
||||
addOrUpdateMessage(folder, message, true, true);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user