summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdam Cohen <adamcohen@google.com>2014-04-04 20:42:10 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2014-04-04 20:42:10 +0000
commiteaabe7c89a778afdcc0c0be538bff807ea1304ae (patch)
treee88423632feaa7b6af8d3fea4e2b7363bd92e9d9
parent8f006edba228622422088a358aafee069e1d9cfb (diff)
parent119285e755f8572632dc845d72320d9eed378f69 (diff)
downloadandroid_packages_apps_Trebuchet-eaabe7c89a778afdcc0c0be538bff807ea1304ae.tar.gz
android_packages_apps_Trebuchet-eaabe7c89a778afdcc0c0be538bff807ea1304ae.tar.bz2
android_packages_apps_Trebuchet-eaabe7c89a778afdcc0c0be538bff807ea1304ae.zip
Merge "Cleanup orphaned workspace items on db upgrade" into ub-now-mister-ugly
-rw-r--r--src/com/android/launcher3/LauncherProvider.java18
1 files changed, 17 insertions, 1 deletions
diff --git a/src/com/android/launcher3/LauncherProvider.java b/src/com/android/launcher3/LauncherProvider.java
index 2a645255c..fa3a75299 100644
--- a/src/com/android/launcher3/LauncherProvider.java
+++ b/src/com/android/launcher3/LauncherProvider.java
@@ -74,7 +74,7 @@ public class LauncherProvider extends ContentProvider {
private static final String DATABASE_NAME = "launcher.db";
- private static final int DATABASE_VERSION = 17;
+ private static final int DATABASE_VERSION = 18;
static final String OLD_AUTHORITY = "com.android.launcher2.settings";
static final String AUTHORITY = ProviderConfig.AUTHORITY;
@@ -492,6 +492,13 @@ public class LauncherProvider extends ContentProvider {
");");
}
+ private void removeOrphanedItems(SQLiteDatabase db) {
+ db.execSQL("DELETE FROM " + TABLE_FAVORITES + " WHERE " +
+ LauncherSettings.Favorites.SCREEN + " NOT IN (SELECT " +
+ LauncherSettings.WorkspaceScreens._ID + " FROM " + TABLE_WORKSPACE_SCREENS +
+ ")");
+ }
+
private void setFlagJustLoadedOldDb() {
String spKey = LauncherAppState.getSharedPreferencesKey();
SharedPreferences sp = mContext.getSharedPreferences(spKey, Context.MODE_PRIVATE);
@@ -792,6 +799,15 @@ public class LauncherProvider extends ContentProvider {
version = 17;
}
+ if (version < 18) {
+ // Due to a data loss bug, some users may have items associated with screen ids
+ // which no longer exist. Since this can cause other problems, and since the user
+ // will never see these items anyway, we use database upgrade as an opportunity to
+ // clean things up.
+ removeOrphanedItems(db);
+ version = 18;
+ }
+
if (version != DATABASE_VERSION) {
Log.w(TAG, "Destroying all old data.");
db.execSQL("DROP TABLE IF EXISTS " + TABLE_FAVORITES);