Merge "Removing Key-Value pair backup logic as Launcher now uses full-data backup" into ub-launcher3-calgary
This commit is contained in:
@@ -1,137 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.launcher3;
|
||||
|
||||
import android.app.backup.BackupAgentHelper;
|
||||
import android.app.backup.BackupDataInput;
|
||||
import android.app.backup.BackupManager;
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
import android.database.Cursor;
|
||||
import android.os.ParcelFileDescriptor;
|
||||
import android.util.Log;
|
||||
|
||||
import com.android.launcher3.model.GridSizeMigrationTask;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
public class LauncherBackupAgentHelper extends BackupAgentHelper {
|
||||
|
||||
private static final String TAG = "LauncherBAHelper";
|
||||
|
||||
private static final String KEY_LAST_NOTIFIED_TIME = "backup_manager_last_notified";
|
||||
|
||||
private static final String LAUNCHER_DATA_PREFIX = "L";
|
||||
|
||||
static final boolean VERBOSE = false;
|
||||
static final boolean DEBUG = false;
|
||||
|
||||
/**
|
||||
* Notify the backup manager that out database is dirty.
|
||||
*
|
||||
* <P>This does not force an immediate backup.
|
||||
*
|
||||
* @param context application context
|
||||
*/
|
||||
public static void dataChanged(Context context) {
|
||||
dataChanged(context, 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* Notify the backup manager that out database is dirty.
|
||||
*
|
||||
* <P>This does not force an immediate backup.
|
||||
*
|
||||
* @param context application context
|
||||
* @param throttleMs duration in ms for which two consecutive calls to backup manager should
|
||||
* not be made.
|
||||
*/
|
||||
public static void dataChanged(Context context, long throttleMs) {
|
||||
SharedPreferences prefs = Utilities.getPrefs(context);
|
||||
long now = System.currentTimeMillis();
|
||||
long lastTime = prefs.getLong(KEY_LAST_NOTIFIED_TIME, 0);
|
||||
|
||||
// User can manually change the system time, which could lead to now < lastTime.
|
||||
// Re-backup in that case, as the backup will have a wrong lastModifiedTime.
|
||||
if (now < lastTime || now >= (lastTime + throttleMs)) {
|
||||
BackupManager.dataChanged(context.getPackageName());
|
||||
prefs.edit().putLong(KEY_LAST_NOTIFIED_TIME, now).apply();
|
||||
}
|
||||
}
|
||||
|
||||
private LauncherBackupHelper mHelper;
|
||||
|
||||
@Override
|
||||
public void onCreate() {
|
||||
super.onCreate();
|
||||
mHelper = new LauncherBackupHelper(this);
|
||||
addHelper(LAUNCHER_DATA_PREFIX, mHelper);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onRestore(BackupDataInput data, int appVersionCode, ParcelFileDescriptor newState)
|
||||
throws IOException {
|
||||
if (!Utilities.ATLEAST_LOLLIPOP) {
|
||||
// No restore for old devices.
|
||||
Log.i(TAG, "You shall not pass!!!");
|
||||
Log.d(TAG, "Restore is only supported on devices running Lollipop and above.");
|
||||
return;
|
||||
}
|
||||
|
||||
// Clear dB before restore
|
||||
LauncherSettings.Settings.call(getContentResolver(),
|
||||
LauncherSettings.Settings.METHOD_CREATE_EMPTY_DB);
|
||||
|
||||
boolean hasData;
|
||||
try {
|
||||
super.onRestore(data, appVersionCode, newState);
|
||||
// If no favorite was migrated, clear the data and start fresh.
|
||||
final Cursor c = getContentResolver().query(
|
||||
LauncherSettings.Favorites.CONTENT_URI, null, null, null, null);
|
||||
hasData = c.moveToNext();
|
||||
c.close();
|
||||
} catch (Exception e) {
|
||||
// If the restore fails, we should do a fresh start.
|
||||
Log.e(TAG, "Restore failed", e);
|
||||
hasData = false;
|
||||
}
|
||||
|
||||
if (hasData && mHelper.restoreSuccessful) {
|
||||
LauncherSettings.Settings.call(getContentResolver(),
|
||||
LauncherSettings.Settings.METHOD_CLEAR_EMPTY_DB_FLAG);
|
||||
LauncherClings.markFirstRunClingDismissed(this);
|
||||
|
||||
// Rank was added in v4.
|
||||
if (mHelper.restoredBackupVersion <= 3) {
|
||||
LauncherSettings.Settings.call(getContentResolver(),
|
||||
LauncherSettings.Settings.METHOD_UPDATE_FOLDER_ITEMS_RANK);
|
||||
}
|
||||
|
||||
if (GridSizeMigrationTask.ENABLED && mHelper.shouldAttemptWorkspaceMigration()) {
|
||||
GridSizeMigrationTask.markForMigration(getApplicationContext(),
|
||||
mHelper.widgetSizes, mHelper.migrationCompatibleProfileData);
|
||||
}
|
||||
|
||||
LauncherSettings.Settings.call(getContentResolver(),
|
||||
LauncherSettings.Settings.METHOD_CONVERT_SHORTCUTS_TO_ACTIVITIES);
|
||||
} else {
|
||||
if (VERBOSE) Log.v(TAG, "Nothing was restored, clearing DB");
|
||||
LauncherSettings.Settings.call(getContentResolver(),
|
||||
LauncherSettings.Settings.METHOD_CREATE_EMPTY_DB);
|
||||
}
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@@ -382,14 +382,6 @@ public class LauncherProvider extends ContentProvider {
|
||||
loadDefaultFavoritesIfNecessary();
|
||||
return null;
|
||||
}
|
||||
case LauncherSettings.Settings.METHOD_UPDATE_FOLDER_ITEMS_RANK: {
|
||||
mOpenHelper.updateFolderItemsRank(mOpenHelper.getWritableDatabase(), false);
|
||||
return null;
|
||||
}
|
||||
case LauncherSettings.Settings.METHOD_CONVERT_SHORTCUTS_TO_ACTIVITIES: {
|
||||
mOpenHelper.convertShortcutsToLauncherActivities(mOpenHelper.getWritableDatabase());
|
||||
return null;
|
||||
}
|
||||
case LauncherSettings.Settings.METHOD_DELETE_DB: {
|
||||
// Are you sure? (y/n)
|
||||
mOpenHelper.createEmptyDB(mOpenHelper.getWritableDatabase());
|
||||
@@ -439,8 +431,6 @@ public class LauncherProvider extends ContentProvider {
|
||||
* Overridden in tests
|
||||
*/
|
||||
protected void notifyListeners() {
|
||||
// always notify the backup agent
|
||||
LauncherBackupAgentHelper.dataChanged(getContext());
|
||||
mListenerHandler.sendEmptyMessage(ChangeListenerWrapper.MSG_LAUNCHER_PROVIDER_CHANGED);
|
||||
}
|
||||
|
||||
|
||||
@@ -285,9 +285,6 @@ public class LauncherSettings {
|
||||
public static final String METHOD_CLEAR_EMPTY_DB_FLAG = "clear_empty_db_flag";
|
||||
|
||||
public static final String METHOD_DELETE_EMPTY_FOLDERS = "delete_empty_folders";
|
||||
public static final String METHOD_UPDATE_FOLDER_ITEMS_RANK = "update_folder_items_rank";
|
||||
public static final String METHOD_CONVERT_SHORTCUTS_TO_ACTIVITIES =
|
||||
"convert_shortcuts_to_launcher_activities";
|
||||
|
||||
public static final String METHOD_NEW_ITEM_ID = "generate_new_item_id";
|
||||
public static final String METHOD_NEW_SCREEN_ID = "generate_new_screen_id";
|
||||
|
||||
@@ -51,10 +51,6 @@ public class GridSizeMigrationTask {
|
||||
private static final String KEY_MIGRATION_SRC_WORKSPACE_SIZE = "migration_src_workspace_size";
|
||||
private static final String KEY_MIGRATION_SRC_HOTSEAT_COUNT = "migration_src_hotseat_count";
|
||||
|
||||
// Set of entries indicating minimum size a widget can be resized to. This is used during
|
||||
// restore in case the widget has not been installed yet.
|
||||
private static final String KEY_MIGRATION_WIDGET_MINSIZE = "migration_widget_min_size";
|
||||
|
||||
// These are carefully selected weights for various item types (Math.random?), to allow for
|
||||
// the least absurd migration experience.
|
||||
private static final float WT_SHORTCUT = 1;
|
||||
@@ -81,11 +77,9 @@ public class GridSizeMigrationTask {
|
||||
private final int mDestHotseatSize;
|
||||
|
||||
protected GridSizeMigrationTask(Context context, InvariantDeviceProfile idp,
|
||||
HashSet<String> validPackages, HashMap<String, Point> widgetMinSize,
|
||||
Point sourceSize, Point targetSize) {
|
||||
HashSet<String> validPackages, Point sourceSize, Point targetSize) {
|
||||
mContext = context;
|
||||
mValidPackages = validPackages;
|
||||
mWidgetMinSize.putAll(widgetMinSize);
|
||||
mIdp = idp;
|
||||
|
||||
mSrcX = sourceSize.x;
|
||||
@@ -886,16 +880,6 @@ public class GridSizeMigrationTask {
|
||||
return String.format(Locale.ENGLISH, "%d,%d", x, y);
|
||||
}
|
||||
|
||||
public static void markForMigration(
|
||||
Context context, HashSet<String> widgets, BackupProtos.DeviceProfieData srcProfile) {
|
||||
Utilities.getPrefs(context).edit()
|
||||
.putString(KEY_MIGRATION_SRC_WORKSPACE_SIZE,
|
||||
getPointString((int) srcProfile.desktopCols, (int) srcProfile.desktopRows))
|
||||
.putInt(KEY_MIGRATION_SRC_HOTSEAT_COUNT, (int) srcProfile.hotseatCount)
|
||||
.putStringSet(KEY_MIGRATION_WIDGET_MINSIZE, widgets)
|
||||
.apply();
|
||||
}
|
||||
|
||||
/**
|
||||
* Migrates the workspace and hotseat in case their sizes changed.
|
||||
* @return false if the migration failed.
|
||||
@@ -957,14 +941,6 @@ public class GridSizeMigrationTask {
|
||||
+ " to " + targetSize);
|
||||
}
|
||||
|
||||
// Min widget sizes
|
||||
HashMap<String, Point> widgetMinSize = new HashMap<>();
|
||||
for (String s : Utilities.getPrefs(context).getStringSet(KEY_MIGRATION_WIDGET_MINSIZE,
|
||||
Collections.<String>emptySet())) {
|
||||
String[] parts = s.split("#");
|
||||
widgetMinSize.put(parts[0], parsePoint(parts[1]));
|
||||
}
|
||||
|
||||
// Migrate the workspace grid, step by step.
|
||||
while (targetSizeIndex < sourceSizeIndex ) {
|
||||
// We only need to migrate the grid if source size is greater
|
||||
@@ -974,8 +950,7 @@ public class GridSizeMigrationTask {
|
||||
|
||||
if (new GridSizeMigrationTask(context,
|
||||
LauncherAppState.getInstance().getInvariantDeviceProfile(),
|
||||
validPackages, widgetMinSize,
|
||||
stepSourceSize, stepTargetSize).migrateWorkspace()) {
|
||||
validPackages, stepSourceSize, stepTargetSize).migrateWorkspace()) {
|
||||
dbChanged = true;
|
||||
}
|
||||
sourceSizeIndex--;
|
||||
@@ -1006,7 +981,6 @@ public class GridSizeMigrationTask {
|
||||
prefs.edit()
|
||||
.putString(KEY_MIGRATION_SRC_WORKSPACE_SIZE, gridSizeString)
|
||||
.putInt(KEY_MIGRATION_SRC_HOTSEAT_COUNT, idp.numHotseatIcons)
|
||||
.remove(KEY_MIGRATION_WIDGET_MINSIZE)
|
||||
.apply();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -47,8 +47,9 @@ public class LossyScreenMigrationTask extends GridSizeMigrationTask {
|
||||
protected LossyScreenMigrationTask(
|
||||
Context context, InvariantDeviceProfile idp, SQLiteDatabase db) {
|
||||
// Decrease the rows count by 1
|
||||
super(context, idp, getValidPackages(context), new HashMap<String, Point>(),
|
||||
new Point(idp.numColumns, idp.numRows + 1), new Point(idp.numColumns, idp.numRows));
|
||||
super(context, idp, getValidPackages(context),
|
||||
new Point(idp.numColumns, idp.numRows + 1),
|
||||
new Point(idp.numColumns, idp.numRows));
|
||||
|
||||
mDb = db;
|
||||
mOriginalItems = new LongArrayMap<>();
|
||||
|
||||
Reference in New Issue
Block a user