1
0
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:
Daniel Applebaum 2010-05-01 20:06:52 +00:00
parent c6fee3efb9
commit ee1b4b70e2
6 changed files with 224 additions and 114 deletions

View File

@ -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)

View File

@ -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();
} }

View File

@ -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

View File

@ -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;

View File

@ -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)

View File

@ -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);
}
} }