From 4524dccde80bdecb31b3e2cc05638fb8bee4e2cb Mon Sep 17 00:00:00 2001 From: Anthony Lee Date: Thu, 7 Aug 2014 13:13:21 -0700 Subject: [PATCH] Make sure that we close the cursor. Found this problem while testing Email migration. Change-Id: I07862b5c4dd2ef189a87f7dbd085030c448f365f --- .../android/email/provider/EmailProvider.java | 32 ++++++++++++------- 1 file changed, 20 insertions(+), 12 deletions(-) diff --git a/src/com/android/email/provider/EmailProvider.java b/src/com/android/email/provider/EmailProvider.java index abf60d54d..d7fcff266 100644 --- a/src/com/android/email/provider/EmailProvider.java +++ b/src/com/android/email/provider/EmailProvider.java @@ -4057,10 +4057,11 @@ public class EmailProvider extends ContentProvider * @return array of URIs */ private Uri[] defaultRecentFolders(final String id) { + Uri[] recentFolders = new Uri[0]; final SQLiteDatabase db = getDatabase(getContext()); if (id.equals(COMBINED_ACCOUNT_ID_STRING)) { // We don't have default recents for the combined view. - return new Uri[0]; + return recentFolders; } // We search for the types we want, and find corresponding IDs. final String[] idAndType = { BaseColumns._ID, UIProvider.FolderColumns.TYPE }; @@ -4084,18 +4085,25 @@ public class EmailProvider extends ContentProvider .append(")"); LogUtils.d(TAG, "defaultRecentFolders: Query is %s", sb); final Cursor c = db.rawQuery(sb.toString(), null); - if (c == null || c.getCount() <= 0 || !c.moveToFirst()) { - return new Uri[0]; + try { + if (c == null || c.getCount() <= 0 || !c.moveToFirst()) { + return recentFolders; + } + // Read all the IDs of the mailboxes, and turn them into URIs. + recentFolders = new Uri[c.getCount()]; + int i = 0; + do { + final long folderId = c.getLong(0); + recentFolders[i] = uiUri("uifolder", folderId); + LogUtils.d(TAG, "Default recent folder: %d, with uri %s", folderId, + recentFolders[i]); + ++i; + } while (c.moveToNext()); + } finally { + if (c != null) { + c.close(); + } } - // Read all the IDs of the mailboxes, and turn them into URIs. - final Uri[] recentFolders = new Uri[c.getCount()]; - int i = 0; - do { - final long folderId = c.getLong(0); - recentFolders[i] = uiUri("uifolder", folderId); - LogUtils.d(TAG, "Default recent folder: %d, with uri %s", folderId, recentFolders[i]); - ++i; - } while (c.moveToNext()); return recentFolders; }