diff --git a/src/com/fsck/k9/activity/MessageView.java b/src/com/fsck/k9/activity/MessageView.java index 4fae5910f..1ba481cab 100644 --- a/src/com/fsck/k9/activity/MessageView.java +++ b/src/com/fsck/k9/activity/MessageView.java @@ -1455,8 +1455,6 @@ public class MessageView extends K9Activity implements OnClickListener { final Address senderEmail = mMessage.getFrom()[0]; mContacts.createContact(this, senderEmail); - - Address.clearContactsNameCache(); } catch (Exception e) { @@ -2170,11 +2168,12 @@ public class MessageView extends K9Activity implements OnClickListener final Message message) throws MessagingException { String subjectText = message.getSubject(); - CharSequence fromText = Address.toFriendly(message.getFrom(), mContacts); + final Contacts contacts = K9.showContactName() ? mContacts : null; + CharSequence fromText = Address.toFriendly(message.getFrom(), contacts); String dateText = getDateFormat().format(message.getSentDate()); String timeText = getTimeFormat().format(message.getSentDate()); - CharSequence toText = Address.toFriendly(message.getRecipients(RecipientType.TO), mContacts); - CharSequence ccText = Address.toFriendly(message.getRecipients(RecipientType.CC), mContacts); + CharSequence toText = Address.toFriendly(message.getRecipients(RecipientType.TO), contacts); + CharSequence ccText = Address.toFriendly(message.getRecipients(RecipientType.CC), contacts); int color = mAccount.getChipColor(); boolean hasAttachments = ((LocalMessage) message).getAttachmentCount() > 0; diff --git a/src/com/fsck/k9/helper/Contacts.java b/src/com/fsck/k9/helper/Contacts.java index 6f85bf7f5..e95caf130 100644 --- a/src/com/fsck/k9/helper/Contacts.java +++ b/src/com/fsck/k9/helper/Contacts.java @@ -147,7 +147,14 @@ public abstract class Contacts */ public abstract Cursor searchContacts(CharSequence filter); - public abstract Cursor searchByAddress(String address); + /** + * Get the name of the contact an email address belongs to. + * + * @param address The email address to search for. + * @return The name of the contact the email address belongs to. Or + * null if there's no matching contact. + */ + public abstract String getNameForAddress(String address); /** * Extract the name from a {@link Cursor} instance returned by diff --git a/src/com/fsck/k9/helper/ContactsSdk3_4.java b/src/com/fsck/k9/helper/ContactsSdk3_4.java index f512e067d..0d15d8baa 100644 --- a/src/com/fsck/k9/helper/ContactsSdk3_4.java +++ b/src/com/fsck/k9/helper/ContactsSdk3_4.java @@ -174,21 +174,16 @@ public class ContactsSdk3_4 extends com.fsck.k9.helper.Contacts } @Override - public Cursor searchByAddress(String address) + public String getNameForAddress(String address) { - final String where; - final String[] args; if (address == null) { - where = null; - args = null; - } - else - { - where = Contacts.ContactMethods.DATA + " = ?"; - args = new String[] {address}; + return null; } + final String where = Contacts.ContactMethods.DATA + " = ?"; + final String[] args = new String[] {address}; + final Cursor c = mContentResolver.query( Contacts.ContactMethods.CONTENT_EMAIL_URI, PROJECTION, @@ -196,20 +191,18 @@ public class ContactsSdk3_4 extends com.fsck.k9.helper.Contacts args, SORT_ORDER); + String name = null; if (c != null) { - /* - * To prevent expensive execution in the UI thread: - * Cursors get lazily executed, so if you don't call anything on - * the cursor before returning it from the background thread you'll - * have a complied program for the cursor, but it won't have been - * executed to generate the data yet. Often the execution is more - * expensive than the compilation... - */ - c.getCount(); + if (c.getCount() > 0) + { + c.moveToFirst(); + name = getName(c); + } + c.close(); } - return c; + return name; } @Override diff --git a/src/com/fsck/k9/helper/ContactsSdk5.java b/src/com/fsck/k9/helper/ContactsSdk5.java index 2388dd734..1ebf26e11 100644 --- a/src/com/fsck/k9/helper/ContactsSdk5.java +++ b/src/com/fsck/k9/helper/ContactsSdk5.java @@ -150,10 +150,14 @@ public class ContactsSdk5 extends com.fsck.k9.helper.Contacts } @Override - public Cursor searchByAddress(String address) + public String getNameForAddress(String address) { - final String filter = (address == null) ? "" : address; - final Uri uri = Uri.withAppendedPath(Email.CONTENT_FILTER_URI, Uri.encode(filter)); + if (address == null) + { + return null; + } + + final Uri uri = Uri.withAppendedPath(Email.CONTENT_LOOKUP_URI, Uri.encode(address)); final Cursor c = mContentResolver.query( uri, PROJECTION, @@ -161,20 +165,18 @@ public class ContactsSdk5 extends com.fsck.k9.helper.Contacts null, SORT_ORDER); + String name = null; if (c != null) { - /* - * To prevent expensive execution in the UI thread: - * Cursors get lazily executed, so if you don't call anything on - * the cursor before returning it from the background thread you'll - * have a complied program for the cursor, but it won't have been - * executed to generate the data yet. Often the execution is more - * expensive than the compilation... - */ - c.getCount(); + if (c.getCount() > 0) + { + c.moveToFirst(); + name = getName(c); + } + c.close(); } - return c; + return name; } @Override diff --git a/src/com/fsck/k9/helper/MessageHelper.java b/src/com/fsck/k9/helper/MessageHelper.java index 5487cb6a4..b8c38b308 100644 --- a/src/com/fsck/k9/helper/MessageHelper.java +++ b/src/com/fsck/k9/helper/MessageHelper.java @@ -53,7 +53,7 @@ public class MessageHelper public void populate(final MessageInfoHolder target, final Message m, final FolderInfoHolder folder, final Account account) { - final Contacts contactHelper = Contacts.getInstance(mContext); + final Contacts contactHelper = K9.showContactName() ? Contacts.getInstance(mContext) : null; try { LocalMessage message = (LocalMessage) m; diff --git a/src/com/fsck/k9/mail/Address.java b/src/com/fsck/k9/mail/Address.java index 44dcf7f9e..ed9914d5d 100644 --- a/src/com/fsck/k9/mail/Address.java +++ b/src/com/fsck/k9/mail/Address.java @@ -1,9 +1,6 @@ package com.fsck.k9.mail; -import android.database.Cursor; -import android.graphics.Color; -import android.text.Html; import android.text.Spannable; import android.text.SpannableString; import android.text.SpannableStringBuilder; @@ -23,27 +20,27 @@ import org.apache.james.mime4j.field.address.NamedMailbox; import org.apache.james.mime4j.field.address.parser.ParseException; import java.util.ArrayList; -import java.util.Collections; -import java.util.HashMap; import java.util.List; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; public class Address { + /** + * If the number of addresses exceeds this value the addresses aren't + * resolved to the names of Android contacts. + * + *
+ * TODO: This number was chosen arbitrarily and should be determined by + * performance tests. + *
+ * + * @see Address#toFriendly(Address[], Contacts) + */ + private static final int TOO_MANY_ADDRESSES = 50; /** * Immutable empty {@link Address} array */ private static final Address[] EMPTY_ADDRESS_ARRAY = new Address[0]; - private static Map