1
0
mirror of https://github.com/moparisthebest/k-9 synced 2025-01-11 21:58:35 -05:00

Merge pull request #10 from k9mail/art/more-tidying-arrays

Replace many arrays with collections
This commit is contained in:
cketti 2014-11-11 19:45:35 +01:00
commit 7211080415
34 changed files with 381 additions and 385 deletions

View File

@ -338,7 +338,7 @@ public class Account implements BaseAccount {
* Pick a nice Android guidelines color if we haven't used them all yet. * Pick a nice Android guidelines color if we haven't used them all yet.
*/ */
private int pickColor(Context context) { private int pickColor(Context context) {
Account[] accounts = Preferences.getPreferences(context).getAccounts(); List<Account> accounts = Preferences.getPreferences(context).getAccounts();
List<Integer> availableColors = new ArrayList<Integer>(PREDEFINED_COLORS.length); List<Integer> availableColors = new ArrayList<Integer>(PREDEFINED_COLORS.length);
Collections.addAll(availableColors, PREDEFINED_COLORS); Collections.addAll(availableColors, PREDEFINED_COLORS);
@ -620,8 +620,8 @@ public class Account implements BaseAccount {
} }
public static List<Integer> getExistingAccountNumbers(Preferences preferences) { public static List<Integer> getExistingAccountNumbers(Preferences preferences) {
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
List<Integer> accountNumbers = new ArrayList<Integer>(accounts.length); List<Integer> accountNumbers = new ArrayList<Integer>(accounts.size());
for (Account a : accounts) { for (Account a : accounts) {
accountNumbers.add(a.getAccountNumber()); accountNumbers.add(a.getAccountNumber());
} }
@ -679,10 +679,10 @@ public class Account implements BaseAccount {
* *
* I bet there is a much smarter way to do this. Anyone like to suggest it? * I bet there is a much smarter way to do this. Anyone like to suggest it?
*/ */
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
int[] accountNumbers = new int[accounts.length]; int[] accountNumbers = new int[accounts.size()];
for (int i = 0; i < accounts.length; i++) { for (int i = 0; i < accounts.size(); i++) {
accountNumbers[i] = accounts[i].getAccountNumber(); accountNumbers[i] = accounts.get(i).getAccountNumber();
} }
Arrays.sort(accountNumbers); Arrays.sort(accountNumbers);
for (int accountNumber : accountNumbers) { for (int accountNumber : accountNumbers) {

View File

@ -3,6 +3,7 @@ package com.fsck.k9;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@ -18,11 +19,6 @@ import com.fsck.k9.preferences.Storage;
public class Preferences { public class Preferences {
/**
* Immutable empty {@link Account} array
*/
private static final Account[] EMPTY_ACCOUNT_ARRAY = new Account[0];
private static Preferences preferences; private static Preferences preferences;
public static synchronized Preferences getPreferences(Context context) { public static synchronized Preferences getPreferences(Context context) {
@ -43,7 +39,7 @@ public class Preferences {
private Preferences(Context context) { private Preferences(Context context) {
mStorage = Storage.getStorage(context); mStorage = Storage.getStorage(context);
mContext = context; mContext = context;
if (mStorage.size() == 0) { if (mStorage.isEmpty()) {
Log.i(K9.LOG_TAG, "Preferences storage is zero-size, importing from Android-style preferences"); Log.i(K9.LOG_TAG, "Preferences storage is zero-size, importing from Android-style preferences");
Editor editor = mStorage.edit(); Editor editor = mStorage.edit();
editor.copy(context.getSharedPreferences("AndroidMail.Main", Context.MODE_PRIVATE)); editor.copy(context.getSharedPreferences("AndroidMail.Main", Context.MODE_PRIVATE));
@ -75,12 +71,12 @@ public class Preferences {
* registered the method returns an empty array. * registered the method returns an empty array.
* @return all accounts * @return all accounts
*/ */
public synchronized Account[] getAccounts() { public synchronized List<Account> getAccounts() {
if (accounts == null) { if (accounts == null) {
loadAccounts(); loadAccounts();
} }
return accountsInOrder.toArray(EMPTY_ACCOUNT_ARRAY); return Collections.unmodifiableList(accountsInOrder);
} }
/** /**
@ -89,7 +85,7 @@ public class Preferences {
* @return all accounts with {@link Account#isAvailable(Context)} * @return all accounts with {@link Account#isAvailable(Context)}
*/ */
public synchronized Collection<Account> getAvailableAccounts() { public synchronized Collection<Account> getAvailableAccounts() {
Account[] allAccounts = getAccounts(); List<Account> allAccounts = getAccounts();
Collection<Account> retval = new ArrayList<Account>(accounts.size()); Collection<Account> retval = new ArrayList<Account>(accounts.size());
for (Account account : allAccounts) { for (Account account : allAccounts) {
if (account.isEnabled() && account.isAvailable(mContext)) { if (account.isEnabled() && account.isAvailable(mContext)) {

View File

@ -68,7 +68,7 @@ public abstract class AccountList extends K9ListActivity implements OnItemClickL
* @param realAccounts * @param realAccounts
* An array of accounts to display. * An array of accounts to display.
*/ */
public void populateListView(Account[] realAccounts) { public void populateListView(List<Account> realAccounts) {
List<BaseAccount> accounts = new ArrayList<BaseAccount>(); List<BaseAccount> accounts = new ArrayList<BaseAccount>();
if (displaySpecialAccounts() && !K9.isHideSpecialAccounts()) { if (displaySpecialAccounts() && !K9.isHideSpecialAccounts()) {
@ -79,7 +79,7 @@ public abstract class AccountList extends K9ListActivity implements OnItemClickL
accounts.add(allMessagesAccount); accounts.add(allMessagesAccount);
} }
accounts.addAll(Arrays.asList(realAccounts)); accounts.addAll(realAccounts);
AccountsAdapter adapter = new AccountsAdapter(accounts); AccountsAdapter adapter = new AccountsAdapter(accounts);
ListView listView = getListView(); ListView listView = getListView();
listView.setAdapter(adapter); listView.setAdapter(adapter);
@ -169,15 +169,15 @@ public abstract class AccountList extends K9ListActivity implements OnItemClickL
/** /**
* Load accounts in a background thread * Load accounts in a background thread
*/ */
class LoadAccounts extends AsyncTask<Void, Void, Account[]> { class LoadAccounts extends AsyncTask<Void, Void, List<Account>> {
@Override @Override
protected Account[] doInBackground(Void... params) { protected List<Account> doInBackground(Void... params) {
Account[] accounts = Preferences.getPreferences(getApplicationContext()).getAccounts(); List<Account> accounts = Preferences.getPreferences(getApplicationContext()).getAccounts();
return accounts; return accounts;
} }
@Override @Override
protected void onPostExecute(Account[] accounts) { protected void onPostExecute(List<Account> accounts) {
populateListView(accounts); populateListView(accounts);
} }
} }

View File

@ -102,11 +102,6 @@ import de.cketti.library.changelog.ChangeLog;
public class Accounts extends K9ListActivity implements OnItemClickListener { public class Accounts extends K9ListActivity implements OnItemClickListener {
/**
* Immutable empty {@link BaseAccount} array
*/
private static final BaseAccount[] EMPTY_BASE_ACCOUNT_ARRAY = new BaseAccount[0];
/** /**
* URL used to open Android Market application * URL used to open Android Market application
*/ */
@ -400,14 +395,14 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
createSpecialAccounts(); createSpecialAccounts();
} }
Account[] accounts = Preferences.getPreferences(this).getAccounts(); List<Account> accounts = Preferences.getPreferences(this).getAccounts();
Intent intent = getIntent(); Intent intent = getIntent();
//onNewIntent(intent); //onNewIntent(intent);
// see if we should show the welcome message // see if we should show the welcome message
if (ACTION_IMPORT_SETTINGS.equals(intent.getAction())) { if (ACTION_IMPORT_SETTINGS.equals(intent.getAction())) {
onImport(); onImport();
} else if (accounts.length < 1) { } else if (accounts.size() < 1) {
WelcomeMessage.showWelcomeMessage(this); WelcomeMessage.showWelcomeMessage(this);
finish(); finish();
return; return;
@ -423,7 +418,7 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
onOpenAccount(mUnifiedInboxAccount); onOpenAccount(mUnifiedInboxAccount);
finish(); finish();
return; return;
} else if (startup && accounts.length == 1 && onOpenAccount(accounts[0])) { } else if (startup && accounts.size() == 1 && onOpenAccount(accounts.get(0))) {
finish(); finish();
return; return;
} }
@ -543,18 +538,18 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
return retain; return retain;
} }
private BaseAccount[] accounts = new BaseAccount[0]; private List<BaseAccount> accounts = new ArrayList<BaseAccount>();
private enum ACCOUNT_LOCATION { private enum ACCOUNT_LOCATION {
TOP, MIDDLE, BOTTOM; TOP, MIDDLE, BOTTOM;
} }
private EnumSet<ACCOUNT_LOCATION> accountLocation(BaseAccount account) { private EnumSet<ACCOUNT_LOCATION> accountLocation(BaseAccount account) {
EnumSet<ACCOUNT_LOCATION> accountLocation = EnumSet.of(ACCOUNT_LOCATION.MIDDLE); EnumSet<ACCOUNT_LOCATION> accountLocation = EnumSet.of(ACCOUNT_LOCATION.MIDDLE);
if (accounts.length > 0) { if (accounts.size() > 0) {
if (accounts[0].equals(account)) { if (accounts.get(0).equals(account)) {
accountLocation.remove(ACCOUNT_LOCATION.MIDDLE); accountLocation.remove(ACCOUNT_LOCATION.MIDDLE);
accountLocation.add(ACCOUNT_LOCATION.TOP); accountLocation.add(ACCOUNT_LOCATION.TOP);
} }
if (accounts[accounts.length - 1].equals(account)) { if (accounts.get(accounts.size() - 1).equals(account)) {
accountLocation.remove(ACCOUNT_LOCATION.MIDDLE); accountLocation.remove(ACCOUNT_LOCATION.MIDDLE);
accountLocation.add(ACCOUNT_LOCATION.BOTTOM); accountLocation.add(ACCOUNT_LOCATION.BOTTOM);
} }
@ -564,7 +559,8 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
private void refresh() { private void refresh() {
accounts = Preferences.getPreferences(this).getAccounts(); accounts.clear();
accounts.addAll(Preferences.getPreferences(this).getAccounts());
// see if we should show the welcome message // see if we should show the welcome message
// if (accounts.length < 1) { // if (accounts.length < 1) {
@ -573,22 +569,22 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
// } // }
List<BaseAccount> newAccounts; List<BaseAccount> newAccounts;
if (!K9.isHideSpecialAccounts() && accounts.length > 0) { if (!K9.isHideSpecialAccounts() && accounts.size() > 0) {
if (mUnifiedInboxAccount == null || mAllMessagesAccount == null) { if (mUnifiedInboxAccount == null || mAllMessagesAccount == null) {
createSpecialAccounts(); createSpecialAccounts();
} }
newAccounts = new ArrayList<BaseAccount>(accounts.length + newAccounts = new ArrayList<BaseAccount>(accounts.size() +
SPECIAL_ACCOUNTS_COUNT); SPECIAL_ACCOUNTS_COUNT);
newAccounts.add(mUnifiedInboxAccount); newAccounts.add(mUnifiedInboxAccount);
newAccounts.add(mAllMessagesAccount); newAccounts.add(mAllMessagesAccount);
} else { } else {
newAccounts = new ArrayList<BaseAccount>(accounts.length); newAccounts = new ArrayList<BaseAccount>(accounts.size());
} }
newAccounts.addAll(Arrays.asList(accounts)); newAccounts.addAll(accounts);
mAdapter = new AccountsAdapter(newAccounts.toArray(EMPTY_BASE_ACCOUNT_ARRAY)); mAdapter = new AccountsAdapter(newAccounts);
getListView().setAdapter(mAdapter); getListView().setAdapter(mAdapter);
if (!newAccounts.isEmpty()) { if (!newAccounts.isEmpty()) {
mHandler.progress(Window.PROGRESS_START); mHandler.progress(Window.PROGRESS_START);
@ -1737,7 +1733,7 @@ public class Accounts extends K9ListActivity implements OnItemClickListener {
} }
class AccountsAdapter extends ArrayAdapter<BaseAccount> { class AccountsAdapter extends ArrayAdapter<BaseAccount> {
public AccountsAdapter(BaseAccount[] accounts) { public AccountsAdapter(List<BaseAccount> accounts) {
super(Accounts.this, 0, accounts); super(Accounts.this, 0, accounts);
} }

View File

@ -261,7 +261,7 @@ public class ChooseFolder extends K9ListActivity {
mHandler.progress(false); mHandler.progress(false);
} }
@Override @Override
public void listFolders(Account account, Folder[] folders) { public void listFolders(Account account, List<? extends Folder> folders) {
if (!account.equals(mAccount)) { if (!account.equals(mAccount)) {
return; return;
} }

View File

@ -740,7 +740,7 @@ public class FolderList extends K9ListActivity {
} }
@Override @Override
public void listFolders(Account account, Folder[] folders) { public void listFolders(Account account, List<? extends Folder> folders) {
if (account.equals(mAccount)) { if (account.equals(mAccount)) {
List<FolderInfoHolder> newFolders = new LinkedList<FolderInfoHolder>(); List<FolderInfoHolder> newFolders = new LinkedList<FolderInfoHolder>();

View File

@ -9,6 +9,7 @@ import java.nio.charset.Charset;
import java.text.DateFormat; import java.text.DateFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.Date; import java.util.Date;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
@ -191,8 +192,6 @@ public class MessageCompose extends K9Activity implements OnClickListener,
private static final int CONTACT_PICKER_CC2 = 8; private static final int CONTACT_PICKER_CC2 = 8;
private static final int CONTACT_PICKER_BCC2 = 9; private static final int CONTACT_PICKER_BCC2 = 9;
private static final Account[] EMPTY_ACCOUNT_ARRAY = new Account[0];
private static final int REQUEST_CODE_SIGN_ENCRYPT = 12; private static final int REQUEST_CODE_SIGN_ENCRYPT = 12;
/** /**
@ -1057,7 +1056,7 @@ public class MessageCompose extends K9Activity implements OnClickListener,
} }
private boolean addRecipients(TextView view, List<String> recipients) { private boolean addRecipients(TextView view, List<String> recipients) {
if (recipients == null || recipients.size() == 0) { if (recipients == null || recipients.isEmpty()) {
return false; return false;
} }
@ -3916,7 +3915,7 @@ public class MessageCompose extends K9Activity implements OnClickListener,
List<Object> items = new ArrayList<Object>(); List<Object> items = new ArrayList<Object>();
Preferences prefs = Preferences.getPreferences(context.getApplicationContext()); Preferences prefs = Preferences.getPreferences(context.getApplicationContext());
Account[] accounts = prefs.getAvailableAccounts().toArray(EMPTY_ACCOUNT_ARRAY); Collection<Account> accounts = prefs.getAvailableAccounts();
for (Account account : accounts) { for (Account account : accounts) {
items.add(account); items.add(account);
List<Identity> identities = account.getIdentities(); List<Identity> identities = account.getIdentities();

View File

@ -451,10 +451,10 @@ public class MessageList extends K9FragmentActivity implements MessageListFragme
String[] accountUuids = mSearch.getAccountUuids(); String[] accountUuids = mSearch.getAccountUuids();
if (mSearch.searchAllAccounts()) { if (mSearch.searchAllAccounts()) {
Account[] accounts = prefs.getAccounts(); List<Account> accounts = prefs.getAccounts();
mSingleAccountMode = (accounts.length == 1); mSingleAccountMode = (accounts.size() == 1);
if (mSingleAccountMode) { if (mSingleAccountMode) {
mAccount = accounts[0]; mAccount = accounts.get(0);
} }
} else { } else {
mSingleAccountMode = (accountUuids.length == 1); mSingleAccountMode = (accountUuids.length == 1);

View File

@ -101,7 +101,7 @@ public class EmailProviderCache {
Map<String, String> map = mMessageCache.get(messageId); Map<String, String> map = mMessageCache.get(messageId);
if (map != null) { if (map != null) {
map.remove(columnName); map.remove(columnName);
if (map.size() == 0) { if (map.isEmpty()) {
mMessageCache.remove(messageId); mMessageCache.remove(messageId);
} }
} }
@ -115,7 +115,7 @@ public class EmailProviderCache {
Map<String, String> map = mThreadCache.get(threadRootId); Map<String, String> map = mThreadCache.get(threadRootId);
if (map != null) { if (map != null) {
map.remove(columnName); map.remove(columnName);
if (map.size() == 0) { if (map.isEmpty()) {
mThreadCache.remove(threadRootId); mThreadCache.remove(threadRootId);
} }
} }
@ -143,7 +143,7 @@ public class EmailProviderCache {
} }
} }
public void unhideMessages(Message[] messages) { public void unhideMessages(List<? extends Message> messages) {
synchronized (mHiddenMessageCache) { synchronized (mHiddenMessageCache) {
for (Message message : messages) { for (Message message : messages) {
LocalMessage localMessage = (LocalMessage) message; LocalMessage localMessage = (LocalMessage) message;

View File

@ -108,7 +108,7 @@ public class EmailProviderCacheCursor extends CursorWrapper {
@Override @Override
public boolean moveToPosition(int position) { public boolean moveToPosition(int position) {
if (mHiddenRows.size() == 0) { if (mHiddenRows.isEmpty()) {
return super.moveToPosition(position); return super.moveToPosition(position);
} }
@ -126,7 +126,7 @@ public class EmailProviderCacheCursor extends CursorWrapper {
@Override @Override
public int getPosition() { public int getPosition() {
if (mHiddenRows.size() == 0) { if (mHiddenRows.isEmpty()) {
return super.getPosition(); return super.getPosition();
} }

View File

@ -8,6 +8,7 @@ import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.Date; import java.util.Date;
import java.util.EnumSet;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.Iterator; import java.util.Iterator;
@ -116,16 +117,6 @@ public class MessagingController implements Runnable {
*/ */
private static final String[] EMPTY_STRING_ARRAY = new String[0]; private static final String[] EMPTY_STRING_ARRAY = new String[0];
/**
* Immutable empty {@link Message} array
*/
private static final Message[] EMPTY_MESSAGE_ARRAY = new Message[0];
/**
* Immutable empty {@link Folder} array
*/
private static final Folder[] EMPTY_FOLDER_ARRAY = new Folder[0];
/** /**
* The maximum message size that we'll consider to be "small". A small message is downloaded * The maximum message size that we'll consider to be "small". A small message is downloaded
* in full immediately instead of in pieces. Anything over this size will be downloaded in * in full immediately instead of in pieces. Anything over this size will be downloaded in
@ -321,8 +312,7 @@ public class MessagingController implements Runnable {
// Key is accountNumber // Key is accountNumber
private final ConcurrentMap<Integer, NotificationData> notificationData = new ConcurrentHashMap<Integer, NotificationData>(); private final ConcurrentMap<Integer, NotificationData> notificationData = new ConcurrentHashMap<Integer, NotificationData>();
private static final Flag[] SYNC_FLAGS = new Flag[] { Flag.SEEN, Flag.FLAGGED, Flag.ANSWERED, Flag.FORWARDED }; private static final Set<Flag> SYNC_FLAGS = EnumSet.of(Flag.SEEN, Flag.FLAGGED, Flag.ANSWERED, Flag.FORWARDED);
private void suppressMessages(Account account, List<Message> messages) { private void suppressMessages(Account account, List<Message> messages) {
EmailProviderCache cache = EmailProviderCache.getCache(account.getUuid(), EmailProviderCache cache = EmailProviderCache.getCache(account.getUuid(),
@ -330,7 +320,7 @@ public class MessagingController implements Runnable {
cache.hideMessages(messages); cache.hideMessages(messages);
} }
private void unsuppressMessages(Account account, Message[] messages) { private void unsuppressMessages(Account account, List<? extends Message> messages) {
EmailProviderCache cache = EmailProviderCache.getCache(account.getUuid(), EmailProviderCache cache = EmailProviderCache.getCache(account.getUuid(),
mApplication.getApplicationContext()); mApplication.getApplicationContext());
cache.unhideMessages(messages); cache.unhideMessages(messages);
@ -574,15 +564,13 @@ public class MessagingController implements Runnable {
Store localStore = account.getLocalStore(); Store localStore = account.getLocalStore();
localFolders = localStore.getPersonalNamespaces(false); localFolders = localStore.getPersonalNamespaces(false);
Folder[] folderArray = localFolders.toArray(EMPTY_FOLDER_ARRAY);
if (refreshRemote || localFolders.isEmpty()) { if (refreshRemote || localFolders.isEmpty()) {
doRefreshRemote(account, listener); doRefreshRemote(account, listener);
return; return;
} }
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
l.listFolders(account, folderArray); l.listFolders(account, localFolders);
} }
} catch (Exception e) { } catch (Exception e) {
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
@ -654,10 +642,9 @@ public class MessagingController implements Runnable {
} }
localFolders = localStore.getPersonalNamespaces(false); localFolders = localStore.getPersonalNamespaces(false);
Folder[] folderArray = localFolders.toArray(EMPTY_FOLDER_ARRAY);
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
l.listFolders(account, folderArray); l.listFolders(account, localFolders);
} }
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
l.listFoldersFinished(account); l.listFoldersFinished(account);
@ -694,7 +681,7 @@ public class MessagingController implements Runnable {
public void searchLocalMessagesSynchronous(final LocalSearch search, final MessagingListener listener) { public void searchLocalMessagesSynchronous(final LocalSearch search, final MessagingListener listener) {
final AccountStats stats = new AccountStats(); final AccountStats stats = new AccountStats();
final Set<String> uuidSet = new HashSet<String>(Arrays.asList(search.getAccountUuids())); final Set<String> uuidSet = new HashSet<String>(Arrays.asList(search.getAccountUuids()));
Account[] accounts = Preferences.getPreferences(mApplication.getApplicationContext()).getAccounts(); List<Account> accounts = Preferences.getPreferences(mApplication.getApplicationContext()).getAccounts();
boolean allAccounts = uuidSet.contains(SearchSpecification.ALL_ACCOUNTS); boolean allAccounts = uuidSet.contains(SearchSpecification.ALL_ACCOUNTS);
// for every account we want to search do the query in the localstore // for every account we want to search do the query in the localstore
@ -755,7 +742,7 @@ public class MessagingController implements Runnable {
public Future<?> searchRemoteMessages(final String acctUuid, final String folderName, final String query, public Future<?> searchRemoteMessages(final String acctUuid, final String folderName, final String query,
final Flag[] requiredFlags, final Flag[] forbiddenFlags, final MessagingListener listener) { final Set<Flag> requiredFlags, final Set<Flag> forbiddenFlags, final MessagingListener listener) {
if (K9.DEBUG) { if (K9.DEBUG) {
String msg = "searchRemoteMessages (" String msg = "searchRemoteMessages ("
+ "acct=" + acctUuid + "acct=" + acctUuid
@ -773,7 +760,7 @@ public class MessagingController implements Runnable {
}); });
} }
public void searchRemoteMessagesSynchronous(final String acctUuid, final String folderName, final String query, public void searchRemoteMessagesSynchronous(final String acctUuid, final String folderName, final String query,
final Flag[] requiredFlags, final Flag[] forbiddenFlags, final MessagingListener listener) { final Set<Flag> requiredFlags, final Set<Flag> forbiddenFlags, final MessagingListener listener) {
final Account acct = Preferences.getPreferences(mApplication.getApplicationContext()).getAccount(acctUuid); final Account acct = Preferences.getPreferences(mApplication.getApplicationContext()).getAccount(acctUuid);
if (listener != null) { if (listener != null) {
@ -885,10 +872,10 @@ public class MessagingController implements Runnable {
LocalMessage localMsg = localFolder.getMessage(message.getUid()); LocalMessage localMsg = localFolder.getMessage(message.getUid());
if (localMsg == null) { if (localMsg == null) {
remoteFolder.fetch(new Message [] {message}, header, null); remoteFolder.fetch(Collections.singletonList(message), header, null);
//fun fact: ImapFolder.fetch can't handle getting STRUCTURE at same time as headers //fun fact: ImapFolder.fetch can't handle getting STRUCTURE at same time as headers
remoteFolder.fetch(new Message [] {message}, structure, null); remoteFolder.fetch(Collections.singletonList(message), structure, null);
localFolder.appendMessages(new Message [] {message}); localFolder.appendMessages(Collections.singletonList(message));
localMsg = localFolder.getMessage(message.getUid()); localMsg = localFolder.getMessage(message.getUid());
} }
@ -992,7 +979,7 @@ public class MessagingController implements Runnable {
final LocalFolder localFolder = tLocalFolder; final LocalFolder localFolder = tLocalFolder;
localFolder.open(Folder.OPEN_MODE_RW); localFolder.open(Folder.OPEN_MODE_RW);
localFolder.updateLastUid(); localFolder.updateLastUid();
Message[] localMessages = localFolder.getMessages(null); List<? extends Message> localMessages = localFolder.getMessages(null);
Map<String, Message> localUidMap = new HashMap<String, Message>(); Map<String, Message> localUidMap = new HashMap<String, Message>();
for (Message message : localMessages) { for (Message message : localMessages) {
localUidMap.put(message.getUid(), message); localUidMap.put(message.getUid(), message);
@ -1058,7 +1045,6 @@ public class MessagingController implements Runnable {
visibleLimit = K9.DEFAULT_VISIBLE_LIMIT; visibleLimit = K9.DEFAULT_VISIBLE_LIMIT;
} }
Message[] remoteMessageArray = EMPTY_MESSAGE_ARRAY;
final List<Message> remoteMessages = new ArrayList<Message>(); final List<Message> remoteMessages = new ArrayList<Message>();
Map<String, Message> remoteUidMap = new HashMap<String, Message>(); Map<String, Message> remoteUidMap = new HashMap<String, Message>();
@ -1086,9 +1072,9 @@ public class MessagingController implements Runnable {
} }
remoteMessageArray = remoteFolder.getMessages(remoteStart, remoteEnd, earliestDate, null); List<? extends Message> remoteMessageArray = remoteFolder.getMessages(remoteStart, remoteEnd, earliestDate, null);
int messageCount = remoteMessageArray.length; int messageCount = remoteMessageArray.size();
for (Message thisMess : remoteMessageArray) { for (Message thisMess : remoteMessageArray) {
headerProgress.incrementAndGet(); headerProgress.incrementAndGet();
@ -1104,7 +1090,6 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.v(K9.LOG_TAG, "SYNC: Got " + remoteUidMap.size() + " messages for folder " + folder); Log.v(K9.LOG_TAG, "SYNC: Got " + remoteUidMap.size() + " messages for folder " + folder);
remoteMessageArray = null;
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
l.synchronizeMailboxHeadersFinished(account, folder, headerProgress.get(), remoteUidMap.size()); l.synchronizeMailboxHeadersFinished(account, folder, headerProgress.get(), remoteUidMap.size());
} }
@ -1125,7 +1110,7 @@ public class MessagingController implements Runnable {
} }
localFolder.destroyMessages(destroyMessages.toArray(EMPTY_MESSAGE_ARRAY)); localFolder.destroyMessages(destroyMessages);
for (Message destroyMessage : destroyMessages) { for (Message destroyMessage : destroyMessages) {
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
@ -1437,7 +1422,7 @@ public class MessagingController implements Runnable {
Log.v(K9.LOG_TAG, "Message with uid " + message.getUid() + " is partially or fully downloaded"); Log.v(K9.LOG_TAG, "Message with uid " + message.getUid() + " is partially or fully downloaded");
// Store the updated message locally // Store the updated message locally
localFolder.appendMessages(new Message[] { message }); localFolder.appendMessages(Collections.singletonList(message));
localMessage = localFolder.getMessage(message.getUid()); localMessage = localFolder.getMessage(message.getUid());
@ -1489,7 +1474,7 @@ public class MessagingController implements Runnable {
*/ */
final List<Message> chunk = new ArrayList<Message>(UNSYNC_CHUNK_SIZE); final List<Message> chunk = new ArrayList<Message>(UNSYNC_CHUNK_SIZE);
remoteFolder.fetch(unsyncedMessages.toArray(EMPTY_MESSAGE_ARRAY), fp, remoteFolder.fetch(unsyncedMessages, fp,
new MessageRetrievalListener() { new MessageRetrievalListener() {
@Override @Override
public void messageFinished(Message message, int number, int ofTotal) { public void messageFinished(Message message, int number, int ofTotal) {
@ -1578,7 +1563,7 @@ public class MessagingController implements Runnable {
} }
try { try {
// Store the new message locally // Store the new message locally
localFolder.appendMessages(messages.toArray(new Message[messages.size()])); localFolder.appendMessages(messages);
for (final Message message : messages) { for (final Message message : messages) {
final Message localMessage = localFolder.getMessage(message.getUid()); final Message localMessage = localFolder.getMessage(message.getUid());
@ -1624,7 +1609,7 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.d(K9.LOG_TAG, "SYNC: Fetching small messages for folder " + folder); Log.d(K9.LOG_TAG, "SYNC: Fetching small messages for folder " + folder);
remoteFolder.fetch(smallMessages.toArray(new Message[smallMessages.size()]), remoteFolder.fetch(smallMessages,
fp, new MessageRetrievalListener() { fp, new MessageRetrievalListener() {
@Override @Override
public void messageFinished(final Message message, int number, int ofTotal) { public void messageFinished(final Message message, int number, int ofTotal) {
@ -1703,7 +1688,7 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.d(K9.LOG_TAG, "SYNC: Fetching large messages for folder " + folder); Log.d(K9.LOG_TAG, "SYNC: Fetching large messages for folder " + folder);
remoteFolder.fetch(largeMessages.toArray(new Message[largeMessages.size()]), fp, null); remoteFolder.fetch(largeMessages, fp, null);
for (Message message : largeMessages) { for (Message message : largeMessages) {
if (!shouldImportMessage(account, folder, message, progress, earliestDate)) { if (!shouldImportMessage(account, folder, message, progress, earliestDate)) {
@ -1726,10 +1711,10 @@ public class MessagingController implements Runnable {
* they equal we can mark this SYNCHRONIZED instead of PARTIALLY_SYNCHRONIZED * they equal we can mark this SYNCHRONIZED instead of PARTIALLY_SYNCHRONIZED
*/ */
remoteFolder.fetch(new Message[] { message }, fp, null); remoteFolder.fetch(Collections.singletonList(message), fp, null);
// Store the updated message locally // Store the updated message locally
localFolder.appendMessages(new Message[] { message }); localFolder.appendMessages(Collections.singletonList(message));
Message localMessage = localFolder.getMessage(message.getUid()); Message localMessage = localFolder.getMessage(message.getUid());
@ -1770,7 +1755,7 @@ public class MessagingController implements Runnable {
remoteFolder.fetchPart(message, part, null); remoteFolder.fetchPart(message, part, null);
} }
// Store the updated message locally // Store the updated message locally
localFolder.appendMessages(new Message[] { message }); localFolder.appendMessages(Collections.singletonList(message));
Message localMessage = localFolder.getMessage(message.getUid()); Message localMessage = localFolder.getMessage(message.getUid());
@ -1836,7 +1821,7 @@ public class MessagingController implements Runnable {
} }
} }
remoteFolder.fetch(undeletedMessages.toArray(EMPTY_MESSAGE_ARRAY), fp, null); remoteFolder.fetch(undeletedMessages, fp, null);
for (Message remoteMessage : syncFlagMessages) { for (Message remoteMessage : syncFlagMessages) {
Message localMessage = localFolder.getMessage(remoteMessage.getUid()); Message localMessage = localFolder.getMessage(remoteMessage.getUid());
boolean messageChanged = syncFlags(localMessage, remoteMessage); boolean messageChanged = syncFlags(localMessage, remoteMessage);
@ -2111,10 +2096,10 @@ public class MessagingController implements Runnable {
*/ */
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
localFolder.fetch(new Message[] { localMessage } , fp, null); localFolder.fetch(Collections.singletonList(localMessage) , fp, null);
String oldUid = localMessage.getUid(); String oldUid = localMessage.getUid();
localMessage.setFlag(Flag.X_REMOTE_COPY_STARTED, true); localMessage.setFlag(Flag.X_REMOTE_COPY_STARTED, true);
remoteFolder.appendMessages(new Message[] { localMessage }); remoteFolder.appendMessages(Collections.singletonList(localMessage));
localFolder.changeUid(localMessage); localFolder.changeUid(localMessage);
for (MessagingListener l : getListeners()) { for (MessagingListener l : getListeners()) {
@ -2129,7 +2114,7 @@ public class MessagingController implements Runnable {
*/ */
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.ENVELOPE); fp.add(FetchProfile.Item.ENVELOPE);
remoteFolder.fetch(new Message[] { remoteMessage }, fp, null); remoteFolder.fetch(Collections.singletonList(remoteMessage), fp, null);
Date localDate = localMessage.getInternalDate(); Date localDate = localMessage.getInternalDate();
Date remoteDate = remoteMessage.getInternalDate(); Date remoteDate = remoteMessage.getInternalDate();
if (remoteDate != null && remoteDate.compareTo(localDate) > 0) { if (remoteDate != null && remoteDate.compareTo(localDate) > 0) {
@ -2146,12 +2131,12 @@ public class MessagingController implements Runnable {
fp.clear(); fp.clear();
fp = new FetchProfile(); fp = new FetchProfile();
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
localFolder.fetch(new Message[] { localMessage }, fp, null); localFolder.fetch(Collections.singletonList(localMessage), fp, null);
String oldUid = localMessage.getUid(); String oldUid = localMessage.getUid();
localMessage.setFlag(Flag.X_REMOTE_COPY_STARTED, true); localMessage.setFlag(Flag.X_REMOTE_COPY_STARTED, true);
remoteFolder.appendMessages(new Message[] { localMessage }); remoteFolder.appendMessages(Collections.singletonList(localMessage));
localFolder.changeUid(localMessage); localFolder.changeUid(localMessage);
for (MessagingListener l : getListeners()) { for (MessagingListener l : getListeners()) {
l.messageUidChanged(account, folder, oldUid, localMessage.getUid()); l.messageUidChanged(account, folder, oldUid, localMessage.getUid());
@ -2325,14 +2310,14 @@ public class MessagingController implements Runnable {
if (K9.FOLDER_NONE.equals(destFolderName)) { if (K9.FOLDER_NONE.equals(destFolderName)) {
destFolderName = null; destFolderName = null;
} }
remoteSrcFolder.delete(messages.toArray(EMPTY_MESSAGE_ARRAY), destFolderName); remoteSrcFolder.delete(messages, destFolderName);
} else { } else {
remoteDestFolder = remoteStore.getFolder(destFolder); remoteDestFolder = remoteStore.getFolder(destFolder);
if (isCopy) { if (isCopy) {
remoteUidMap = remoteSrcFolder.copyMessages(messages.toArray(EMPTY_MESSAGE_ARRAY), remoteDestFolder); remoteUidMap = remoteSrcFolder.copyMessages(messages, remoteDestFolder);
} else { } else {
remoteUidMap = remoteSrcFolder.moveMessages(messages.toArray(EMPTY_MESSAGE_ARRAY), remoteDestFolder); remoteUidMap = remoteSrcFolder.moveMessages(messages, remoteDestFolder);
} }
} }
if (!isCopy && Account.EXPUNGE_IMMEDIATELY.equals(account.getExpungePolicy())) { if (!isCopy && Account.EXPUNGE_IMMEDIATELY.equals(account.getExpungePolicy())) {
@ -2425,7 +2410,7 @@ public class MessagingController implements Runnable {
if (messages.isEmpty()) { if (messages.isEmpty()) {
return; return;
} }
remoteFolder.setFlags(messages.toArray(EMPTY_MESSAGE_ARRAY), new Flag[] { flag }, newState); remoteFolder.setFlags(messages, Collections.singleton(flag), newState);
} finally { } finally {
closeFolder(remoteFolder); closeFolder(remoteFolder);
} }
@ -2571,9 +2556,9 @@ public class MessagingController implements Runnable {
} }
if (isCopy) { if (isCopy) {
remoteSrcFolder.copyMessages(new Message[] { remoteMessage }, remoteDestFolder); remoteSrcFolder.copyMessages(Collections.singletonList(remoteMessage), remoteDestFolder);
} else { } else {
remoteSrcFolder.moveMessages(new Message[] { remoteMessage }, remoteDestFolder); remoteSrcFolder.moveMessages(Collections.singletonList(remoteMessage), remoteDestFolder);
} }
remoteSrcFolder.close(); remoteSrcFolder.close();
remoteDestFolder.close(); remoteDestFolder.close();
@ -2587,7 +2572,7 @@ public class MessagingController implements Runnable {
Store localStore = account.getLocalStore(); Store localStore = account.getLocalStore();
localFolder = (LocalFolder) localStore.getFolder(folder); localFolder = (LocalFolder) localStore.getFolder(folder);
localFolder.open(Folder.OPEN_MODE_RW); localFolder.open(Folder.OPEN_MODE_RW);
Message[] messages = localFolder.getMessages(null, false); List<? extends Message> messages = localFolder.getMessages(null, false);
for (Message message : messages) { for (Message message : messages) {
if (!message.isSet(Flag.SEEN)) { if (!message.isSet(Flag.SEEN)) {
message.setFlag(Flag.SEEN, true); message.setFlag(Flag.SEEN, true);
@ -2617,7 +2602,7 @@ public class MessagingController implements Runnable {
return; return;
} }
remoteFolder.setFlags(new Flag[] {Flag.SEEN}, true); remoteFolder.setFlags(Collections.singleton(Flag.SEEN), true);
remoteFolder.close(); remoteFolder.close();
} catch (UnsupportedOperationException uoe) { } catch (UnsupportedOperationException uoe) {
Log.w(K9.LOG_TAG, "Could not mark all server-side as read because store doesn't support operation", uoe); Log.w(K9.LOG_TAG, "Could not mark all server-side as read because store doesn't support operation", uoe);
@ -2727,10 +2712,8 @@ public class MessagingController implements Runnable {
Store localStore = account.getLocalStore(); Store localStore = account.getLocalStore();
LocalFolder localFolder = (LocalFolder)localStore.getFolder(account.getErrorFolderName()); LocalFolder localFolder = (LocalFolder)localStore.getFolder(account.getErrorFolderName());
Message[] messages = new Message[1];
MimeMessage message = new MimeMessage(); MimeMessage message = new MimeMessage();
message.setBody(new TextBody(body)); message.setBody(new TextBody(body));
message.setFlag(Flag.X_DOWNLOADED_FULL, true); message.setFlag(Flag.X_DOWNLOADED_FULL, true);
message.setSubject(subject); message.setSubject(subject);
@ -2740,9 +2723,8 @@ public class MessagingController implements Runnable {
message.setInternalDate(nowDate); message.setInternalDate(nowDate);
message.addSentDate(nowDate); message.addSentDate(nowDate);
message.setFrom(new Address(account.getEmail(), "K9mail internal")); message.setFrom(new Address(account.getEmail(), "K9mail internal"));
messages[0] = message;
localFolder.appendMessages(messages); localFolder.appendMessages(Collections.singletonList(message));
localFolder.clearMessagesOlderThan(nowTime - (15 * 60 * 1000)); localFolder.clearMessagesOlderThan(nowTime - (15 * 60 * 1000));
@ -2874,7 +2856,7 @@ public class MessagingController implements Runnable {
* @param newState * @param newState
* {@code true}, if the flag should be set. {@code false} if it should be removed. * {@code true}, if the flag should be set. {@code false} if it should be removed.
*/ */
public void setFlag(Account account, String folderName, Message[] messages, Flag flag, public void setFlag(Account account, String folderName, List<Message> messages, Flag flag,
boolean newState) { boolean newState) {
// TODO: Put this into the background, but right now some callers depend on the message // TODO: Put this into the background, but right now some callers depend on the message
// objects being modified right after this method returns. // objects being modified right after this method returns.
@ -2896,7 +2878,7 @@ public class MessagingController implements Runnable {
} }
// Update the messages in the local store // Update the messages in the local store
localFolder.setFlags(messages, new Flag[] {flag}, newState); localFolder.setFlags(messages, Collections.singleton(flag), newState);
int unreadMessageCount = localFolder.getUnreadMessageCount(); int unreadMessageCount = localFolder.getUnreadMessageCount();
for (MessagingListener l : getListeners()) { for (MessagingListener l : getListeners()) {
@ -2914,9 +2896,9 @@ public class MessagingController implements Runnable {
return; return;
} }
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0, end = uids.length; i < end; i++) { for (int i = 0, end = uids.length; i < end; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
queueSetFlag(account, folderName, Boolean.toString(newState), flag.toString(), uids); queueSetFlag(account, folderName, Boolean.toString(newState), flag.toString(), uids);
@ -2953,7 +2935,7 @@ public class MessagingController implements Runnable {
Message message = localFolder.getMessage(uid); Message message = localFolder.getMessage(uid);
if (message != null) { if (message != null) {
setFlag(account, folderName, new Message[] { message }, flag, newState); setFlag(account, folderName, Collections.singletonList(message), flag, newState);
} }
} catch (MessagingException me) { } catch (MessagingException me) {
addErrorMessage(account, null, me); addErrorMessage(account, null, me);
@ -3026,7 +3008,7 @@ public class MessagingController implements Runnable {
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.ENVELOPE); fp.add(FetchProfile.Item.ENVELOPE);
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
localFolder.fetch(new Message[] { message }, fp, null); localFolder.fetch(Collections.singletonList(message), fp, null);
} else { } else {
/* /*
* At this point the message is not available, so we need to download it * At this point the message is not available, so we need to download it
@ -3042,16 +3024,16 @@ public class MessagingController implements Runnable {
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
remoteFolder.fetch(new Message[] { remoteMessage }, fp, null); remoteFolder.fetch(Collections.singletonList(remoteMessage), fp, null);
// Store the message locally and load the stored message into memory // Store the message locally and load the stored message into memory
localFolder.appendMessages(new Message[] { remoteMessage }); localFolder.appendMessages(Collections.singletonList(remoteMessage));
if (loadPartialFromSearch) { if (loadPartialFromSearch) {
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
} }
fp.add(FetchProfile.Item.ENVELOPE); fp.add(FetchProfile.Item.ENVELOPE);
message = localFolder.getMessage(uid); message = localFolder.getMessage(uid);
localFolder.fetch(new Message[] { message }, fp, null); localFolder.fetch(Collections.singletonList(message), fp, null);
// Mark that this message is now fully synched // Mark that this message is now fully synched
if (account.isMarkMessageAsReadOnView()) { if (account.isMarkMessageAsReadOnView()) {
@ -3124,9 +3106,7 @@ public class MessagingController implements Runnable {
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.ENVELOPE); fp.add(FetchProfile.Item.ENVELOPE);
fp.add(FetchProfile.Item.BODY); fp.add(FetchProfile.Item.BODY);
localFolder.fetch(new Message[] { localFolder.fetch(Collections.singletonList(message), fp, null);
message
}, fp, null);
localFolder.close(); localFolder.close();
for (MessagingListener l : getListeners(listener)) { for (MessagingListener l : getListeners(listener)) {
@ -3266,7 +3246,7 @@ public class MessagingController implements Runnable {
LocalStore localStore = account.getLocalStore(); LocalStore localStore = account.getLocalStore();
LocalFolder localFolder = localStore.getFolder(account.getOutboxFolderName()); LocalFolder localFolder = localStore.getFolder(account.getOutboxFolderName());
localFolder.open(Folder.OPEN_MODE_RW); localFolder.open(Folder.OPEN_MODE_RW);
localFolder.appendMessages(new Message[] { message }); localFolder.appendMessages(Collections.singletonList(message));
Message localMessage = localFolder.getMessage(message.getUid()); Message localMessage = localFolder.getMessage(message.getUid());
localMessage.setFlag(Flag.X_DOWNLOADED_FULL, true); localMessage.setFlag(Flag.X_DOWNLOADED_FULL, true);
localFolder.close(); localFolder.close();
@ -3504,9 +3484,9 @@ public class MessagingController implements Runnable {
} }
localFolder.open(Folder.OPEN_MODE_RW); localFolder.open(Folder.OPEN_MODE_RW);
Message[] localMessages = localFolder.getMessages(null); List<? extends Message> localMessages = localFolder.getMessages(null);
int progress = 0; int progress = 0;
int todo = localMessages.length; int todo = localMessages.size();
for (MessagingListener l : getListeners()) { for (MessagingListener l : getListeners()) {
l.synchronizeMailboxProgress(account, account.getSentFolderName(), progress, todo); l.synchronizeMailboxProgress(account, account.getSentFolderName(), progress, todo);
} }
@ -3545,7 +3525,7 @@ public class MessagingController implements Runnable {
localFolder.fetch(new Message[] { message }, fp, null); localFolder.fetch(Collections.singletonList(message), fp, null);
try { try {
@ -3576,7 +3556,7 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.i(K9.LOG_TAG, "Moving sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") "); Log.i(K9.LOG_TAG, "Moving sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
localFolder.moveMessages(new Message[] { message }, localSentFolder); localFolder.moveMessages(Collections.singletonList(message), localSentFolder);
if (K9.DEBUG) if (K9.DEBUG)
Log.i(K9.LOG_TAG, "Moved sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") "); Log.i(K9.LOG_TAG, "Moved sent message to folder '" + account.getSentFolderName() + "' (" + localSentFolder.getId() + ") ");
@ -3594,7 +3574,7 @@ public class MessagingController implements Runnable {
// This is a complete hack, but is worlds better than the previous // This is a complete hack, but is worlds better than the previous
// "don't even bother" functionality // "don't even bother" functionality
if (getRootCauseMessage(e).startsWith("5")) { if (getRootCauseMessage(e).startsWith("5")) {
localFolder.moveMessages(new Message[] { message }, (LocalFolder) localStore.getFolder(account.getDraftsFolderName())); localFolder.moveMessages(Collections.singletonList(message), (LocalFolder) localStore.getFolder(account.getDraftsFolderName()));
} }
notifyUserIfCertificateProblem(mApplication, e, account, false); notifyUserIfCertificateProblem(mApplication, e, account, false);
@ -3679,14 +3659,14 @@ public class MessagingController implements Runnable {
// Collect accounts that belong to the search // Collect accounts that belong to the search
String[] accountUuids = search.getAccountUuids(); String[] accountUuids = search.getAccountUuids();
Account[] accounts; List<Account> accounts;
if (search.searchAllAccounts()) { if (search.searchAllAccounts()) {
accounts = preferences.getAccounts(); accounts = preferences.getAccounts();
} else { } else {
accounts = new Account[accountUuids.length]; accounts = new ArrayList<Account>(accountUuids.length);
for (int i = 0, len = accountUuids.length; i < len; i++) { for (int i = 0, len = accountUuids.length; i < len; i++) {
String accountUuid = accountUuids[i]; String accountUuid = accountUuids[i];
accounts[i] = preferences.getAccount(accountUuid); accounts.set(i, preferences.getAccount(accountUuid));
} }
} }
@ -3895,8 +3875,8 @@ public class MessagingController implements Runnable {
} }
} }
Message[] messages = localSrcFolder.getMessages(uids.toArray(EMPTY_STRING_ARRAY), null); List<? extends Message> messages = localSrcFolder.getMessages(uids.toArray(EMPTY_STRING_ARRAY), null);
if (messages.length > 0) { if (messages.size() > 0) {
Map<String, Message> origUidMap = new HashMap<String, Message>(); Map<String, Message> origUidMap = new HashMap<String, Message>();
for (Message message : messages) { for (Message message : messages) {
@ -3905,7 +3885,7 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.i(K9.LOG_TAG, "moveOrCopyMessageSynchronous: source folder = " + srcFolder Log.i(K9.LOG_TAG, "moveOrCopyMessageSynchronous: source folder = " + srcFolder
+ ", " + messages.length + " messages, " + ", destination folder = " + destFolder + ", isCopy = " + isCopy); + ", " + messages.size() + " messages, " + ", destination folder = " + destFolder + ", isCopy = " + isCopy);
if (isCopy) { if (isCopy) {
FetchProfile fp = new FetchProfile(); FetchProfile fp = new FetchProfile();
@ -4014,7 +3994,7 @@ public class MessagingController implements Runnable {
List<Message> messagesToDelete = collectMessagesInThreads(account, messages); List<Message> messagesToDelete = collectMessagesInThreads(account, messages);
deleteMessagesSynchronous(account, folderName, deleteMessagesSynchronous(account, folderName,
messagesToDelete.toArray(EMPTY_MESSAGE_ARRAY), null); messagesToDelete, null);
} catch (MessagingException e) { } catch (MessagingException e) {
Log.e(K9.LOG_TAG, "Something went wrong while deleting threads", e); Log.e(K9.LOG_TAG, "Something went wrong while deleting threads", e);
} }
@ -4031,8 +4011,9 @@ public class MessagingController implements Runnable {
long rootId = localMessage.getRootId(); long rootId = localMessage.getRootId();
long threadId = (rootId == -1) ? localMessage.getThreadId() : rootId; long threadId = (rootId == -1) ? localMessage.getThreadId() : rootId;
Message[] messagesInThread = localStore.getMessagesInThread(threadId); List<? extends Message> messagesInThread = localStore.getMessagesInThread(threadId);
Collections.addAll(messagesInThreads, messagesInThread);
messagesInThreads.addAll(messagesInThread);
} }
return messagesInThreads; return messagesInThreads;
@ -4050,7 +4031,7 @@ public class MessagingController implements Runnable {
@Override @Override
public void run() { public void run() {
deleteMessagesSynchronous(account, folder.getName(), deleteMessagesSynchronous(account, folder.getName(),
accountMessages.toArray(EMPTY_MESSAGE_ARRAY), listener); accountMessages, listener);
} }
}); });
} }
@ -4059,7 +4040,7 @@ public class MessagingController implements Runnable {
} }
private void deleteMessagesSynchronous(final Account account, final String folder, final Message[] messages, private void deleteMessagesSynchronous(final Account account, final String folder, final List<? extends Message> messages,
MessagingListener listener) { MessagingListener listener) {
Folder localFolder = null; Folder localFolder = null;
Folder localTrashFolder = null; Folder localTrashFolder = null;
@ -4079,7 +4060,7 @@ public class MessagingController implements Runnable {
if (K9.DEBUG) if (K9.DEBUG)
Log.d(K9.LOG_TAG, "Deleting messages in trash folder or trash set to -None-, not copying"); Log.d(K9.LOG_TAG, "Deleting messages in trash folder or trash set to -None-, not copying");
localFolder.setFlags(messages, new Flag[] { Flag.DELETED }, true); localFolder.setFlags(messages, Collections.singleton(Flag.DELETED), true);
} else { } else {
localTrashFolder = localStore.getFolder(account.getTrashFolderName()); localTrashFolder = localStore.getFolder(account.getTrashFolderName());
if (!localTrashFolder.exists()) { if (!localTrashFolder.exists()) {
@ -4147,10 +4128,10 @@ public class MessagingController implements Runnable {
} }
} }
private String[] getUidsFromMessages(Message[] messages) { private String[] getUidsFromMessages(List <? extends Message> messages) {
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0; i < messages.length; i++) { for (int i = 0; i < messages.size(); i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
return uids; return uids;
} }
@ -4162,7 +4143,7 @@ public class MessagingController implements Runnable {
try { try {
if (remoteFolder.exists()) { if (remoteFolder.exists()) {
remoteFolder.open(Folder.OPEN_MODE_RW); remoteFolder.open(Folder.OPEN_MODE_RW);
remoteFolder.setFlags(new Flag [] { Flag.DELETED }, true); remoteFolder.setFlags(Collections.singleton(Flag.DELETED), true);
if (Account.EXPUNGE_IMMEDIATELY.equals(account.getExpungePolicy())) { if (Account.EXPUNGE_IMMEDIATELY.equals(account.getExpungePolicy())) {
remoteFolder.expunge(); remoteFolder.expunge();
} }
@ -4193,7 +4174,7 @@ public class MessagingController implements Runnable {
if (isTrashLocalOnly) { if (isTrashLocalOnly) {
localFolder.clearAllMessages(); localFolder.clearAllMessages();
} else { } else {
localFolder.setFlags(new Flag[] { Flag.DELETED }, true); localFolder.setFlags(Collections.singleton(Flag.DELETED), true);
} }
for (MessagingListener l : getListeners()) { for (MessagingListener l : getListeners()) {
@ -5030,7 +5011,7 @@ public class MessagingController implements Runnable {
} }
private boolean skipAccountsInBackStack(Context context) { private boolean skipAccountsInBackStack(Context context) {
return Preferences.getPreferences(context).getAccounts().length == 1; return Preferences.getPreferences(context).getAccounts().size() == 1;
} }
/** /**
@ -5112,9 +5093,7 @@ public class MessagingController implements Runnable {
} }
// Save the message to the store. // Save the message to the store.
localFolder.appendMessages(new Message[] { localFolder.appendMessages(Collections.singletonList(message));
message
});
// Fetch the message back from the store. This is the Message that's returned to the caller. // Fetch the message back from the store. This is the Message that's returned to the caller.
localMessage = localFolder.getMessage(message.getUid()); localMessage = localFolder.getMessage(message.getUid());
localMessage.setFlag(Flag.X_DOWNLOADED_FULL, true); localMessage.setFlag(Flag.X_DOWNLOADED_FULL, true);

View File

@ -33,7 +33,7 @@ public class MessagingListener {
public void listFoldersStarted(Account account) {} public void listFoldersStarted(Account account) {}
public void listFolders(Account account, Folder[] folders) {} public void listFolders(Account account, List<? extends Folder> folders) {}
public void listFoldersFinished(Account account) {} public void listFoldersFinished(Account account) {}

View File

@ -960,16 +960,16 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
accountUuids[0].equals(SearchSpecification.ALL_ACCOUNTS)) { accountUuids[0].equals(SearchSpecification.ALL_ACCOUNTS)) {
mAllAccounts = true; mAllAccounts = true;
Account[] accounts = mPreferences.getAccounts(); List<Account> accounts = mPreferences.getAccounts();
mAccountUuids = new String[accounts.length]; mAccountUuids = new String[accounts.size()];
for (int i = 0, len = accounts.length; i < len; i++) { for (int i = 0, len = accounts.size(); i < len; i++) {
mAccountUuids[i] = accounts[i].getUuid(); mAccountUuids[i] = accounts.get(i).getUuid();
} }
if (mAccountUuids.length == 1) { if (mAccountUuids.length == 1) {
mSingleAccountMode = true; mSingleAccountMode = true;
mAccount = accounts[0]; mAccount = accounts.get(0);
} }
} else { } else {
mAccountUuids = accountUuids; mAccountUuids = accountUuids;
@ -1084,11 +1084,11 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
mController.addListener(mListener); mController.addListener(mListener);
//Cancel pending new mail notifications when we open an account //Cancel pending new mail notifications when we open an account
Account[] accountsWithNotification; List<Account> accountsWithNotification;
Account account = mAccount; Account account = mAccount;
if (account != null) { if (account != null) {
accountsWithNotification = new Account[] { account }; accountsWithNotification = Collections.singletonList(account);
} else { } else {
accountsWithNotification = mPreferences.getAccounts(); accountsWithNotification = mPreferences.getAccounts();
} }
@ -1814,7 +1814,7 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
} }
List<String> folderNames = mSearch.getFolderNames(); List<String> folderNames = mSearch.getFolderNames();
return (folderNames.size() == 0 || folderNames.contains(folder)); return (folderNames.isEmpty() || folderNames.contains(folder));
} }
} }
@ -2362,7 +2362,7 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
} }
private void setFlagForSelected(final Flag flag, final boolean newState) { private void setFlagForSelected(final Flag flag, final boolean newState) {
if (mSelected.size() == 0) { if (mSelected.isEmpty()) {
return; return;
} }
@ -2586,7 +2586,7 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
private boolean checkCopyOrMovePossible(final List<Message> messages, private boolean checkCopyOrMovePossible(final List<Message> messages,
final FolderOperation operation) { final FolderOperation operation) {
if (messages.size() == 0) { if (messages.isEmpty()) {
return false; return false;
} }
@ -3515,7 +3515,7 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
} }
private void cleanupSelected(Cursor cursor) { private void cleanupSelected(Cursor cursor) {
if (mSelected.size() == 0) { if (mSelected.isEmpty()) {
return; return;
} }
@ -3534,7 +3534,7 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
* Starts or finishes the action mode when necessary. * Starts or finishes the action mode when necessary.
*/ */
private void resetActionMode() { private void resetActionMode() {
if (mSelected.size() == 0) { if (mSelected.isEmpty()) {
if (mActionMode != null) { if (mActionMode != null) {
mActionMode.finish(); mActionMode.finish();
} }

View File

@ -369,7 +369,7 @@ public class MessageViewFragment extends Fragment implements OnClickListener,
if (mMessage != null) { if (mMessage != null) {
boolean newState = !mMessage.isSet(Flag.FLAGGED); boolean newState = !mMessage.isSet(Flag.FLAGGED);
mController.setFlag(mAccount, mMessage.getFolder().getName(), mController.setFlag(mAccount, mMessage.getFolder().getName(),
new Message[] { mMessage }, Flag.FLAGGED, newState); Collections.singletonList(mMessage), Flag.FLAGGED, newState);
mMessageView.setHeaders(mMessage, mAccount); mMessageView.setHeaders(mMessage, mAccount);
} }
} }
@ -485,7 +485,7 @@ public class MessageViewFragment extends Fragment implements OnClickListener,
public void onToggleRead() { public void onToggleRead() {
if (mMessage != null) { if (mMessage != null) {
mController.setFlag(mAccount, mMessage.getFolder().getName(), mController.setFlag(mAccount, mMessage.getFolder().getName(),
new Message[] { mMessage }, Flag.SEEN, !mMessage.isSet(Flag.SEEN)); Collections.singletonList(mMessage), Flag.SEEN, !mMessage.isSet(Flag.SEEN));
mMessageView.setHeaders(mMessage, mAccount); mMessageView.setHeaders(mMessage, mAccount);
String subject = mMessage.getSubject(); String subject = mMessage.getSubject();
displayMessageSubject(subject); displayMessageSubject(subject);

View File

@ -302,7 +302,7 @@ public class Contacts {
} }
// Return 'null' if no email addresses have been found // Return 'null' if no email addresses have been found
if (email.size() == 0) { if (email.isEmpty()) {
return null; return null;
} }

View File

@ -105,6 +105,22 @@ public class Utility {
return TextUtils.join(String.valueOf(separator), parts); return TextUtils.join(String.valueOf(separator), parts);
} }
/**
* Combines the given Objects into a single String using
* each Object's toString() method and the separator character
* between each part.
*
* @param parts
* @param separator
* @return new String
*/
public static String combine(Iterable<?> parts, char separator) {
if (parts == null) {
return null;
}
return TextUtils.join(String.valueOf(separator), parts);
}
public static String base64Decode(String encoded) { public static String base64Decode(String encoded) {
if (encoded == null) { if (encoded == null) {
return null; return null;

View File

@ -1,8 +1,10 @@
package com.fsck.k9.mail; package com.fsck.k9.mail;
import java.util.Collection;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set;
import android.util.Log; import android.util.Log;
import com.fsck.k9.Account; import com.fsck.k9.Account;
@ -92,7 +94,7 @@ public abstract class Folder {
* @return List of messages * @return List of messages
* @throws MessagingException * @throws MessagingException
*/ */
public abstract Message[] getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) throws MessagingException; public abstract List<? extends Message> getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) throws MessagingException;
/** /**
* Fetches the given list of messages. The specified listener is notified as * Fetches the given list of messages. The specified listener is notified as
@ -102,36 +104,36 @@ public abstract class Folder {
* @param listener Listener to notify as we download messages. * @param listener Listener to notify as we download messages.
* @return List of messages * @return List of messages
*/ */
public abstract Message[] getMessages(MessageRetrievalListener listener) throws MessagingException; public abstract List<? extends Message> getMessages(MessageRetrievalListener listener) throws MessagingException;
public Message[] getMessages(MessageRetrievalListener listener, boolean includeDeleted) throws MessagingException { public List<? extends Message> getMessages(MessageRetrievalListener listener, boolean includeDeleted) throws MessagingException {
return getMessages(listener); return getMessages(listener);
} }
public abstract Message[] getMessages(String[] uids, MessageRetrievalListener listener) public abstract List<? extends Message> getMessages(String[] uids, MessageRetrievalListener listener)
throws MessagingException; throws MessagingException;
public abstract Map<String, String> appendMessages(Message[] messages) throws MessagingException; public abstract Map<String, String> appendMessages(List<? extends Message> messages) throws MessagingException;
public Map<String, String> copyMessages(Message[] msgs, Folder folder) throws MessagingException { public Map<String, String> copyMessages(List<? extends Message> msgs, Folder folder) throws MessagingException {
return null; return null;
} }
public Map<String, String> moveMessages(Message[] msgs, Folder folder) throws MessagingException { public Map<String, String> moveMessages(List<? extends Message> msgs, Folder folder) throws MessagingException {
return null; return null;
} }
public void delete(Message[] msgs, String trashFolderName) throws MessagingException { public void delete(List<? extends Message> msgs, String trashFolderName) throws MessagingException {
for (Message message : msgs) { for (Message message : msgs) {
Message myMessage = getMessage(message.getUid()); Message myMessage = getMessage(message.getUid());
myMessage.delete(trashFolderName); myMessage.delete(trashFolderName);
} }
} }
public abstract void setFlags(Message[] messages, Flag[] flags, boolean value) public abstract void setFlags(List<? extends Message> messages, Set<Flag> flags, boolean value)
throws MessagingException; throws MessagingException;
public abstract void setFlags(Flag[] flags, boolean value) throws MessagingException; public abstract void setFlags(Set<Flag> flags, boolean value) throws MessagingException;
public abstract String getUidFromMessageId(Message message) throws MessagingException; public abstract String getUidFromMessageId(Message message) throws MessagingException;
@ -146,7 +148,7 @@ public abstract class Folder {
* @param listener Listener to notify as we fetch messages. * @param listener Listener to notify as we fetch messages.
* @throws MessagingException * @throws MessagingException
*/ */
public abstract void fetch(Message[] messages, FetchProfile fp, public abstract void fetch(List<? extends Message> messages, FetchProfile fp,
MessageRetrievalListener listener) throws MessagingException; MessageRetrievalListener listener) throws MessagingException;
public void fetchPart(Message message, Part part, public void fetchPart(Message message, Part part,
@ -243,7 +245,7 @@ public abstract class Folder {
return mAccount; return mAccount;
} }
public List<Message> search(String queryString, final Flag[] requiredFlags, final Flag[] forbiddenFlags) public List<Message> search(String queryString, final Set<Flag> requiredFlags, final Set<Flag> forbiddenFlags)
throws MessagingException { throws MessagingException {
throw new MessagingException("K-9 does not support searches on this folder type"); throw new MessagingException("K-9 does not support searches on this folder type");
} }

View File

@ -2,7 +2,10 @@
package com.fsck.k9.mail; package com.fsck.k9.mail;
import java.io.IOException; import java.io.IOException;
import java.util.Collection;
import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.EnumSet;
import java.util.HashSet; import java.util.HashSet;
import java.util.Set; import java.util.Set;
@ -16,7 +19,6 @@ import com.fsck.k9.mail.store.UnavailableStorageException;
public abstract class Message implements Part, CompositeBody { public abstract class Message implements Part, CompositeBody {
private static final Flag[] EMPTY_FLAG_ARRAY = new Flag[0];
private MessageReference mReference = null; private MessageReference mReference = null;
@ -26,7 +28,7 @@ public abstract class Message implements Part, CompositeBody {
protected String mUid; protected String mUid;
private Set<Flag> mFlags = new HashSet<Flag>(); private Set<Flag> mFlags = EnumSet.noneOf(Flag.class);
private Date mInternalDate; private Date mInternalDate;
@ -208,8 +210,8 @@ public abstract class Message implements Part, CompositeBody {
/* /*
* TODO Refactor Flags at some point to be able to store user defined flags. * TODO Refactor Flags at some point to be able to store user defined flags.
*/ */
public Flag[] getFlags() { public Set<Flag> getFlags() {
return mFlags.toArray(EMPTY_FLAG_ARRAY); return Collections.unmodifiableSet(mFlags);
} }
/** /**
@ -233,7 +235,7 @@ public abstract class Message implements Part, CompositeBody {
* @param flags * @param flags
* @param set * @param set
*/ */
public void setFlags(Flag[] flags, boolean set) throws MessagingException { public void setFlags(final Set<Flag> flags, boolean set) throws MessagingException {
for (Flag flag : flags) { for (Flag flag : flags) {
setFlag(flag, set); setFlag(flag, set);
} }
@ -290,7 +292,7 @@ public abstract class Message implements Part, CompositeBody {
destination.mReference = mReference; destination.mReference = mReference;
// mFlags contents can change during the object lifetime, so copy the Set // mFlags contents can change during the object lifetime, so copy the Set
destination.mFlags = new HashSet<Flag>(mFlags); destination.mFlags = EnumSet.copyOf(mFlags);
} }
/** /**

View File

@ -244,7 +244,7 @@ public abstract class Store {
return true; return true;
} }
public void sendMessages(Message[] messages) throws MessagingException { public void sendMessages(List<? extends Message> messages) throws MessagingException {
} }
public Pusher getPusher(PushReceiver receiver) { public Pusher getPusher(PushReceiver receiver) {

View File

@ -26,9 +26,11 @@ import java.security.Security;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.Deque; import java.util.Deque;
import java.util.EnumSet;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.Iterator; import java.util.Iterator;
@ -115,7 +117,7 @@ public class ImapStore extends Store {
private static int FETCH_WINDOW_SIZE = 100; private static int FETCH_WINDOW_SIZE = 100;
private Set<Flag> mPermanentFlagsIndex = new HashSet<Flag>(); private Set<Flag> mPermanentFlagsIndex = EnumSet.noneOf(Flag.class);
private static final String CAPABILITY_IDLE = "IDLE"; private static final String CAPABILITY_IDLE = "IDLE";
private static final String CAPABILITY_AUTH_CRAM_MD5 = "AUTH=CRAM-MD5"; private static final String CAPABILITY_AUTH_CRAM_MD5 = "AUTH=CRAM-MD5";
@ -132,8 +134,6 @@ public class ImapStore extends Store {
private static final String CAPABILITY_COMPRESS_DEFLATE = "COMPRESS=DEFLATE"; private static final String CAPABILITY_COMPRESS_DEFLATE = "COMPRESS=DEFLATE";
private static final String COMMAND_COMPRESS_DEFLATE = "COMPRESS DEFLATE"; private static final String COMMAND_COMPRESS_DEFLATE = "COMPRESS DEFLATE";
private static final Message[] EMPTY_MESSAGE_ARRAY = new Message[0];
private static final String[] EMPTY_STRING_ARRAY = new String[0]; private static final String[] EMPTY_STRING_ARRAY = new String[0];
/** /**
@ -1092,22 +1092,22 @@ public class ImapStore extends Store {
* @return The mapping of original message UIDs to the new server UIDs. * @return The mapping of original message UIDs to the new server UIDs.
*/ */
@Override @Override
public Map<String, String> copyMessages(Message[] messages, Folder folder) public Map<String, String> copyMessages(List<? extends Message> messages, Folder folder)
throws MessagingException { throws MessagingException {
if (!(folder instanceof ImapFolder)) { if (!(folder instanceof ImapFolder)) {
throw new MessagingException("ImapFolder.copyMessages passed non-ImapFolder"); throw new MessagingException("ImapFolder.copyMessages passed non-ImapFolder");
} }
if (messages.length == 0) { if (messages.isEmpty()) {
return null; return null;
} }
ImapFolder iFolder = (ImapFolder)folder; ImapFolder iFolder = (ImapFolder)folder;
checkOpen(); //only need READ access checkOpen(); //only need READ access
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
try { try {
@ -1193,21 +1193,21 @@ public class ImapStore extends Store {
} }
@Override @Override
public Map<String, String> moveMessages(Message[] messages, Folder folder) throws MessagingException { public Map<String, String> moveMessages(List<? extends Message> messages, Folder folder) throws MessagingException {
if (messages.length == 0) if (messages.isEmpty())
return null; return null;
Map<String, String> uidMap = copyMessages(messages, folder); Map<String, String> uidMap = copyMessages(messages, folder);
setFlags(messages, new Flag[] { Flag.DELETED }, true); setFlags(messages, Collections.singleton(Flag.DELETED), true);
return uidMap; return uidMap;
} }
@Override @Override
public void delete(Message[] messages, String trashFolderName) throws MessagingException { public void delete(List<? extends Message> messages, String trashFolderName) throws MessagingException {
if (messages.length == 0) if (messages.isEmpty())
return; return;
if (trashFolderName == null || getName().equalsIgnoreCase(trashFolderName)) { if (trashFolderName == null || getName().equalsIgnoreCase(trashFolderName)) {
setFlags(messages, new Flag[] { Flag.DELETED }, true); setFlags(messages, Collections.singleton(Flag.DELETED), true);
} else { } else {
ImapFolder remoteTrashFolder = (ImapFolder)getStore().getFolder(trashFolderName); ImapFolder remoteTrashFolder = (ImapFolder)getStore().getFolder(trashFolderName);
String remoteTrashName = encodeString(encodeFolderName(remoteTrashFolder.getPrefixedName())); String remoteTrashName = encodeString(encodeFolderName(remoteTrashFolder.getPrefixedName()));
@ -1223,7 +1223,7 @@ public class ImapStore extends Store {
if (exists(remoteTrashName)) { if (exists(remoteTrashName)) {
if (K9.DEBUG) if (K9.DEBUG)
Log.d(K9.LOG_TAG, "IMAPMessage.delete: copying remote " + messages.length + " messages to '" + trashFolderName + "' for " + getLogId()); Log.d(K9.LOG_TAG, "IMAPMessage.delete: copying remote " + messages.size() + " messages to '" + trashFolderName + "' for " + getLogId());
moveMessages(messages, remoteTrashFolder); moveMessages(messages, remoteTrashFolder);
} else { } else {
@ -1278,9 +1278,9 @@ public class ImapStore extends Store {
return executeSimpleCommand("UID SEARCH *:*"); return executeSimpleCommand("UID SEARCH *:*");
} }
}; };
Message[] messages = search(searcher, null).toArray(EMPTY_MESSAGE_ARRAY); List<? extends Message> messages = search(searcher, null);
if (messages.length > 0) { if (messages.size() > 0) {
return Long.parseLong(messages[0].getUid()); return Long.parseLong(messages.get(0).getUid());
} }
} catch (Exception e) { } catch (Exception e) {
Log.e(K9.LOG_TAG, "Unable to find highest UID in folder " + getName(), e); Log.e(K9.LOG_TAG, "Unable to find highest UID in folder " + getName(), e);
@ -1301,12 +1301,12 @@ public class ImapStore extends Store {
@Override @Override
public Message[] getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) public List<? extends Message> getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
return getMessages(start, end, earliestDate, false, listener); return getMessages(start, end, earliestDate, false, listener);
} }
protected Message[] getMessages(final int start, final int end, Date earliestDate, final boolean includeDeleted, final MessageRetrievalListener listener) protected List<? extends Message> getMessages(final int start, final int end, Date earliestDate, final boolean includeDeleted, final MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
if (start < 1 || end < 1 || end < start) { if (start < 1 || end < 1 || end < start) {
throw new MessagingException( throw new MessagingException(
@ -1328,10 +1328,10 @@ public class ImapStore extends Store {
return executeSimpleCommand(String.format(Locale.US, "UID SEARCH %d:%d%s%s", start, end, dateSearchString, includeDeleted ? "" : " NOT DELETED")); return executeSimpleCommand(String.format(Locale.US, "UID SEARCH %d:%d%s%s", start, end, dateSearchString, includeDeleted ? "" : " NOT DELETED"));
} }
}; };
return search(searcher, listener).toArray(EMPTY_MESSAGE_ARRAY); return search(searcher, listener);
} }
protected Message[] getMessages(final List<Long> mesgSeqs, final boolean includeDeleted, final MessageRetrievalListener listener) protected List<? extends Message> getMessages(final List<Long> mesgSeqs, final boolean includeDeleted, final MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
ImapSearcher searcher = new ImapSearcher() { ImapSearcher searcher = new ImapSearcher() {
@Override @Override
@ -1339,10 +1339,10 @@ public class ImapStore extends Store {
return executeSimpleCommand(String.format("UID SEARCH %s%s", Utility.combine(mesgSeqs.toArray(), ','), includeDeleted ? "" : " NOT DELETED")); return executeSimpleCommand(String.format("UID SEARCH %s%s", Utility.combine(mesgSeqs.toArray(), ','), includeDeleted ? "" : " NOT DELETED"));
} }
}; };
return search(searcher, listener).toArray(EMPTY_MESSAGE_ARRAY); return search(searcher, listener);
} }
protected Message[] getMessagesFromUids(final List<String> mesgUids, final boolean includeDeleted, final MessageRetrievalListener listener) protected List<? extends Message> getMessagesFromUids(final List<String> mesgUids, final boolean includeDeleted, final MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
ImapSearcher searcher = new ImapSearcher() { ImapSearcher searcher = new ImapSearcher() {
@Override @Override
@ -1350,7 +1350,7 @@ public class ImapStore extends Store {
return executeSimpleCommand(String.format("UID SEARCH UID %s%s", Utility.combine(mesgUids.toArray(), ','), includeDeleted ? "" : " NOT DELETED")); return executeSimpleCommand(String.format("UID SEARCH UID %s%s", Utility.combine(mesgUids.toArray(), ','), includeDeleted ? "" : " NOT DELETED"));
} }
}; };
return search(searcher, listener).toArray(EMPTY_MESSAGE_ARRAY); return search(searcher, listener);
} }
private List<Message> search(ImapSearcher searcher, MessageRetrievalListener listener) throws MessagingException { private List<Message> search(ImapSearcher searcher, MessageRetrievalListener listener) throws MessagingException {
@ -1395,12 +1395,12 @@ public class ImapStore extends Store {
@Override @Override
public Message[] getMessages(MessageRetrievalListener listener) throws MessagingException { public List<? extends Message> getMessages(MessageRetrievalListener listener) throws MessagingException {
return getMessages(null, listener); return getMessages(null, listener);
} }
@Override @Override
public Message[] getMessages(String[] uids, MessageRetrievalListener listener) public List<? extends Message> getMessages(String[] uids, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
checkOpen(); //only need READ access checkOpen(); //only need READ access
List<Message> messages = new ArrayList<Message>(); List<Message> messages = new ArrayList<Message>();
@ -1430,18 +1430,18 @@ public class ImapStore extends Store {
} catch (IOException ioe) { } catch (IOException ioe) {
throw ioExceptionHandler(mConnection, ioe); throw ioExceptionHandler(mConnection, ioe);
} }
return messages.toArray(EMPTY_MESSAGE_ARRAY); return messages;
} }
@Override @Override
public void fetch(Message[] messages, FetchProfile fp, MessageRetrievalListener listener) public void fetch(List<? extends Message> messages, FetchProfile fp, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
if (messages == null || messages.length == 0) { if (messages == null || messages.isEmpty()) {
return; return;
} }
checkOpen(); //only need READ access checkOpen(); //only need READ access
List<String> uids = new ArrayList<String>(messages.length); List<String> uids = new ArrayList<String>(messages.size());
Map<String, Message> messageMap = new HashMap<String, Message>(); HashMap<String, Message> messageMap = new HashMap<String, Message>();
for (Message msg : messages) { for (Message msg : messages) {
String uid = msg.getUid(); String uid = msg.getUid();
uids.add(uid); uids.add(uid);
@ -1482,8 +1482,8 @@ public class ImapStore extends Store {
for (int windowStart = 0; windowStart < messages.length; windowStart += (FETCH_WINDOW_SIZE)) { for (int windowStart = 0; windowStart < messages.size(); windowStart += (FETCH_WINDOW_SIZE)) {
List<String> uidWindow = uids.subList(windowStart, Math.min((windowStart + FETCH_WINDOW_SIZE), messages.length)); List<String> uidWindow = uids.subList(windowStart, Math.min((windowStart + FETCH_WINDOW_SIZE), messages.size()));
try { try {
mConnection.sendCommand(String.format("UID FETCH %s (%s)", mConnection.sendCommand(String.format("UID FETCH %s (%s)",
@ -1965,7 +1965,7 @@ public class ImapStore extends Store {
* @return The mapping of original message UIDs to the new server UIDs. * @return The mapping of original message UIDs to the new server UIDs.
*/ */
@Override @Override
public Map<String, String> appendMessages(Message[] messages) throws MessagingException { public Map<String, String> appendMessages(List<? extends Message> messages) throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
checkOpen(); checkOpen();
try { try {
@ -2037,7 +2037,7 @@ public class ImapStore extends Store {
* with the behavior of other similar methods (copyMessages, moveMessages) which * with the behavior of other similar methods (copyMessages, moveMessages) which
* return null. * return null.
*/ */
return (uidMap.size() == 0) ? null : uidMap; return (uidMap.isEmpty()) ? null : uidMap;
} catch (IOException ioe) { } catch (IOException ioe) {
throw ioExceptionHandler(mConnection, ioe); throw ioExceptionHandler(mConnection, ioe);
} }
@ -2088,7 +2088,7 @@ public class ImapStore extends Store {
} }
} }
private String combineFlags(Flag[] flags) { private String combineFlags(Iterable<Flag> flags) {
List<String> flagNames = new ArrayList<String>(); List<String> flagNames = new ArrayList<String>();
for (Flag flag : flags) { for (Flag flag : flags) {
if (flag == Flag.SEEN) { if (flag == Flag.SEEN) {
@ -2110,7 +2110,7 @@ public class ImapStore extends Store {
@Override @Override
public void setFlags(Flag[] flags, boolean value) public void setFlags(Set<Flag> flags, boolean value)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
checkOpen(); checkOpen();
@ -2145,13 +2145,13 @@ public class ImapStore extends Store {
@Override @Override
public void setFlags(Message[] messages, Flag[] flags, boolean value) public void setFlags(List<? extends Message> messages, final Set<Flag> flags, boolean value)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
checkOpen(); checkOpen();
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
try { try {
executeSimpleCommand(String.format("UID STORE %s %sFLAGS.SILENT (%s)", executeSimpleCommand(String.format("UID STORE %s %sFLAGS.SILENT (%s)",
@ -2212,7 +2212,7 @@ public class ImapStore extends Store {
* @throws MessagingException On any error. * @throws MessagingException On any error.
*/ */
@Override @Override
public List<Message> search(final String queryString, final Flag[] requiredFlags, final Flag[] forbiddenFlags) public List<Message> search(final String queryString, final Set<Flag> requiredFlags, final Set<Flag> forbiddenFlags)
throws MessagingException { throws MessagingException {
if (!mAccount.allowRemoteSearch()) { if (!mAccount.allowRemoteSearch()) {
@ -2911,12 +2911,12 @@ public class ImapStore extends Store {
@Override @Override
public void setFlag(Flag flag, boolean set) throws MessagingException { public void setFlag(Flag flag, boolean set) throws MessagingException {
super.setFlag(flag, set); super.setFlag(flag, set);
mFolder.setFlags(new Message[] { this }, new Flag[] { flag }, set); mFolder.setFlags(Collections.singletonList(this), Collections.singleton(flag), set);
} }
@Override @Override
public void delete(String trashFolderName) throws MessagingException { public void delete(String trashFolderName) throws MessagingException {
getFolder().delete(new Message[] { this }, trashFolderName); getFolder().delete(Collections.singletonList(this), trashFolderName);
} }
} }
@ -3209,9 +3209,9 @@ public class ImapStore extends Store {
Log.e(K9.LOG_TAG, "Unable to get oldUidNext for " + getLogId(), e); Log.e(K9.LOG_TAG, "Unable to get oldUidNext for " + getLogId(), e);
} }
Message[] messageArray = getMessages(end, end, null, true, null); List<? extends Message> messageList = getMessages(end, end, null, true, null);
if (messageArray != null && messageArray.length > 0) { if (messageList != null && messageList.size() > 0) {
long newUid = Long.parseLong(messageArray[0].getUid()); long newUid = Long.parseLong(messageList.get(0).getUid());
if (K9.DEBUG) if (K9.DEBUG)
Log.i(K9.LOG_TAG, "Got newUid " + newUid + " for message " + end + " on " + getLogId()); Log.i(K9.LOG_TAG, "Got newUid " + newUid + " for message " + end + " on " + getLogId());
long startUid = oldUidNext; long startUid = oldUidNext;
@ -3239,12 +3239,10 @@ public class ImapStore extends Store {
private void syncMessages(List<Long> flagSyncMsgSeqs) { private void syncMessages(List<Long> flagSyncMsgSeqs) {
try { try {
Message[] messageArray = null; List<? extends Message> messageList = getMessages(flagSyncMsgSeqs, true, null);
messageArray = getMessages(flagSyncMsgSeqs, true, null);
List<Message> messages = new ArrayList<Message>(); List<Message> messages = new ArrayList<Message>();
messages.addAll(Arrays.asList(messageArray)); messages.addAll(messageList);
pushMessages(messages, false); pushMessages(messages, false);
} catch (Exception e) { } catch (Exception e) {
@ -3256,7 +3254,7 @@ public class ImapStore extends Store {
List<Message> messages = new ArrayList<Message>(removeUids.size()); List<Message> messages = new ArrayList<Message>(removeUids.size());
try { try {
Message[] existingMessages = getMessagesFromUids(removeUids, true, null); List<? extends Message> existingMessages = getMessagesFromUids(removeUids, true, null);
for (Message existingMessage : existingMessages) { for (Message existingMessage : existingMessages) {
needsPoll.set(true); needsPoll.set(true);
msgSeqUidMap.clear(); msgSeqUidMap.clear();

View File

@ -24,6 +24,8 @@ import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; import java.security.NoSuchAlgorithmException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.HashMap; import java.util.HashMap;
@ -566,7 +568,7 @@ public class Pop3Store extends Store {
} }
@Override @Override
public Message[] getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) public List<? extends Message> getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
if (start < 1 || end < 1 || end < start) { if (start < 1 || end < 1 || end < start) {
throw new MessagingException(String.format(Locale.US, "Invalid message set %d %d", throw new MessagingException(String.format(Locale.US, "Invalid message set %d %d",
@ -599,7 +601,7 @@ public class Pop3Store extends Store {
listener.messageFinished(message, i++, (end - start) + 1); listener.messageFinished(message, i++, (end - start) + 1);
} }
} }
return messages.toArray(new Message[messages.size()]); return messages;
} }
/** /**
@ -741,12 +743,12 @@ public class Pop3Store extends Store {
} }
@Override @Override
public Message[] getMessages(MessageRetrievalListener listener) throws MessagingException { public List<? extends Message> getMessages(MessageRetrievalListener listener) throws MessagingException {
throw new UnsupportedOperationException("Pop3: No getMessages"); throw new UnsupportedOperationException("Pop3: No getMessages");
} }
@Override @Override
public Message[] getMessages(String[] uids, MessageRetrievalListener listener) public List<? extends Message> getMessages(String[] uids, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
throw new UnsupportedOperationException("Pop3: No getMessages by uids"); throw new UnsupportedOperationException("Pop3: No getMessages by uids");
} }
@ -759,9 +761,9 @@ public class Pop3Store extends Store {
* @throws MessagingException * @throws MessagingException
*/ */
@Override @Override
public void fetch(Message[] messages, FetchProfile fp, MessageRetrievalListener listener) public void fetch(List<? extends Message> messages, FetchProfile fp, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
if (messages == null || messages.length == 0) { if (messages == null || messages.isEmpty()) {
return; return;
} }
List<String> uids = new ArrayList<String>(); List<String> uids = new ArrayList<String>();
@ -786,8 +788,8 @@ public class Pop3Store extends Store {
} catch (IOException ioe) { } catch (IOException ioe) {
throw new MessagingException("fetch", ioe); throw new MessagingException("fetch", ioe);
} }
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
Message message = messages[i]; Message message = messages.get(i);
if (!(message instanceof Pop3Message)) { if (!(message instanceof Pop3Message)) {
throw new MessagingException("Pop3Store.fetch called with non-Pop3 Message"); throw new MessagingException("Pop3Store.fetch called with non-Pop3 Message");
} }
@ -825,7 +827,7 @@ public class Pop3Store extends Store {
} }
} }
private void fetchEnvelope(Message[] messages, private void fetchEnvelope(List<? extends Message> messages,
MessageRetrievalListener listener) throws IOException, MessagingException { MessageRetrievalListener listener) throws IOException, MessagingException {
int unsizedMessages = 0; int unsizedMessages = 0;
for (Message message : messages) { for (Message message : messages) {
@ -841,8 +843,8 @@ public class Pop3Store extends Store {
* In extreme cases we'll do a command per message instead of a bulk request * In extreme cases we'll do a command per message instead of a bulk request
* to hopefully save some time and bandwidth. * to hopefully save some time and bandwidth.
*/ */
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
Message message = messages[i]; Message message = messages.get(i);
if (!(message instanceof Pop3Message)) { if (!(message instanceof Pop3Message)) {
throw new MessagingException("Pop3Store.fetch called with non-Pop3 Message"); throw new MessagingException("Pop3Store.fetch called with non-Pop3 Message");
} }
@ -865,7 +867,7 @@ public class Pop3Store extends Store {
for (Message message : messages) { for (Message message : messages) {
msgUidIndex.add(message.getUid()); msgUidIndex.add(message.getUid());
} }
int i = 0, count = messages.length; int i = 0, count = messages.size();
String response = executeSimpleCommand(LIST_COMMAND); String response = executeSimpleCommand(LIST_COMMAND);
while ((response = readLine()) != null) { while ((response = readLine()) != null) {
if (response.equals(".")) { if (response.equals(".")) {
@ -956,7 +958,7 @@ public class Pop3Store extends Store {
} }
@Override @Override
public Map<String, String> appendMessages(Message[] messages) throws MessagingException { public Map<String, String> appendMessages(List<? extends Message> messages) throws MessagingException {
return null; return null;
} }
@ -965,8 +967,8 @@ public class Pop3Store extends Store {
} }
@Override @Override
public void delete(Message[] msgs, String trashFolderName) throws MessagingException { public void delete(List<? extends Message> msgs, String trashFolderName) throws MessagingException {
setFlags(msgs, new Flag[] { Flag.DELETED }, true); setFlags(msgs, Collections.singleton(Flag.DELETED), true);
} }
@Override @Override
@ -975,14 +977,14 @@ public class Pop3Store extends Store {
} }
@Override @Override
public void setFlags(Flag[] flags, boolean value) throws MessagingException { public void setFlags(final Set<Flag> flags, boolean value) throws MessagingException {
throw new UnsupportedOperationException("POP3: No setFlags(Flag[],boolean)"); throw new UnsupportedOperationException("POP3: No setFlags(Set<Flag>,boolean)");
} }
@Override @Override
public void setFlags(Message[] messages, Flag[] flags, boolean value) public void setFlags(List<? extends Message> messages, final Set<Flag> flags, boolean value)
throws MessagingException { throws MessagingException {
if (!value || !Utility.arrayContains(flags, Flag.DELETED)) { if (!value || !flags.contains(Flag.DELETED)) {
/* /*
* The only flagging we support is setting the Deleted flag. * The only flagging we support is setting the Deleted flag.
*/ */
@ -1185,7 +1187,7 @@ public class Pop3Store extends Store {
@Override @Override
public void setFlag(Flag flag, boolean set) throws MessagingException { public void setFlag(Flag flag, boolean set) throws MessagingException {
super.setFlag(flag, set); super.setFlag(flag, set);
mFolder.setFlags(new Message[] { this }, new Flag[] { flag }, set); mFolder.setFlags(Collections.singletonList(this), Collections.singleton(flag), set);
} }
@Override @Override

View File

@ -65,8 +65,6 @@ public class WebDavStore extends Store {
private static final String[] EMPTY_STRING_ARRAY = new String[0]; private static final String[] EMPTY_STRING_ARRAY = new String[0];
private static final Message[] EMPTY_MESSAGE_ARRAY = new Message[0];
// These are the ids used from Exchange server to identify the special folders // These are the ids used from Exchange server to identify the special folders
// http://social.technet.microsoft.com/Forums/en/exchangesvrdevelopment/thread/1cd2e98c-8a12-44bd-a3e3-9c5ee9e4e14d // http://social.technet.microsoft.com/Forums/en/exchangesvrdevelopment/thread/1cd2e98c-8a12-44bd-a3e3-9c5ee9e4e14d
private static final String DAV_MAIL_INBOX_FOLDER = "inbox"; private static final String DAV_MAIL_INBOX_FOLDER = "inbox";
@ -1197,11 +1195,11 @@ public class WebDavStore extends Store {
} }
@Override @Override
public void sendMessages(Message[] messages) throws MessagingException { public void sendMessages(List<? extends Message> messages) throws MessagingException {
WebDavFolder tmpFolder = (WebDavStore.WebDavFolder) getFolder(mAccount.getDraftsFolderName()); WebDavFolder tmpFolder = (WebDavStore.WebDavFolder) getFolder(mAccount.getDraftsFolderName());
try { try {
tmpFolder.open(Folder.OPEN_MODE_RW); tmpFolder.open(Folder.OPEN_MODE_RW);
Message[] retMessages = tmpFolder.appendWebDavMessages(messages); List<? extends Message> retMessages = tmpFolder.appendWebDavMessages(messages);
tmpFolder.moveMessages(retMessages, getSendSpoolFolder()); tmpFolder.moveMessages(retMessages, getSendSpoolFolder());
} finally { } finally {
@ -1270,28 +1268,28 @@ public class WebDavStore extends Store {
} }
@Override @Override
public Map<String, String> copyMessages(Message[] messages, Folder folder) throws MessagingException { public Map<String, String> copyMessages(List<? extends Message> messages, Folder folder) throws MessagingException {
moveOrCopyMessages(messages, folder.getName(), false); moveOrCopyMessages(messages, folder.getName(), false);
return null; return null;
} }
@Override @Override
public Map<String, String> moveMessages(Message[] messages, Folder folder) throws MessagingException { public Map<String, String> moveMessages(List<? extends Message> messages, Folder folder) throws MessagingException {
moveOrCopyMessages(messages, folder.getName(), true); moveOrCopyMessages(messages, folder.getName(), true);
return null; return null;
} }
@Override @Override
public void delete(Message[] msgs, String trashFolderName) throws MessagingException { public void delete(List<? extends Message> msgs, String trashFolderName) throws MessagingException {
moveOrCopyMessages(msgs, trashFolderName, true); moveOrCopyMessages(msgs, trashFolderName, true);
} }
private void moveOrCopyMessages(Message[] messages, String folderName, boolean isMove) private void moveOrCopyMessages(List<? extends Message> messages, String folderName, boolean isMove)
throws MessagingException { throws MessagingException {
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
String messageBody = ""; String messageBody = "";
Map<String, String> headers = new HashMap<String, String>(); Map<String, String> headers = new HashMap<String, String>();
@ -1300,8 +1298,8 @@ public class WebDavStore extends Store {
for (int i = 0, count = uids.length; i < count; i++) { for (int i = 0, count = uids.length; i < count; i++) {
urls[i] = uidToUrl.get(uids[i]); urls[i] = uidToUrl.get(uids[i]);
if (urls[i] == null && messages[i] instanceof WebDavMessage) { if (urls[i] == null && messages.get(i) instanceof WebDavMessage) {
WebDavMessage wdMessage = (WebDavMessage) messages[i]; WebDavMessage wdMessage = (WebDavMessage) messages.get(i);
urls[i] = wdMessage.getUrl(); urls[i] = wdMessage.getUrl();
} }
} }
@ -1312,7 +1310,7 @@ public class WebDavStore extends Store {
headers.put("Brief", "t"); headers.put("Brief", "t");
headers.put("If-Match", "*"); headers.put("If-Match", "*");
String action = (isMove ? "BMOVE" : "BCOPY"); String action = (isMove ? "BMOVE" : "BCOPY");
Log.i(K9.LOG_TAG, "Moving " + messages.length + " messages to " + destFolder.mFolderUrl); Log.i(K9.LOG_TAG, "Moving " + messages.size() + " messages to " + destFolder.mFolderUrl);
processRequest(mFolderUrl, action, messageBody, headers, false); processRequest(mFolderUrl, action, messageBody, headers, false);
} }
@ -1404,7 +1402,7 @@ public class WebDavStore extends Store {
} }
@Override @Override
public Message[] getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) public List<? extends Message> getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
List<Message> messages = new ArrayList<Message>(); List<Message> messages = new ArrayList<Message>();
String[] uids; String[] uids;
@ -1450,22 +1448,22 @@ public class WebDavStore extends Store {
} }
} }
return messages.toArray(EMPTY_MESSAGE_ARRAY); return messages;
} }
@Override @Override
public Message[] getMessages(MessageRetrievalListener listener) throws MessagingException { public List<? extends Message> getMessages(MessageRetrievalListener listener) throws MessagingException {
return getMessages(null, listener); return getMessages(null, listener);
} }
@Override @Override
public Message[] getMessages(String[] uids, MessageRetrievalListener listener) throws MessagingException { public List<? extends Message> getMessages(String[] uids, MessageRetrievalListener listener) throws MessagingException {
List<Message> messageList = new ArrayList<Message>(); List<Message> messageList = new ArrayList<Message>();
Message[] messages; List<? extends Message> messages;
if (uids == null || if (uids == null ||
uids.length == 0) { uids.length == 0) {
return messageList.toArray(EMPTY_MESSAGE_ARRAY); return messageList;
} }
for (int i = 0, count = uids.length; i < count; i++) { for (int i = 0, count = uids.length; i < count; i++) {
@ -1480,7 +1478,7 @@ public class WebDavStore extends Store {
listener.messageFinished(message, i, count); listener.messageFinished(message, i, count);
} }
} }
messages = messageList.toArray(EMPTY_MESSAGE_ARRAY); messages = messageList;
return messages; return messages;
} }
@ -1500,10 +1498,10 @@ public class WebDavStore extends Store {
} }
@Override @Override
public void fetch(Message[] messages, FetchProfile fp, MessageRetrievalListener listener) public void fetch(List<? extends Message> messages, FetchProfile fp, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
if (messages == null || if (messages == null ||
messages.length == 0) { messages.isEmpty()) {
return; return;
} }
@ -1535,7 +1533,7 @@ public class WebDavStore extends Store {
/** /**
* Fetches the full messages or up to lines lines and passes them to the message parser. * Fetches the full messages or up to lines lines and passes them to the message parser.
*/ */
private void fetchMessages(Message[] messages, MessageRetrievalListener listener, int lines) private void fetchMessages(List<? extends Message> messages, MessageRetrievalListener listener, int lines)
throws MessagingException { throws MessagingException {
WebDavHttpClient httpclient; WebDavHttpClient httpclient;
httpclient = getHttpClient(); httpclient = getHttpClient();
@ -1543,15 +1541,15 @@ public class WebDavStore extends Store {
/** /**
* We can't hand off to processRequest() since we need the stream to parse. * We can't hand off to processRequest() since we need the stream to parse.
*/ */
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
WebDavMessage wdMessage; WebDavMessage wdMessage;
int statusCode = 0; int statusCode = 0;
if (!(messages[i] instanceof WebDavMessage)) { if (!(messages.get(i) instanceof WebDavMessage)) {
throw new MessagingException("WebDavStore fetch called with non-WebDavMessage"); throw new MessagingException("WebDavStore fetch called with non-WebDavMessage");
} }
wdMessage = (WebDavMessage) messages[i]; wdMessage = (WebDavMessage) messages.get(i);
if (listener != null) { if (listener != null) {
listener.messageStarted(wdMessage.getUid(), i, count); listener.messageStarted(wdMessage.getUid(), i, count);
@ -1649,36 +1647,36 @@ public class WebDavStore extends Store {
* Fetches and sets the message flags for the supplied messages. The idea is to have this be recursive so that * Fetches and sets the message flags for the supplied messages. The idea is to have this be recursive so that
* we do a series of medium calls instead of one large massive call or a large number of smaller calls. * we do a series of medium calls instead of one large massive call or a large number of smaller calls.
*/ */
private void fetchFlags(Message[] startMessages, MessageRetrievalListener listener) throws MessagingException { private void fetchFlags(List<? extends Message> startMessages, MessageRetrievalListener listener) throws MessagingException {
Map<String, String> headers = new HashMap<String, String>(); HashMap<String, String> headers = new HashMap<String, String>();
String messageBody = ""; String messageBody = "";
Message[] messages = new Message[20]; List<Message> messages = new ArrayList<Message>(20);
String[] uids; String[] uids;
if (startMessages == null || if (startMessages == null ||
startMessages.length == 0) { startMessages.isEmpty()) {
return; return;
} }
if (startMessages.length > 20) { if (startMessages.size() > 20) {
Message[] newMessages = new Message[startMessages.length - 20]; List<Message> newMessages = new ArrayList<Message>(startMessages.size() - 20);
for (int i = 0, count = startMessages.length; i < count; i++) { for (int i = 0, count = startMessages.size(); i < count; i++) {
if (i < 20) { if (i < 20) {
messages[i] = startMessages[i]; messages.set(i, startMessages.get(i));
} else { } else {
newMessages[i - 20] = startMessages[i]; newMessages.set(i - 20, startMessages.get(i));
} }
} }
fetchFlags(newMessages, listener); fetchFlags(newMessages, listener);
} else { } else {
messages = startMessages; messages.addAll(startMessages);
} }
uids = new String[messages.length]; uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
messageBody = getMessageFlagsXml(uids); messageBody = getMessageFlagsXml(uids);
@ -1691,11 +1689,11 @@ public class WebDavStore extends Store {
Map<String, Boolean> uidToReadStatus = dataset.getUidToRead(); Map<String, Boolean> uidToReadStatus = dataset.getUidToRead();
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
if (!(messages[i] instanceof WebDavMessage)) { if (!(messages.get(i) instanceof WebDavMessage)) {
throw new MessagingException("WebDavStore fetch called with non-WebDavMessage"); throw new MessagingException("WebDavStore fetch called with non-WebDavMessage");
} }
WebDavMessage wdMessage = (WebDavMessage) messages[i]; WebDavMessage wdMessage = (WebDavMessage) messages.get(i);
if (listener != null) { if (listener != null) {
listener.messageStarted(wdMessage.getUid(), i, count); listener.messageStarted(wdMessage.getUid(), i, count);
@ -1718,37 +1716,37 @@ public class WebDavStore extends Store {
* that we do a series of medium calls instead of one large massive call or a large number of smaller calls. * that we do a series of medium calls instead of one large massive call or a large number of smaller calls.
* Call it a happy balance * Call it a happy balance
*/ */
private void fetchEnvelope(Message[] startMessages, MessageRetrievalListener listener) private void fetchEnvelope(List<? extends Message> startMessages, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
Map<String, String> headers = new HashMap<String, String>(); Map<String, String> headers = new HashMap<String, String>();
String messageBody = ""; String messageBody = "";
String[] uids; String[] uids;
Message[] messages = new Message[10]; List<Message> messages = new ArrayList<Message>(10);
if (startMessages == null || if (startMessages == null ||
startMessages.length == 0) { startMessages.isEmpty()) {
return; return;
} }
if (startMessages.length > 10) { if (startMessages.size() > 10) {
Message[] newMessages = new Message[startMessages.length - 10]; List<Message> newMessages = new ArrayList<Message>(startMessages.size() - 10);
for (int i = 0, count = startMessages.length; i < count; i++) { for (int i = 0, count = startMessages.size(); i < count; i++) {
if (i < 10) { if (i < 10) {
messages[i] = startMessages[i]; messages.set(i, startMessages.get(i));
} else { } else {
newMessages[i - 10] = startMessages[i]; newMessages.set(i - 10,startMessages.get(i));
} }
} }
fetchEnvelope(newMessages, listener); fetchEnvelope(newMessages, listener);
} else { } else {
messages = startMessages; messages.addAll(startMessages);
} }
uids = new String[messages.length]; uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
messageBody = getMessageEnvelopeXml(uids); messageBody = getMessageEnvelopeXml(uids);
@ -1757,15 +1755,15 @@ public class WebDavStore extends Store {
Map<String, ParsedMessageEnvelope> envelopes = dataset.getMessageEnvelopes(); Map<String, ParsedMessageEnvelope> envelopes = dataset.getMessageEnvelopes();
int count = messages.length; int count = messages.size();
for (int i = messages.length - 1; i >= 0; i--) { for (int i = messages.size() - 1; i >= 0; i--) {
if (!(messages[i] instanceof WebDavMessage)) { if (!(messages.get(i) instanceof WebDavMessage)) {
throw new MessagingException("WebDavStore fetch called with non-WebDavMessage"); throw new MessagingException("WebDavStore fetch called with non-WebDavMessage");
} }
WebDavMessage wdMessage = (WebDavMessage) messages[i]; WebDavMessage wdMessage = (WebDavMessage) messages.get(i);
if (listener != null) { if (listener != null) {
listener.messageStarted(messages[i].getUid(), i, count); listener.messageStarted(messages.get(i).getUid(), i, count);
} }
ParsedMessageEnvelope envelope = envelopes.get(wdMessage.getUid()); ParsedMessageEnvelope envelope = envelopes.get(wdMessage.getUid());
@ -1777,18 +1775,18 @@ public class WebDavStore extends Store {
} }
if (listener != null) { if (listener != null) {
listener.messageFinished(messages[i], i, count); listener.messageFinished(messages.get(i), i, count);
} }
} }
} }
@Override @Override
public void setFlags(Message[] messages, Flag[] flags, boolean value) public void setFlags(List<? extends Message> messages, final Set<Flag> flags, boolean value)
throws MessagingException { throws MessagingException {
String[] uids = new String[messages.length]; String[] uids = new String[messages.size()];
for (int i = 0, count = messages.length; i < count; i++) { for (int i = 0, count = messages.size(); i < count; i++) {
uids[i] = messages[i].getUid(); uids[i] = messages.get(i).getUid();
} }
for (Flag flag : flags) { for (Flag flag : flags) {
@ -1848,13 +1846,13 @@ public class WebDavStore extends Store {
} }
@Override @Override
public Map<String, String> appendMessages(Message[] messages) throws MessagingException { public Map<String, String> appendMessages(List<? extends Message> messages) throws MessagingException {
appendWebDavMessages(messages); appendWebDavMessages(messages);
return null; return null;
} }
public Message[] appendWebDavMessages(Message[] messages) throws MessagingException { public List<? extends Message> appendWebDavMessages(List<? extends Message> messages) throws MessagingException {
Message[] retMessages = new Message[messages.length]; List<Message> retMessages = new ArrayList<Message>(messages.size());
int ind = 0; int ind = 0;
WebDavHttpClient httpclient = getHttpClient(); WebDavHttpClient httpclient = getHttpClient();
@ -1909,7 +1907,7 @@ public class WebDavStore extends Store {
WebDavMessage retMessage = new WebDavMessage(message.getUid(), this); WebDavMessage retMessage = new WebDavMessage(message.getUid(), this);
retMessage.setUrl(messageURL); retMessage.setUrl(messageURL);
retMessages[ind++] = retMessage; retMessages.set(ind++, retMessage);
} catch (Exception e) { } catch (Exception e) {
throw new MessagingException("Unable to append", e); throw new MessagingException("Unable to append", e);
} }
@ -1931,9 +1929,9 @@ public class WebDavStore extends Store {
} }
@Override @Override
public void setFlags(Flag[] flags, boolean value) throws MessagingException { public void setFlags(final Set<Flag> flags, boolean value) throws MessagingException {
Log.e(K9.LOG_TAG, Log.e(K9.LOG_TAG,
"Unimplemented method setFlags(Flag[], boolean) breaks markAllMessagesAsRead and EmptyTrash"); "Unimplemented method setFlags(Set<Flag>, boolean) breaks markAllMessagesAsRead and EmptyTrash");
// Try to make this efficient by not retrieving all of the messages // Try to make this efficient by not retrieving all of the messages
} }
} }
@ -2025,13 +2023,13 @@ public class WebDavStore extends Store {
public void delete(String trashFolderName) throws MessagingException { public void delete(String trashFolderName) throws MessagingException {
WebDavFolder wdFolder = (WebDavFolder) getFolder(); WebDavFolder wdFolder = (WebDavFolder) getFolder();
Log.i(K9.LOG_TAG, "Deleting message by moving to " + trashFolderName); Log.i(K9.LOG_TAG, "Deleting message by moving to " + trashFolderName);
wdFolder.moveMessages(new Message[] { this }, wdFolder.getStore().getFolder(trashFolderName)); wdFolder.moveMessages(Collections.singletonList(this), wdFolder.getStore().getFolder(trashFolderName));
} }
@Override @Override
public void setFlag(Flag flag, boolean set) throws MessagingException { public void setFlag(Flag flag, boolean set) throws MessagingException {
super.setFlag(flag, set); super.setFlag(flag, set);
mFolder.setFlags(new Message[] { this }, new Flag[] { flag }, set); mFolder.setFlags(Collections.singletonList(this), Collections.singleton(flag), set);
} }
} }

View File

@ -7,6 +7,8 @@ import java.io.InputStream;
import java.io.Serializable; import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.Date; import java.util.Date;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
@ -370,12 +372,12 @@ public class LocalFolder extends Folder implements Serializable {
return ; return ;
} }
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
Message[] messages = getMessages(null, false); List<? extends Message> messages = getMessages(null, false);
for (int i = mVisibleLimit; i < messages.length; i++) { for (int i = mVisibleLimit; i < messages.size(); i++) {
if (listener != null) { if (listener != null) {
listener.messageRemoved(messages[i]); listener.messageRemoved(messages.get(i));
} }
messages[i].destroy(); messages.get(i).destroy();
} }
} }
} }
@ -597,7 +599,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public void fetch(final Message[] messages, final FetchProfile fp, final MessageRetrievalListener listener) public void fetch(final List<? extends Message> messages, final FetchProfile fp, final MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
try { try {
this.localStore.database.execute(false, new DbCallback<Void>() { this.localStore.database.execute(false, new DbCallback<Void>() {
@ -798,7 +800,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public Message[] getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener) public List<? extends Message> getMessages(int start, int end, Date earliestDate, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
throw new MessagingException( throw new MessagingException(
@ -931,16 +933,16 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public Message[] getMessages(MessageRetrievalListener listener) throws MessagingException { public List<? extends Message> getMessages(MessageRetrievalListener listener) throws MessagingException {
return getMessages(listener, true); return getMessages(listener, true);
} }
@Override @Override
public Message[] getMessages(final MessageRetrievalListener listener, final boolean includeDeleted) throws MessagingException { public List<? extends Message> getMessages(final MessageRetrievalListener listener, final boolean includeDeleted) throws MessagingException {
try { try {
return this.localStore.database.execute(false, new DbCallback<Message[]>() { return this.localStore.database.execute(false, new DbCallback<List<? extends Message>>() {
@Override @Override
public Message[] doDbWork(final SQLiteDatabase db) throws WrappedException, UnavailableStorageException { public List<? extends Message> doDbWork(final SQLiteDatabase db) throws WrappedException, UnavailableStorageException {
try { try {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
return LocalFolder.this.localStore.getMessages( return LocalFolder.this.localStore.getMessages(
@ -965,7 +967,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public Message[] getMessages(String[] uids, MessageRetrievalListener listener) public List<? extends Message> getMessages(String[] uids, MessageRetrievalListener listener)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
if (uids == null) { if (uids == null) {
@ -978,11 +980,11 @@ public class LocalFolder extends Folder implements Serializable {
messages.add(message); messages.add(message);
} }
} }
return messages.toArray(LocalStore.EMPTY_MESSAGE_ARRAY); return messages;
} }
@Override @Override
public Map<String, String> copyMessages(Message[] msgs, Folder folder) throws MessagingException { public Map<String, String> copyMessages(List<? extends Message> msgs, Folder folder) throws MessagingException {
if (!(folder instanceof LocalFolder)) { if (!(folder instanceof LocalFolder)) {
throw new MessagingException("copyMessages called with incorrect Folder"); throw new MessagingException("copyMessages called with incorrect Folder");
} }
@ -990,7 +992,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public Map<String, String> moveMessages(final Message[] msgs, final Folder destFolder) throws MessagingException { public Map<String, String> moveMessages(final List<? extends Message> msgs, final Folder destFolder) throws MessagingException {
if (!(destFolder instanceof LocalFolder)) { if (!(destFolder instanceof LocalFolder)) {
throw new MessagingException("moveMessages called with non-LocalFolder"); throw new MessagingException("moveMessages called with non-LocalFolder");
} }
@ -1128,7 +1130,7 @@ public class LocalFolder extends Folder implements Serializable {
@Override @Override
public Message doDbWork(final SQLiteDatabase db) throws WrappedException, UnavailableStorageException { public Message doDbWork(final SQLiteDatabase db) throws WrappedException, UnavailableStorageException {
try { try {
appendMessages(new Message[] { message }); appendMessages(Collections.singletonList(message));
final String uid = message.getUid(); final String uid = message.getUid();
final Message result = getMessage(uid); final Message result = getMessage(uid);
runnable.run(); runnable.run();
@ -1154,11 +1156,11 @@ public class LocalFolder extends Folder implements Serializable {
* message, retrieve the appropriate local message instance first (if it already exists). * message, retrieve the appropriate local message instance first (if it already exists).
*/ */
@Override @Override
public Map<String, String> appendMessages(Message[] messages) throws MessagingException { public Map<String, String> appendMessages(List<? extends Message> messages) throws MessagingException {
return appendMessages(messages, false); return appendMessages(messages, false);
} }
public void destroyMessages(final Message[] messages) { public void destroyMessages(final List<? extends Message> messages) {
try { try {
this.localStore.database.execute(true, new DbCallback<Void>() { this.localStore.database.execute(true, new DbCallback<Void>() {
@Override @Override
@ -1221,7 +1223,7 @@ public class LocalFolder extends Folder implements Serializable {
* @param copy * @param copy
* @return Map<String, String> uidMap of srcUids -> destUids * @return Map<String, String> uidMap of srcUids -> destUids
*/ */
private Map<String, String> appendMessages(final Message[] messages, final boolean copy) throws MessagingException { private Map<String, String> appendMessages(final List<? extends Message> messages, final boolean copy) throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
try { try {
final Map<String, String> uidMap = new HashMap<String, String>(); final Map<String, String> uidMap = new HashMap<String, String>();
@ -1490,12 +1492,12 @@ public class LocalFolder extends Folder implements Serializable {
// Remember that all headers for this message have been saved, so it is // Remember that all headers for this message have been saved, so it is
// not necessary to download them again in case the user wants to see all headers. // not necessary to download them again in case the user wants to see all headers.
List<Flag> appendedFlags = new ArrayList<Flag>(); List<Flag> appendedFlags = new ArrayList<Flag>();
appendedFlags.addAll(Arrays.asList(message.getFlags())); appendedFlags.addAll(message.getFlags());
appendedFlags.add(Flag.X_GOT_ALL_HEADERS); appendedFlags.add(Flag.X_GOT_ALL_HEADERS);
db.execSQL("UPDATE messages " + "SET flags = ? " + " WHERE id = ?", db.execSQL("UPDATE messages " + "SET flags = ? " + " WHERE id = ?",
new Object[] new Object[]
{ LocalFolder.this.localStore.serializeFlags(appendedFlags.toArray(LocalStore.EMPTY_FLAG_ARRAY)), id }); { LocalFolder.this.localStore.serializeFlags(appendedFlags), id });
return null; return null;
} }
@ -1722,7 +1724,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public void setFlags(final Message[] messages, final Flag[] flags, final boolean value) public void setFlags(final List<? extends Message> messages, final Set<Flag> flags, final boolean value)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
@ -1750,7 +1752,7 @@ public class LocalFolder extends Folder implements Serializable {
} }
@Override @Override
public void setFlags(Flag[] flags, boolean value) public void setFlags(final Set<Flag> flags, boolean value)
throws MessagingException { throws MessagingException {
open(OPEN_MODE_RW); open(OPEN_MODE_RW);
for (Message message : getMessages(null)) { for (Message message : getMessages(null)) {
@ -1766,7 +1768,7 @@ public class LocalFolder extends Folder implements Serializable {
public void clearMessagesOlderThan(long cutoff) throws MessagingException { public void clearMessagesOlderThan(long cutoff) throws MessagingException {
open(OPEN_MODE_RO); open(OPEN_MODE_RO);
Message[] messages = this.localStore.getMessages( List<? extends Message> messages = this.localStore.getMessages(
null, null,
this, this,
"SELECT " + LocalStore.GET_MESSAGES_COLS + "SELECT " + LocalStore.GET_MESSAGES_COLS +
@ -1841,7 +1843,7 @@ public class LocalFolder extends Folder implements Serializable {
try { try {
// We need to open the folder first to make sure we've got it's id // We need to open the folder first to make sure we've got it's id
open(OPEN_MODE_RO); open(OPEN_MODE_RO);
Message[] messages = getMessages(null); List<? extends Message> messages = getMessages(null);
for (Message message : messages) { for (Message message : messages) {
deleteAttachments(message.getUid()); deleteAttachments(message.getUid());
} }

View File

@ -4,6 +4,7 @@ package com.fsck.k9.mail.store.local;
import java.io.File; import java.io.File;
import java.io.Serializable; import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@ -55,9 +56,7 @@ public class LocalStore extends Store implements Serializable {
private static final long serialVersionUID = -5142141896809423072L; private static final long serialVersionUID = -5142141896809423072L;
static final Message[] EMPTY_MESSAGE_ARRAY = new Message[0];
static final String[] EMPTY_STRING_ARRAY = new String[0]; static final String[] EMPTY_STRING_ARRAY = new String[0];
static final Flag[] EMPTY_FLAG_ARRAY = new Flag[0];
static final byte[] EMPTY_BYTE_ARRAY = new byte[0]; static final byte[] EMPTY_BYTE_ARRAY = new byte[0];
/* /*
@ -523,7 +522,7 @@ public class LocalStore extends Store implements Serializable {
return true; return true;
} }
public Message[] searchForMessages(MessageRetrievalListener retrievalListener, public List<LocalMessage> searchForMessages(MessageRetrievalListener retrievalListener,
LocalSearch search) throws MessagingException { LocalSearch search) throws MessagingException {
StringBuilder query = new StringBuilder(); StringBuilder query = new StringBuilder();
@ -554,7 +553,7 @@ public class LocalStore extends Store implements Serializable {
* Given a query string, actually do the query for the messages and * Given a query string, actually do the query for the messages and
* call the MessageRetrievalListener for each one * call the MessageRetrievalListener for each one
*/ */
Message[] getMessages( List<LocalMessage> getMessages(
final MessageRetrievalListener listener, final MessageRetrievalListener listener,
final LocalFolder folder, final LocalFolder folder,
final String queryString, final String[] placeHolders final String queryString, final String[] placeHolders
@ -603,11 +602,11 @@ public class LocalStore extends Store implements Serializable {
listener.messagesFinished(j); listener.messagesFinished(j);
} }
return messages.toArray(EMPTY_MESSAGE_ARRAY); return Collections.unmodifiableList(messages);
} }
public Message[] getMessagesInThread(final long rootId) throws MessagingException { public List<LocalMessage> getMessagesInThread(final long rootId) throws MessagingException {
String rootIdString = Long.toString(rootId); String rootIdString = Long.toString(rootId);
LocalSearch search = new LocalSearch(); LocalSearch search = new LocalSearch();
@ -706,7 +705,7 @@ public class LocalStore extends Store implements Serializable {
} }
String serializeFlags(Flag[] flags) { String serializeFlags(Iterable<Flag> flags) {
List<Flag> extraFlags = new ArrayList<Flag>(); List<Flag> extraFlags = new ArrayList<Flag>();
for (Flag flag : flags) { for (Flag flag : flags) {
@ -724,7 +723,7 @@ public class LocalStore extends Store implements Serializable {
} }
} }
return Utility.combine(extraFlags.toArray(EMPTY_FLAG_ARRAY), ',').toUpperCase(Locale.US); return Utility.combine(extraFlags, ',').toUpperCase(Locale.US);
} }
public LockableDatabase getDatabase() { public LockableDatabase getDatabase() {

View File

@ -309,9 +309,9 @@ class StoreSchemaDefinition implements LockableDatabase.SchemaDefinition {
LocalFolder obsoleteOutbox = new LocalFolder(this.localStore, localizedOutbox); LocalFolder obsoleteOutbox = new LocalFolder(this.localStore, localizedOutbox);
if (obsoleteOutbox.exists()) { if (obsoleteOutbox.exists()) {
// Get all messages from the localized outbox ... // Get all messages from the localized outbox ...
Message[] messages = obsoleteOutbox.getMessages(null, false); List<? extends Message> messages = obsoleteOutbox.getMessages(null, false);
if (messages.length > 0) { if (messages.size() > 0) {
// ... and move them to the drafts folder (we don't want to // ... and move them to the drafts folder (we don't want to
// surprise the user by sending potentially very old messages) // surprise the user by sending potentially very old messages)
LocalFolder drafts = new LocalFolder(this.localStore, this.localStore.getAccount().getDraftsFolderName()); LocalFolder drafts = new LocalFolder(this.localStore, this.localStore.getAccount().getDraftsFolderName());
@ -424,7 +424,7 @@ class StoreSchemaDefinition implements LockableDatabase.SchemaDefinition {
} }
cv.put("flags", this.localStore.serializeFlags(extraFlags.toArray(LocalStore.EMPTY_FLAG_ARRAY))); cv.put("flags", this.localStore.serializeFlags(extraFlags));
cv.put("read", read); cv.put("read", read);
cv.put("flagged", flagged); cv.put("flagged", flagged);
cv.put("answered", answered); cv.put("answered", answered);

View File

@ -11,6 +11,8 @@ import com.fsck.k9.mail.ServerSettings;
import com.fsck.k9.mail.Transport; import com.fsck.k9.mail.Transport;
import com.fsck.k9.mail.store.WebDavStore; import com.fsck.k9.mail.store.WebDavStore;
import java.util.Collections;
public class WebDavTransport extends Transport { public class WebDavTransport extends Transport {
public static final String TRANSPORT_TYPE = WebDavStore.STORE_TYPE; public static final String TRANSPORT_TYPE = WebDavStore.STORE_TYPE;
@ -66,6 +68,6 @@ public class WebDavTransport extends Transport {
@Override @Override
public void sendMessage(Message message) throws MessagingException { public void sendMessage(Message message) throws MessagingException {
store.sendMessages(new Message[] { message }); store.sendMessages(Collections.singletonList(message));
} }
} }

View File

@ -51,7 +51,7 @@ public class Settings {
SortedMap<Integer, SettingsDescription> headMap = versions.headMap(version + 1); SortedMap<Integer, SettingsDescription> headMap = versions.headMap(version + 1);
// Skip this setting if it was introduced after 'version' // Skip this setting if it was introduced after 'version'
if (headMap.size() == 0) { if (headMap.isEmpty()) {
continue; continue;
} }

View File

@ -132,7 +132,7 @@ public class SettingsExporter {
Set<String> exportAccounts; Set<String> exportAccounts;
if (accountUuids == null) { if (accountUuids == null) {
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
exportAccounts = new HashSet<String>(); exportAccounts = new HashSet<String>();
for (Account account : accounts) { for (Account account : accounts) {
exportAccounts.add(account.getUuid()); exportAccounts.add(account.getUuid());

View File

@ -340,7 +340,7 @@ public class SettingsImporter {
AccountDescription original = new AccountDescription(account.name, account.uuid); AccountDescription original = new AccountDescription(account.name, account.uuid);
Preferences prefs = Preferences.getPreferences(context); Preferences prefs = Preferences.getPreferences(context);
Account[] accounts = prefs.getAccounts(); List<Account> accounts = prefs.getAccounts();
String uuid = account.uuid; String uuid = account.uuid;
Account existingAccount = prefs.getAccount(uuid); Account existingAccount = prefs.getAccount(uuid);
@ -357,7 +357,7 @@ public class SettingsImporter {
if (isAccountNameUsed(accountName, accounts)) { if (isAccountNameUsed(accountName, accounts)) {
// Account name is already in use. So generate a new one by appending " (x)", where x // Account name is already in use. So generate a new one by appending " (x)", where x
// is the first number >= 1 that results in an unused account name. // is the first number >= 1 that results in an unused account name.
for (int i = 1; i <= accounts.length; i++) { for (int i = 1; i <= accounts.size(); i++) {
accountName = account.name + " (" + i + ")"; accountName = account.name + " (" + i + ")";
if (!isAccountNameUsed(accountName, accounts)) { if (!isAccountNameUsed(accountName, accounts)) {
break; break;
@ -605,7 +605,7 @@ public class SettingsImporter {
} }
} }
private static boolean isAccountNameUsed(String name, Account[] accounts) { private static boolean isAccountNameUsed(String name, List<Account> accounts) {
for (Account account : accounts) { for (Account account : accounts) {
if (account == null) { if (account == null) {
continue; continue;

View File

@ -290,8 +290,8 @@ public class Storage implements SharedPreferences {
} }
} }
public long size() { public boolean isEmpty() {
return storage.size(); return storage.isEmpty();
} }
//@Override //@Override

View File

@ -328,7 +328,7 @@ public class LocalSearch implements SearchSpecification {
*/ */
@Override @Override
public String[] getAccountUuids() { public String[] getAccountUuids() {
if (mAccountUuids.size() == 0) { if (mAccountUuids.isEmpty()) {
return new String[] { SearchSpecification.ALL_ACCOUNTS }; return new String[] { SearchSpecification.ALL_ACCOUNTS };
} }
@ -343,7 +343,7 @@ public class LocalSearch implements SearchSpecification {
* @return {@code true} if all accounts should be searched. * @return {@code true} if all accounts should be searched.
*/ */
public boolean searchAllAccounts() { public boolean searchAllAccounts() {
return (mAccountUuids.size() == 0); return (mAccountUuids.isEmpty());
} }
/** /**

View File

@ -1,5 +1,6 @@
package com.fsck.k9.service; package com.fsck.k9.service;
import java.util.List;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import android.app.Service; import android.app.Service;
@ -186,8 +187,8 @@ public class DatabaseUpgradeService extends Service {
private void upgradeDatabases() { private void upgradeDatabases() {
Preferences preferences = Preferences.getPreferences(this); Preferences preferences = Preferences.getPreferences(this);
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
mProgressEnd = accounts.length; mProgressEnd = accounts.size();
mProgress = 0; mProgress = 0;
for (Account account : accounts) { for (Account account : accounts) {

View File

@ -11,6 +11,8 @@ import com.fsck.k9.K9;
import com.fsck.k9.remotecontrol.K9RemoteControl; import com.fsck.k9.remotecontrol.K9RemoteControl;
import com.fsck.k9.Preferences; import com.fsck.k9.Preferences;
import java.util.List;
import static com.fsck.k9.remotecontrol.K9RemoteControl.*; import static com.fsck.k9.remotecontrol.K9RemoteControl.*;
public class RemoteControlReceiver extends CoreReceiver { public class RemoteControlReceiver extends CoreReceiver {
@ -25,12 +27,12 @@ public class RemoteControlReceiver extends CoreReceiver {
} else if (K9RemoteControl.K9_REQUEST_ACCOUNTS.equals(intent.getAction())) { } else if (K9RemoteControl.K9_REQUEST_ACCOUNTS.equals(intent.getAction())) {
try { try {
Preferences preferences = Preferences.getPreferences(context); Preferences preferences = Preferences.getPreferences(context);
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
String[] uuids = new String[accounts.length]; String[] uuids = new String[accounts.size()];
String[] descriptions = new String[accounts.length]; String[] descriptions = new String[accounts.size()];
for (int i = 0; i < accounts.length; i++) { for (int i = 0; i < accounts.size(); i++) {
//warning: account may not be isAvailable() //warning: account may not be isAvailable()
Account account = accounts[i]; Account account = accounts.get(i);
uuids[i] = account.getUuid(); uuids[i] = account.getUuid();
descriptions[i] = account.getDescription(); descriptions[i] = account.getDescription();

View File

@ -17,6 +17,8 @@ import android.content.SharedPreferences.Editor;
import android.util.Log; import android.util.Log;
import android.widget.Toast; import android.widget.Toast;
import java.util.List;
public class RemoteControlService extends CoreService { public class RemoteControlService extends CoreService {
private final static String RESCHEDULE_ACTION = "com.fsck.k9.service.RemoteControlService.RESCHEDULE_ACTION"; private final static String RESCHEDULE_ACTION = "com.fsck.k9.service.RemoteControlService.RESCHEDULE_ACTION";
private final static String PUSH_RESTART_ACTION = "com.fsck.k9.service.RemoteControlService.PUSH_RESTART_ACTION"; private final static String PUSH_RESTART_ACTION = "com.fsck.k9.service.RemoteControlService.PUSH_RESTART_ACTION";
@ -65,7 +67,7 @@ public class RemoteControlService extends CoreService {
Log.i(K9.LOG_TAG, "RemoteControlService changing settings for account with UUID " + uuid); Log.i(K9.LOG_TAG, "RemoteControlService changing settings for account with UUID " + uuid);
} }
} }
Account[] accounts = preferences.getAccounts(); List<Account> accounts = preferences.getAccounts();
for (Account account : accounts) { for (Account account : accounts) {
//warning: account may not be isAvailable() //warning: account may not be isAvailable()
if (allAccounts || account.getUuid().equals(uuid)) { if (allAccounts || account.getUuid().equals(uuid)) {