mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-13 14:48:04 -05:00
Fixes Issue 1412
Keep search results in sync with newly arrived or deleted messages. Intentionally does not remove messages from search results due to flag (flagged/starred or read/unread) state changes, because that would be awkward while manipulating messages in search results.
This commit is contained in:
parent
c6fee3efb9
commit
ee1b4b70e2
@ -776,6 +776,22 @@ public class MessagingController implements Runnable
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
List<Message> messagesToSearch = null;
|
||||||
|
if (messages != null)
|
||||||
|
{
|
||||||
|
messagesToSearch = new LinkedList<Message>();
|
||||||
|
for (Message message : messages)
|
||||||
|
{
|
||||||
|
if (message.getFolder().getAccount().getUuid().equals(account.getUuid()))
|
||||||
|
{
|
||||||
|
messagesToSearch.add(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (messagesToSearch.isEmpty())
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (listener != null)
|
if (listener != null)
|
||||||
{
|
{
|
||||||
listener.listLocalMessagesStarted(account, null);
|
listener.listLocalMessagesStarted(account, null);
|
||||||
@ -876,7 +892,9 @@ public class MessagingController implements Runnable
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
LocalStore localStore = account.getLocalStore();
|
LocalStore localStore = account.getLocalStore();
|
||||||
localStore.searchForMessages(retrievalListener, query, foldersToSearch, messages, requiredFlags, forbiddenFlags);
|
localStore.searchForMessages(retrievalListener, query, foldersToSearch,
|
||||||
|
messagesToSearch == null ? null : messagesToSearch.toArray(new Message[0]),
|
||||||
|
requiredFlags, forbiddenFlags);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
|
@ -22,7 +22,7 @@ public class ChooseFolder extends K9ListActivity
|
|||||||
{
|
{
|
||||||
String mFolder;
|
String mFolder;
|
||||||
Account mAccount;
|
Account mAccount;
|
||||||
String mUID;
|
MessageReference mMessageReference;
|
||||||
ArrayAdapter<String> adapter;
|
ArrayAdapter<String> adapter;
|
||||||
private ChooseFolderHandler mHandler = new ChooseFolderHandler();
|
private ChooseFolderHandler mHandler = new ChooseFolderHandler();
|
||||||
String heldInbox = null;
|
String heldInbox = null;
|
||||||
@ -33,7 +33,7 @@ public class ChooseFolder extends K9ListActivity
|
|||||||
public static final String EXTRA_ACCOUNT = "com.fsck.k9.ChooseFolder_account";
|
public static final String EXTRA_ACCOUNT = "com.fsck.k9.ChooseFolder_account";
|
||||||
public static final String EXTRA_CUR_FOLDER = "com.fsck.k9.ChooseFolder_curfolder";
|
public static final String EXTRA_CUR_FOLDER = "com.fsck.k9.ChooseFolder_curfolder";
|
||||||
public static final String EXTRA_NEW_FOLDER = "com.fsck.k9.ChooseFolder_newfolder";
|
public static final String EXTRA_NEW_FOLDER = "com.fsck.k9.ChooseFolder_newfolder";
|
||||||
public static final String EXTRA_MESSAGE_UID = "com.fsck.k9.ChooseFolder_messageuid";
|
public static final String EXTRA_MESSAGE = "com.fsck.k9.ChooseFolder_message";
|
||||||
public static final String EXTRA_SHOW_CURRENT = "com.fsck.k9.ChooseFolder_showcurrent";
|
public static final String EXTRA_SHOW_CURRENT = "com.fsck.k9.ChooseFolder_showcurrent";
|
||||||
public static final String EXTRA_SHOW_FOLDER_NONE = "com.fsck.k9.ChooseFolder_showOptionNone";
|
public static final String EXTRA_SHOW_FOLDER_NONE = "com.fsck.k9.ChooseFolder_showOptionNone";
|
||||||
public static final String EXTRA_SHOW_DISPLAYABLE_ONLY = "com.fsck.k9.ChooseFolder_showDisplayableOnly";
|
public static final String EXTRA_SHOW_DISPLAYABLE_ONLY = "com.fsck.k9.ChooseFolder_showDisplayableOnly";
|
||||||
@ -51,7 +51,7 @@ public class ChooseFolder extends K9ListActivity
|
|||||||
Intent intent = getIntent();
|
Intent intent = getIntent();
|
||||||
String accountUuid = intent.getStringExtra(EXTRA_ACCOUNT);
|
String accountUuid = intent.getStringExtra(EXTRA_ACCOUNT);
|
||||||
mAccount = Preferences.getPreferences(this).getAccount(accountUuid);
|
mAccount = Preferences.getPreferences(this).getAccount(accountUuid);
|
||||||
mUID = intent.getStringExtra(EXTRA_MESSAGE_UID);
|
mMessageReference = (MessageReference)intent.getSerializableExtra(EXTRA_MESSAGE);
|
||||||
mFolder = intent.getStringExtra(EXTRA_CUR_FOLDER);
|
mFolder = intent.getStringExtra(EXTRA_CUR_FOLDER);
|
||||||
if (intent.getStringExtra(EXTRA_SHOW_CURRENT) != null)
|
if (intent.getStringExtra(EXTRA_SHOW_CURRENT) != null)
|
||||||
{
|
{
|
||||||
@ -89,7 +89,7 @@ public class ChooseFolder extends K9ListActivity
|
|||||||
destFolderName = heldInbox;
|
destFolderName = heldInbox;
|
||||||
}
|
}
|
||||||
intent.putExtra(EXTRA_NEW_FOLDER, destFolderName);
|
intent.putExtra(EXTRA_NEW_FOLDER, destFolderName);
|
||||||
intent.putExtra(EXTRA_MESSAGE_UID, mUID);
|
intent.putExtra(EXTRA_MESSAGE, mMessageReference);
|
||||||
setResult(RESULT_OK, intent);
|
setResult(RESULT_OK, intent);
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,8 @@ import java.util.ArrayList;
|
|||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
@ -124,7 +126,6 @@ public class MessageList
|
|||||||
|
|
||||||
class MessageListHandler extends Handler
|
class MessageListHandler extends Handler
|
||||||
{
|
{
|
||||||
|
|
||||||
public void removeMessage(final List<MessageInfoHolder> messages)
|
public void removeMessage(final List<MessageInfoHolder> messages)
|
||||||
{
|
{
|
||||||
runOnUiThread(new Runnable()
|
runOnUiThread(new Runnable()
|
||||||
@ -145,6 +146,8 @@ public class MessageList
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
resetUnreadCountOnThread();
|
||||||
|
|
||||||
mAdapter.notifyDataSetChanged();
|
mAdapter.notifyDataSetChanged();
|
||||||
toggleBatchButtons();
|
toggleBatchButtons();
|
||||||
}
|
}
|
||||||
@ -152,20 +155,20 @@ public class MessageList
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addMessages(List<MessageInfoHolder> messages)
|
public void addMessages(final List<MessageInfoHolder> messages)
|
||||||
{
|
{
|
||||||
|
|
||||||
final boolean wasEmpty = mAdapter.messages.isEmpty();
|
final boolean wasEmpty = mAdapter.messages.isEmpty();
|
||||||
for (final MessageInfoHolder message : messages)
|
runOnUiThread(new Runnable()
|
||||||
{
|
{
|
||||||
|
public void run()
|
||||||
if (mFolderName == null || (message.folder != null && message.folder.name.equals(mFolderName)))
|
|
||||||
{
|
{
|
||||||
|
for (final MessageInfoHolder message : messages)
|
||||||
runOnUiThread(new Runnable()
|
|
||||||
{
|
{
|
||||||
public void run()
|
|
||||||
|
if (mFolderName == null || (message.folder != null && message.folder.name.equals(mFolderName)))
|
||||||
{
|
{
|
||||||
|
|
||||||
int index = Collections.binarySearch(mAdapter.messages, message);
|
int index = Collections.binarySearch(mAdapter.messages, message);
|
||||||
|
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
@ -176,23 +179,42 @@ public class MessageList
|
|||||||
mAdapter.messages.add(index, message);
|
mAdapter.messages.add(index, message);
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
runOnUiThread(new Runnable()
|
|
||||||
{
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
if (wasEmpty)
|
if (wasEmpty)
|
||||||
{
|
{
|
||||||
mListView.setSelection(0);
|
mListView.setSelection(0);
|
||||||
}
|
}
|
||||||
|
resetUnreadCountOnThread();
|
||||||
|
|
||||||
mAdapter.notifyDataSetChanged();
|
mAdapter.notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void resetUnreadCount()
|
||||||
|
{
|
||||||
|
runOnUiThread(new Runnable()
|
||||||
|
{
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
resetUnreadCountOnThread();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
private void resetUnreadCountOnThread()
|
||||||
|
{
|
||||||
|
if (mQueryString != null)
|
||||||
|
{
|
||||||
|
int unreadCount = 0;
|
||||||
|
for (MessageInfoHolder holder : mAdapter.messages)
|
||||||
|
{
|
||||||
|
unreadCount += holder.read ? 0 : 1;
|
||||||
|
}
|
||||||
|
mUnreadMessageCount = unreadCount;
|
||||||
|
refreshTitleOnThread();
|
||||||
|
}
|
||||||
|
}
|
||||||
private void sortMessages()
|
private void sortMessages()
|
||||||
{
|
{
|
||||||
runOnUiThread(new Runnable()
|
runOnUiThread(new Runnable()
|
||||||
@ -225,11 +247,15 @@ public class MessageList
|
|||||||
{
|
{
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
setWindowTitle();
|
refreshTitleOnThread();
|
||||||
setWindowProgress();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
private void refreshTitleOnThread()
|
||||||
|
{
|
||||||
|
setWindowTitle();
|
||||||
|
setWindowProgress();
|
||||||
|
}
|
||||||
private void setWindowProgress()
|
private void setWindowProgress()
|
||||||
{
|
{
|
||||||
int level = Window.PROGRESS_END;
|
int level = Window.PROGRESS_END;
|
||||||
@ -701,9 +727,9 @@ public class MessageList
|
|||||||
|
|
||||||
private void onOpenMessage(MessageInfoHolder message)
|
private void onOpenMessage(MessageInfoHolder message)
|
||||||
{
|
{
|
||||||
if (message.folder.name.equals(message.account.getDraftsFolderName()))
|
if (message.folder.name.equals(message.message.getFolder().getAccount().getDraftsFolderName()))
|
||||||
{
|
{
|
||||||
MessageCompose.actionEditDraft(this, message.account, message.message);
|
MessageCompose.actionEditDraft(this, message.message.getFolder().getAccount(), message.message);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -712,16 +738,10 @@ public class MessageList
|
|||||||
|
|
||||||
for (MessageInfoHolder holder : mAdapter.messages)
|
for (MessageInfoHolder holder : mAdapter.messages)
|
||||||
{
|
{
|
||||||
MessageReference ref = new MessageReference();
|
MessageReference ref = holder.message.makeMessageReference();
|
||||||
ref.accountUuid = holder.message.getFolder().getAccount().getUuid();
|
|
||||||
ref.folderName = holder.message.getFolder().getName();
|
|
||||||
ref.uid = holder.uid;
|
|
||||||
messageRefs.add(ref);
|
messageRefs.add(ref);
|
||||||
}
|
}
|
||||||
MessageReference ref = new MessageReference();
|
MessageReference ref = message.message.makeMessageReference();
|
||||||
ref.accountUuid = message.message.getFolder().getAccount().getUuid();
|
|
||||||
ref.folderName = message.message.getFolder().getName();
|
|
||||||
ref.uid = message.uid;
|
|
||||||
Log.i(K9.LOG_TAG, "MessageList sending message " + ref);
|
Log.i(K9.LOG_TAG, "MessageList sending message " + ref);
|
||||||
|
|
||||||
MessageView.actionView(this, ref, messageRefs);
|
MessageView.actionView(this, ref, messageRefs);
|
||||||
@ -844,7 +864,7 @@ public class MessageList
|
|||||||
|
|
||||||
private void onMove(MessageInfoHolder holder)
|
private void onMove(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
if (mController.isMoveCapable(holder.account) == false)
|
if (mController.isMoveCapable(holder.message.getFolder().getAccount()) == false)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -857,15 +877,15 @@ public class MessageList
|
|||||||
}
|
}
|
||||||
|
|
||||||
Intent intent = new Intent(this, ChooseFolder.class);
|
Intent intent = new Intent(this, ChooseFolder.class);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, holder.account.getUuid());
|
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, holder.message.getFolder().getAccount().getUuid());
|
||||||
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, holder.folder.name);
|
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, holder.folder.name);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_MESSAGE_UID, holder.message.getUid());
|
intent.putExtra(ChooseFolder.EXTRA_MESSAGE, holder.message.makeMessageReference());
|
||||||
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_MOVE);
|
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_MOVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onCopy(MessageInfoHolder holder)
|
private void onCopy(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
if (mController.isCopyCapable(holder.account) == false)
|
if (mController.isCopyCapable(holder.message.getFolder().getAccount()) == false)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -878,9 +898,9 @@ public class MessageList
|
|||||||
}
|
}
|
||||||
|
|
||||||
Intent intent = new Intent(this, ChooseFolder.class);
|
Intent intent = new Intent(this, ChooseFolder.class);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, holder.account.getUuid());
|
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, holder.message.getFolder().getAccount().getUuid());
|
||||||
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, holder.folder.name);
|
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, holder.folder.name);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_MESSAGE_UID, holder.message.getUid());
|
intent.putExtra(ChooseFolder.EXTRA_MESSAGE, holder.message.makeMessageReference());
|
||||||
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_COPY);
|
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_COPY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -900,9 +920,9 @@ public class MessageList
|
|||||||
|
|
||||||
String destFolderName = data.getStringExtra(ChooseFolder.EXTRA_NEW_FOLDER);
|
String destFolderName = data.getStringExtra(ChooseFolder.EXTRA_NEW_FOLDER);
|
||||||
|
|
||||||
String uid = data.getStringExtra(ChooseFolder.EXTRA_MESSAGE_UID);
|
MessageReference ref = (MessageReference)data.getSerializableExtra(ChooseFolder.EXTRA_MESSAGE);
|
||||||
|
|
||||||
MessageInfoHolder m = mAdapter.getMessage(uid);
|
MessageInfoHolder m = mAdapter.getMessage(ref);
|
||||||
if (destFolderName != null && m != null)
|
if (destFolderName != null && m != null)
|
||||||
{
|
{
|
||||||
switch (requestCode)
|
switch (requestCode)
|
||||||
@ -936,19 +956,19 @@ public class MessageList
|
|||||||
|
|
||||||
private void onMoveChosen(MessageInfoHolder holder, String folderName)
|
private void onMoveChosen(MessageInfoHolder holder, String folderName)
|
||||||
{
|
{
|
||||||
if (mController.isMoveCapable(holder.account) == true && folderName != null)
|
if (mController.isMoveCapable(holder.message.getFolder().getAccount()) == true && folderName != null)
|
||||||
{
|
{
|
||||||
mAdapter.removeMessage(holder);
|
mAdapter.removeMessage(holder);
|
||||||
mController.moveMessage(holder.account, holder.message.getFolder().getName(), holder.message, folderName, null);
|
mController.moveMessage(holder.message.getFolder().getAccount(), holder.message.getFolder().getName(), holder.message, folderName, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void onCopyChosen(MessageInfoHolder holder, String folderName)
|
private void onCopyChosen(MessageInfoHolder holder, String folderName)
|
||||||
{
|
{
|
||||||
if (mController.isCopyCapable(holder.account) == true && folderName != null)
|
if (mController.isCopyCapable(holder.message.getFolder().getAccount()) == true && folderName != null)
|
||||||
{
|
{
|
||||||
mController.copyMessage(holder.account,
|
mController.copyMessage(holder.message.getFolder().getAccount(),
|
||||||
holder.message.getFolder().getName(), holder.message, folderName, null);
|
holder.message.getFolder().getName(), holder.message, folderName, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -956,17 +976,17 @@ public class MessageList
|
|||||||
|
|
||||||
private void onReply(MessageInfoHolder holder)
|
private void onReply(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
MessageCompose.actionReply(this, holder.account, holder.message, false);
|
MessageCompose.actionReply(this, holder.message.getFolder().getAccount(), holder.message, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onReplyAll(MessageInfoHolder holder)
|
private void onReplyAll(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
MessageCompose.actionReply(this, holder.account, holder.message, true);
|
MessageCompose.actionReply(this, holder.message.getFolder().getAccount(), holder.message, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onForward(MessageInfoHolder holder)
|
private void onForward(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
MessageCompose.actionForward(this, holder.account, holder.message);
|
MessageCompose.actionForward(this, holder.message.getFolder().getAccount(), holder.message);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onMarkAllAsRead(final Account account, final String folder)
|
private void onMarkAllAsRead(final Account account, final String folder)
|
||||||
@ -1057,7 +1077,7 @@ public class MessageList
|
|||||||
|
|
||||||
private void onToggleRead(MessageInfoHolder holder)
|
private void onToggleRead(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
mController.setFlag(holder.account, holder.message.getFolder().getName(), new String[] { holder.uid }, Flag.SEEN, !holder.read);
|
mController.setFlag(holder.message.getFolder().getAccount(), holder.message.getFolder().getName(), new String[] { holder.uid }, Flag.SEEN, !holder.read);
|
||||||
holder.read = !holder.read;
|
holder.read = !holder.read;
|
||||||
mHandler.sortMessages();
|
mHandler.sortMessages();
|
||||||
}
|
}
|
||||||
@ -1065,7 +1085,7 @@ public class MessageList
|
|||||||
private void onToggleFlag(MessageInfoHolder holder)
|
private void onToggleFlag(MessageInfoHolder holder)
|
||||||
{
|
{
|
||||||
|
|
||||||
mController.setFlag(holder.account, holder.message.getFolder().getName(), new String[] { holder.uid }, Flag.FLAGGED, !holder.flagged);
|
mController.setFlag(holder.message.getFolder().getAccount(), holder.message.getFolder().getName(), new String[] { holder.uid }, Flag.FLAGGED, !holder.flagged);
|
||||||
holder.flagged = !holder.flagged;
|
holder.flagged = !holder.flagged;
|
||||||
mHandler.sortMessages();
|
mHandler.sortMessages();
|
||||||
}
|
}
|
||||||
@ -1457,12 +1477,12 @@ public class MessageList
|
|||||||
menu.findItem(R.id.flag).setTitle(R.string.unflag_action);
|
menu.findItem(R.id.flag).setTitle(R.string.unflag_action);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mController.isCopyCapable(message.account) == false)
|
if (mController.isCopyCapable(message.message.getFolder().getAccount()) == false)
|
||||||
{
|
{
|
||||||
menu.findItem(R.id.copy).setVisible(false);
|
menu.findItem(R.id.copy).setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mController.isMoveCapable(message.account) == false)
|
if (mController.isMoveCapable(message.message.getFolder().getAccount()) == false)
|
||||||
{
|
{
|
||||||
menu.findItem(R.id.move).setVisible(false);
|
menu.findItem(R.id.move).setVisible(false);
|
||||||
}
|
}
|
||||||
@ -1562,18 +1582,14 @@ public class MessageList
|
|||||||
@Override
|
@Override
|
||||||
public void synchronizeMailboxAddOrUpdateMessage(Account account, String folder, Message message)
|
public void synchronizeMailboxAddOrUpdateMessage(Account account, String folder, Message message)
|
||||||
{
|
{
|
||||||
// eventually, we may want to check a message added during sync against the query filter
|
addOrUpdateMessage(account, folder, message, true);
|
||||||
if (mQueryString == null)
|
|
||||||
{
|
|
||||||
addOrUpdateMessage(account, folder, message);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void synchronizeMailboxRemovedMessage(Account account, String folder,Message message)
|
public void synchronizeMailboxRemovedMessage(Account account, String folder,Message message)
|
||||||
{
|
{
|
||||||
MessageInfoHolder holder = getMessage(message.getUid());
|
MessageInfoHolder holder = getMessage(message);
|
||||||
if (holder == null)
|
if (holder == null)
|
||||||
{
|
{
|
||||||
Log.w(K9.LOG_TAG, "Got callback to remove non-existent message with UID " + message.getUid());
|
Log.w(K9.LOG_TAG, "Got callback to remove non-existent message with UID " + message.getUid());
|
||||||
@ -1634,13 +1650,10 @@ public class MessageList
|
|||||||
@Override
|
@Override
|
||||||
public void listLocalMessagesRemoveMessage(Account account, String folder,Message message)
|
public void listLocalMessagesRemoveMessage(Account account, String folder,Message message)
|
||||||
{
|
{
|
||||||
if (updateForMe(account, folder))
|
MessageInfoHolder holder = getMessage(message);
|
||||||
|
if (holder != null)
|
||||||
{
|
{
|
||||||
MessageInfoHolder holder = getMessage(message.getUid());
|
removeMessage(holder);
|
||||||
if (holder != null)
|
|
||||||
{
|
|
||||||
removeMessage(getMessage(message.getUid()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1648,13 +1661,13 @@ public class MessageList
|
|||||||
@Override
|
@Override
|
||||||
public void listLocalMessagesAddMessages(Account account, String folder, List<Message> messages)
|
public void listLocalMessagesAddMessages(Account account, String folder, List<Message> messages)
|
||||||
{
|
{
|
||||||
addOrUpdateMessages(account, folder, messages);
|
addOrUpdateMessages(account, folder, messages, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void listLocalMessagesUpdateMessage(Account account, String folder, Message message)
|
public void listLocalMessagesUpdateMessage(Account account, String folder, Message message)
|
||||||
{
|
{
|
||||||
addOrUpdateMessage(account, folder, message);
|
addOrUpdateMessage(account, folder, message, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -1706,24 +1719,23 @@ public class MessageList
|
|||||||
@Override
|
@Override
|
||||||
public void messageUidChanged(Account account, String folder, String oldUid, String newUid)
|
public void messageUidChanged(Account account, String folder, String oldUid, String newUid)
|
||||||
{
|
{
|
||||||
if (updateForMe(account, folder))
|
MessageReference ref = new MessageReference();
|
||||||
|
ref.accountUuid = account.getUuid();
|
||||||
|
ref.folderName = folder;
|
||||||
|
ref.uid = oldUid;
|
||||||
|
|
||||||
|
MessageInfoHolder holder = getMessage(ref);
|
||||||
|
if (holder != null)
|
||||||
{
|
{
|
||||||
MessageInfoHolder holder = getMessage(oldUid);
|
holder.uid = newUid;
|
||||||
if (holder != null)
|
holder.message.setUid(newUid);
|
||||||
{
|
|
||||||
holder.uid = newUid;
|
|
||||||
holder.message.setUid(newUid);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private boolean updateForMe(Account account, String folder)
|
private boolean updateForMe(Account account, String folder)
|
||||||
{
|
{
|
||||||
if (mQueryString != null || (account.equals(mAccount) && mFolderName != null && folder.equals(mFolderName)))
|
if ((account.equals(mAccount) && mFolderName != null && folder.equals(mFolderName)))
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1759,45 +1771,74 @@ public class MessageList
|
|||||||
removeMessages(messages);
|
removeMessages(messages);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addOrUpdateMessage(Account account, String folder, Message message)
|
private void addOrUpdateMessage(Account account, String folder, Message message, boolean verifyAgainstSearch)
|
||||||
{
|
{
|
||||||
List<Message> messages = new ArrayList<Message>();
|
List<Message> messages = new ArrayList<Message>();
|
||||||
messages.add(message);
|
messages.add(message);
|
||||||
addOrUpdateMessages(account, folder, messages);
|
addOrUpdateMessages(account, folder, messages, verifyAgainstSearch);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addOrUpdateMessages(Account account, String folder, List<Message> messages)
|
private void addOrUpdateMessages(Account account, String folder, List<Message> messages, boolean verifyAgainstSearch)
|
||||||
{
|
{
|
||||||
boolean needsSort = false;
|
boolean needsSort = false;
|
||||||
List<MessageInfoHolder> messagesToAdd = new ArrayList<MessageInfoHolder>();
|
final List<MessageInfoHolder> messagesToAdd = new ArrayList<MessageInfoHolder>();
|
||||||
List<MessageInfoHolder> messagesToRemove = new ArrayList<MessageInfoHolder>();
|
List<MessageInfoHolder> messagesToRemove = new ArrayList<MessageInfoHolder>();
|
||||||
|
List<Message> messagesToSearch = new ArrayList<Message>();
|
||||||
|
|
||||||
for (Message message : messages)
|
for (Message message : messages)
|
||||||
{
|
{
|
||||||
if (updateForMe(account, folder))
|
MessageInfoHolder m = getMessage(message);
|
||||||
|
if (message.isSet(Flag.DELETED))
|
||||||
{
|
{
|
||||||
MessageInfoHolder m = getMessage(message.getUid());
|
if (m != null)
|
||||||
if (message.isSet(Flag.DELETED))
|
|
||||||
{
|
{
|
||||||
if (m != null)
|
messagesToRemove.add(m);
|
||||||
{
|
|
||||||
messagesToRemove.add(m);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (m == null)
|
}
|
||||||
|
else if (m == null)
|
||||||
|
{
|
||||||
|
if (updateForMe(account, folder))
|
||||||
{
|
{
|
||||||
m = new MessageInfoHolder(message, account);
|
m = new MessageInfoHolder(message);
|
||||||
messagesToAdd.add(m);
|
messagesToAdd.add(m);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m.populate(message, new FolderInfoHolder(message.getFolder(), account), account);
|
if (mQueryString != null)
|
||||||
needsSort = true;
|
{
|
||||||
|
if (verifyAgainstSearch)
|
||||||
|
{
|
||||||
|
messagesToSearch.add(message);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m = new MessageInfoHolder(message);
|
||||||
|
messagesToAdd.add(m);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
else
|
||||||
|
{
|
||||||
|
m.populate(message, new FolderInfoHolder(message.getFolder(), account), account);
|
||||||
|
needsSort = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
if (messagesToSearch.size() > 0)
|
||||||
|
{
|
||||||
|
mController.searchLocalMessages(mAccountUuids, mFolderNames, messagesToSearch.toArray(new Message[0]), mQueryString, mIntegrate, mQueryFlags, mForbiddenFlags,
|
||||||
|
new MessagingListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void listLocalMessagesAddMessages(Account account, String folder, List<Message> messages)
|
||||||
|
{
|
||||||
|
addOrUpdateMessages(account, folder, messages, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
if (messagesToRemove.size() > 0)
|
if (messagesToRemove.size() > 0)
|
||||||
{
|
{
|
||||||
removeMessages(messagesToRemove);
|
removeMessages(messagesToRemove);
|
||||||
@ -1809,18 +1850,24 @@ public class MessageList
|
|||||||
if (needsSort)
|
if (needsSort)
|
||||||
{
|
{
|
||||||
mHandler.sortMessages();
|
mHandler.sortMessages();
|
||||||
|
mHandler.resetUnreadCount();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// XXX TODO - make this not use a for loop
|
public MessageInfoHolder getMessage(Message message)
|
||||||
public MessageInfoHolder getMessage(String messageUid)
|
|
||||||
{
|
{
|
||||||
MessageInfoHolder searchHolder = new MessageInfoHolder();
|
return getMessage(message.makeMessageReference());
|
||||||
searchHolder.uid = messageUid;
|
}
|
||||||
int index = mAdapter.messages.indexOf((Object) searchHolder);
|
|
||||||
if (index >= 0)
|
// XXX TODO - make this not use a for loop
|
||||||
|
public MessageInfoHolder getMessage(MessageReference messageReference)
|
||||||
|
{
|
||||||
|
for (MessageInfoHolder holder : mAdapter.messages)
|
||||||
{
|
{
|
||||||
return (MessageInfoHolder)mAdapter.messages.get(index);
|
if (holder.message.equalsReference(messageReference))
|
||||||
|
{
|
||||||
|
return holder;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -2000,7 +2047,7 @@ public class MessageList
|
|||||||
holder.selected.setVisibility(View.GONE);
|
holder.selected.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
holder.chip.setBackgroundColor(message.account.getChipColor());
|
holder.chip.setBackgroundColor(message.message.getFolder().getAccount().getChipColor());
|
||||||
holder.chip.getBackground().setAlpha(message.read ? 127 : 255);
|
holder.chip.getBackground().setAlpha(message.read ? 127 : 255);
|
||||||
|
|
||||||
if (message.downloaded)
|
if (message.downloaded)
|
||||||
@ -2190,8 +2237,6 @@ public class MessageList
|
|||||||
|
|
||||||
public Message message;
|
public Message message;
|
||||||
|
|
||||||
public Account account;
|
|
||||||
|
|
||||||
public FolderInfoHolder folder;
|
public FolderInfoHolder folder;
|
||||||
|
|
||||||
public boolean selected;
|
public boolean selected;
|
||||||
@ -2202,10 +2247,11 @@ public class MessageList
|
|||||||
this.selected = false;
|
this.selected = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public MessageInfoHolder(Message m, Account account)
|
public MessageInfoHolder(Message m)
|
||||||
{
|
{
|
||||||
this();
|
this();
|
||||||
populate(m, new FolderInfoHolder(m.getFolder(), account), account);
|
Account account = m.getFolder().getAccount();
|
||||||
|
populate(m, new FolderInfoHolder(m.getFolder(), m.getFolder().getAccount()), account);
|
||||||
}
|
}
|
||||||
|
|
||||||
public MessageInfoHolder(Message m, FolderInfoHolder folder, Account account)
|
public MessageInfoHolder(Message m, FolderInfoHolder folder, Account account)
|
||||||
@ -2259,7 +2305,6 @@ public class MessageList
|
|||||||
|
|
||||||
this.uid = message.getUid();
|
this.uid = message.getUid();
|
||||||
this.message = m;
|
this.message = m;
|
||||||
this.account = account;
|
|
||||||
this.preview = message.getPreview();
|
this.preview = message.getPreview();
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -2275,7 +2320,13 @@ public class MessageList
|
|||||||
@Override
|
@Override
|
||||||
public boolean equals(Object o)
|
public boolean equals(Object o)
|
||||||
{
|
{
|
||||||
return (this.uid.equals(((MessageInfoHolder)o).uid));
|
|
||||||
|
if (o instanceof MessageInfoHolder == false)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
MessageInfoHolder other = (MessageInfoHolder)o;
|
||||||
|
return message.equals(other.message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -2,14 +2,19 @@ package com.fsck.k9.activity;
|
|||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
import com.fsck.k9.K9;
|
||||||
|
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
public class MessageReference implements Serializable
|
public class MessageReference implements Serializable
|
||||||
{
|
{
|
||||||
String accountUuid;
|
public String accountUuid;
|
||||||
String folderName;
|
public String folderName;
|
||||||
String uid;
|
public String uid;
|
||||||
|
|
||||||
public boolean equals(Object o)
|
public boolean equals(Object o)
|
||||||
{
|
{
|
||||||
|
Log.i(K9.LOG_TAG, "Comparing this " + this + " to " + o);
|
||||||
if (o instanceof MessageReference == false)
|
if (o instanceof MessageReference == false)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
|
@ -846,7 +846,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
Intent intent = new Intent(this, ChooseFolder.class);
|
Intent intent = new Intent(this, ChooseFolder.class);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, mAccount.getUuid());
|
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, mAccount.getUuid());
|
||||||
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, mMessageReference.folderName);
|
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, mMessageReference.folderName);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_MESSAGE_UID, mMessageReference);
|
intent.putExtra(ChooseFolder.EXTRA_MESSAGE, mMessageReference);
|
||||||
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_MOVE);
|
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_MOVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -865,7 +865,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
Intent intent = new Intent(this, ChooseFolder.class);
|
Intent intent = new Intent(this, ChooseFolder.class);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, mAccount.getUuid());
|
intent.putExtra(ChooseFolder.EXTRA_ACCOUNT, mAccount.getUuid());
|
||||||
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, mMessageReference.folderName);
|
intent.putExtra(ChooseFolder.EXTRA_CUR_FOLDER, mMessageReference.folderName);
|
||||||
intent.putExtra(ChooseFolder.EXTRA_MESSAGE_UID, mMessageReference);
|
intent.putExtra(ChooseFolder.EXTRA_MESSAGE, mMessageReference);
|
||||||
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_COPY);
|
startActivityForResult(intent, ACTIVITY_CHOOSE_FOLDER_COPY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -883,9 +883,9 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
return;
|
return;
|
||||||
String destFolderName = data.getStringExtra(ChooseFolder.EXTRA_NEW_FOLDER);
|
String destFolderName = data.getStringExtra(ChooseFolder.EXTRA_NEW_FOLDER);
|
||||||
String srcFolderName = data.getStringExtra(ChooseFolder.EXTRA_CUR_FOLDER);
|
String srcFolderName = data.getStringExtra(ChooseFolder.EXTRA_CUR_FOLDER);
|
||||||
String uid = data.getStringExtra(ChooseFolder.EXTRA_MESSAGE_UID);
|
MessageReference ref = (MessageReference)data.getSerializableExtra(ChooseFolder.EXTRA_MESSAGE);
|
||||||
|
|
||||||
if (uid.equals(mMessageReference) && srcFolderName.equals(mMessageReference.folderName))
|
if (mMessageReference.equals(ref))
|
||||||
{
|
{
|
||||||
|
|
||||||
switch (requestCode)
|
switch (requestCode)
|
||||||
|
@ -4,8 +4,12 @@ package com.fsck.k9.mail;
|
|||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
|
import com.fsck.k9.activity.MessageReference;
|
||||||
|
|
||||||
public abstract class Message implements Part, Body
|
public abstract class Message implements Part, Body
|
||||||
{
|
{
|
||||||
|
private MessageReference mReference = null;
|
||||||
|
|
||||||
public enum RecipientType
|
public enum RecipientType
|
||||||
{
|
{
|
||||||
TO, CC, BCC,
|
TO, CC, BCC,
|
||||||
@ -19,6 +23,19 @@ public abstract class Message implements Part, Body
|
|||||||
|
|
||||||
protected Folder mFolder;
|
protected Folder mFolder;
|
||||||
|
|
||||||
|
public boolean equals(Object o)
|
||||||
|
{
|
||||||
|
if (o == null || o instanceof Message == false)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Message other = (Message)o;
|
||||||
|
return (mFolder.getName().equals(other.getFolder().getName())
|
||||||
|
&& mFolder.getAccount().getUuid().equals(other.getFolder().getAccount().getUuid())
|
||||||
|
&& mUid.equals(other.getUid()));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public String getUid()
|
public String getUid()
|
||||||
{
|
{
|
||||||
return mUid;
|
return mUid;
|
||||||
@ -26,6 +43,7 @@ public abstract class Message implements Part, Body
|
|||||||
|
|
||||||
public void setUid(String uid)
|
public void setUid(String uid)
|
||||||
{
|
{
|
||||||
|
mReference = null;
|
||||||
this.mUid = uid;
|
this.mUid = uid;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,4 +163,22 @@ public abstract class Message implements Part, Body
|
|||||||
public abstract void saveChanges() throws MessagingException;
|
public abstract void saveChanges() throws MessagingException;
|
||||||
|
|
||||||
public abstract void setEncoding(String encoding);
|
public abstract void setEncoding(String encoding);
|
||||||
|
|
||||||
|
public MessageReference makeMessageReference()
|
||||||
|
{
|
||||||
|
if (mReference == null)
|
||||||
|
{
|
||||||
|
mReference = new MessageReference();
|
||||||
|
mReference.accountUuid = getFolder().getAccount().getUuid();
|
||||||
|
mReference.folderName = getFolder().getName();
|
||||||
|
mReference.uid = mUid;
|
||||||
|
}
|
||||||
|
return mReference;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean equalsReference(MessageReference ref)
|
||||||
|
{
|
||||||
|
MessageReference tmpReference = makeMessageReference();
|
||||||
|
return tmpReference.equals(ref);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user