diff options
author | Sunny Goyal <sunnygoyal@google.com> | 2016-10-12 20:49:31 -0700 |
---|---|---|
committer | Sunny Goyal <sunnygoyal@google.com> | 2016-10-19 07:42:34 +0100 |
commit | d164b7f4abcba6cc965c2264257569f88ad5e4a5 (patch) | |
tree | d3e76ff708d2f647dcf101706ab03f5759d9ea75 /src/com/android/launcher3/LauncherModel.java | |
parent | 67115b1a84006374ebb1b0daf20eab95db267838 (diff) | |
download | android_packages_apps_Trebuchet-d164b7f4abcba6cc965c2264257569f88ad5e4a5.tar.gz android_packages_apps_Trebuchet-d164b7f4abcba6cc965c2264257569f88ad5e4a5.tar.bz2 android_packages_apps_Trebuchet-d164b7f4abcba6cc965c2264257569f88ad5e4a5.zip |
Fixing static instance of Indexer being created in the model
Indexer depends on the locale and should be created when ever the config
changes. Moving the widget indexing to the adapter (similar to allApps)
which gets created whenever the activity is recreated.
This fixes the bug where widgets indexing breaks if locale changes while launcher
process is alive
Also fixing the bug in widget model cloning where the HashMap was not cloning
the underlying ArrayList
Change-Id: I7dbe6290e73299c4c07aa7fa564077a2649e1a4c
Diffstat (limited to 'src/com/android/launcher3/LauncherModel.java')
-rw-r--r-- | src/com/android/launcher3/LauncherModel.java | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/src/com/android/launcher3/LauncherModel.java b/src/com/android/launcher3/LauncherModel.java index caf8870c2..55bd0a45a 100644 --- a/src/com/android/launcher3/LauncherModel.java +++ b/src/com/android/launcher3/LauncherModel.java @@ -61,7 +61,9 @@ import com.android.launcher3.graphics.LauncherIcons; import com.android.launcher3.logging.FileLog; import com.android.launcher3.model.BgDataModel; import com.android.launcher3.model.GridSizeMigrationTask; +import com.android.launcher3.model.PackageItemInfo; import com.android.launcher3.model.SdCardAvailableReceiver; +import com.android.launcher3.model.WidgetItem; import com.android.launcher3.model.WidgetsModel; import com.android.launcher3.provider.ImportDataTask; import com.android.launcher3.provider.LauncherDbUtils; @@ -198,7 +200,7 @@ public class LauncherModel extends BroadcastReceiver UserHandleCompat user); public void bindAppInfosRemoved(ArrayList<AppInfo> appInfos); public void notifyWidgetProvidersChanged(); - public void bindWidgetsModel(WidgetsModel model); + public void bindAllWidgets(MultiHashMap<PackageItemInfo, WidgetItem> widgets); public void onPageBoundSynchronously(int page); public void executeOnNextDraw(ViewOnDrawExecutor executor); public void bindDeepShortcutMap(MultiHashMap<ComponentKey, String> deepShortcutMap); @@ -209,7 +211,7 @@ public class LauncherModel extends BroadcastReceiver Context context = app.getContext(); mApp = app; mBgAllAppsList = new AllAppsList(iconCache, appFilter); - mBgWidgetsModel = new WidgetsModel(context, iconCache, appFilter); + mBgWidgetsModel = new WidgetsModel(iconCache, appFilter); mIconCache = iconCache; mDeepShortcutManager = deepShortcutManager; @@ -3263,13 +3265,15 @@ public class LauncherModel extends BroadcastReceiver } } - private void bindWidgetsModel(final Callbacks callbacks, final WidgetsModel model) { + private void bindWidgetsModel(final Callbacks callbacks) { + final MultiHashMap<PackageItemInfo, WidgetItem> widgets + = mBgWidgetsModel.getWidgetsMap().clone(); mHandler.post(new Runnable() { @Override public void run() { Callbacks cb = getCallback(); if (callbacks == cb && cb != null) { - callbacks.bindWidgetsModel(model); + callbacks.bindAllWidgets(widgets); } } }); @@ -3281,13 +3285,13 @@ public class LauncherModel extends BroadcastReceiver @Override public void run() { if (bindFirst && !mBgWidgetsModel.isEmpty()) { - bindWidgetsModel(callbacks, mBgWidgetsModel.clone()); + bindWidgetsModel(callbacks); } - final WidgetsModel model = mBgWidgetsModel.updateAndClone(mApp.getContext()); - bindWidgetsModel(callbacks, model); + ArrayList<WidgetItem> allWidgets = mBgWidgetsModel.update(mApp.getContext()); + bindWidgetsModel(callbacks); + // update the Widget entries inside DB on the worker thread. - LauncherAppState.getInstance().getWidgetCache().removeObsoletePreviews( - model.getRawList()); + LauncherAppState.getInstance().getWidgetCache().removeObsoletePreviews(allWidgets); } }); } |