diff options
author | Sunny Goyal <sunnygoyal@google.com> | 2015-06-18 03:06:30 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2015-06-18 03:06:30 +0000 |
commit | 27f03251ea8b563dc385094e8d03f9fc1dc9390d (patch) | |
tree | 46efd5f64b2eb9b4447d84e23b90a6531ba78dc3 /src/com/android/launcher3/LauncherProvider.java | |
parent | dad45a7026868832404ecfb722407c685c0e8a13 (diff) | |
parent | b1622cc30f2fd9b579cb918083e063685950df92 (diff) | |
download | android_packages_apps_Trebuchet-27f03251ea8b563dc385094e8d03f9fc1dc9390d.tar.gz android_packages_apps_Trebuchet-27f03251ea8b563dc385094e8d03f9fc1dc9390d.tar.bz2 android_packages_apps_Trebuchet-27f03251ea8b563dc385094e8d03f9fc1dc9390d.zip |
Merge "Deleting empty folders based on DB state" into ub-launcher3-burnaby
Diffstat (limited to 'src/com/android/launcher3/LauncherProvider.java')
-rw-r--r-- | src/com/android/launcher3/LauncherProvider.java | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/com/android/launcher3/LauncherProvider.java b/src/com/android/launcher3/LauncherProvider.java index 4df92af7c..3ebc30737 100644 --- a/src/com/android/launcher3/LauncherProvider.java +++ b/src/com/android/launcher3/LauncherProvider.java @@ -62,6 +62,7 @@ import java.net.URISyntaxException; import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; +import java.util.List; public class LauncherProvider extends ContentProvider { private static final String TAG = "Launcher.LauncherProvider"; @@ -263,6 +264,42 @@ public class LauncherProvider extends ContentProvider { return null; } + /** + * Deletes any empty folder from the DB. + * @return Ids of deleted folders. + */ + public List<Long> deleteEmptyFolders() { + ArrayList<Long> folderIds = new ArrayList<Long>(); + SQLiteDatabase db = mOpenHelper.getWritableDatabase(); + db.beginTransaction(); + try { + // Select folders whose id do not match any container value. + String selection = LauncherSettings.Favorites.ITEM_TYPE + " = " + + LauncherSettings.Favorites.ITEM_TYPE_FOLDER + " AND " + + LauncherSettings.Favorites._ID + " NOT IN (SELECT " + + LauncherSettings.Favorites.CONTAINER + " FROM " + + TABLE_FAVORITES + ")"; + Cursor c = db.query(TABLE_FAVORITES, + new String[] {LauncherSettings.Favorites._ID}, + selection, null, null, null, null); + while (c.moveToNext()) { + folderIds.add(c.getLong(0)); + } + c.close(); + if (folderIds.size() > 0) { + db.delete(TABLE_FAVORITES, Utilities.createDbSelectionQuery( + LauncherSettings.Favorites._ID, folderIds), null); + } + db.setTransactionSuccessful(); + } catch (SQLException ex) { + Log.e(TAG, ex.getMessage(), ex); + folderIds.clear(); + } finally { + db.endTransaction(); + } + return folderIds; + } + private void notifyListeners() { // always notify the backup agent LauncherBackupAgentHelper.dataChanged(getContext()); |