From 76a47a1b2273c4d7dfab0beeadc1a8387e6a2840 Mon Sep 17 00:00:00 2001 From: Adam Cohen Date: Wed, 5 Feb 2014 11:47:43 -0800 Subject: Small refactor to separate adding workspace / all apps items Change-Id: I06b7bc7f7f0e01696cb9670b8385e5148593e3e0 --- src/com/android/launcher3/LauncherModel.java | 58 +++++++++++++++++++--------- 1 file changed, 40 insertions(+), 18 deletions(-) (limited to 'src/com/android/launcher3/LauncherModel.java') diff --git a/src/com/android/launcher3/LauncherModel.java b/src/com/android/launcher3/LauncherModel.java index 2102a1fac..c0444bb0d 100644 --- a/src/com/android/launcher3/LauncherModel.java +++ b/src/com/android/launcher3/LauncherModel.java @@ -292,17 +292,40 @@ public class LauncherModel extends BroadcastReceiver { return null; } - public void addAndBindAddedApps(final Context context, final ArrayList workspaceApps, - final ArrayList allAppsApps) { - Callbacks cb = mCallbacks != null ? mCallbacks.get() : null; - addAndBindAddedApps(context, workspaceApps, cb, allAppsApps); - } - public void addAndBindAddedApps(final Context context, final ArrayList workspaceApps, - final Callbacks callbacks, final ArrayList allAppsApps) { - if (workspaceApps == null || allAppsApps == null) { + public void addAppsToAllApps(final Context ctx, final ArrayList allAppsApps) { + final Callbacks callbacks = mCallbacks != null ? mCallbacks.get() : null; + + if (allAppsApps == null) { + throw new RuntimeException("allAppsApps must not be null"); + } + if (allAppsApps.isEmpty()) { + return; + } + + // Process the newly added applications and add them to the database first + Runnable r = new Runnable() { + public void run() { + runOnMainThread(new Runnable() { + public void run() { + Callbacks cb = mCallbacks != null ? mCallbacks.get() : null; + if (callbacks == cb && cb != null) { + callbacks.bindAppsAdded(null, null, null, allAppsApps); + } + } + }); + } + }; + runOnWorkerThread(r); + } + + public void addAndBindAddedWorkspaceApps(final Context context, + final ArrayList workspaceApps) { + final Callbacks callbacks = mCallbacks != null ? mCallbacks.get() : null; + + if (workspaceApps == null) { throw new RuntimeException("workspaceApps and allAppsApps must not be null"); } - if (workspaceApps.isEmpty() && allAppsApps.isEmpty()) { + if (workspaceApps.isEmpty()) { return; } // Process the newly added applications and add them to the database first @@ -385,7 +408,7 @@ public class LauncherModel extends BroadcastReceiver { // Update the workspace screens updateWorkspaceScreenOrder(context, workspaceScreens); - if (!addedShortcutsFinal.isEmpty() || !allAppsApps.isEmpty()) { + if (!addedShortcutsFinal.isEmpty()) { runOnMainThread(new Runnable() { public void run() { Callbacks cb = mCallbacks != null ? mCallbacks.get() : null; @@ -404,7 +427,7 @@ public class LauncherModel extends BroadcastReceiver { } } callbacks.bindAppsAdded(addedWorkspaceScreensFinal, - addNotAnimated, addAnimated, allAppsApps); + addNotAnimated, addAnimated, null); } } }); @@ -1561,8 +1584,7 @@ public class LauncherModel extends BroadcastReceiver { } } if (!added.isEmpty()) { - Callbacks cb = mCallbacks != null ? mCallbacks.get() : null; - addAndBindAddedApps(context, added, cb, new ArrayList()); + addAndBindAddedWorkspaceApps(context, added); } } @@ -2594,14 +2616,14 @@ public class LauncherModel extends BroadcastReceiver { if (added != null) { // Ensure that we add all the workspace applications to the db - Callbacks cb = mCallbacks != null ? mCallbacks.get() : null; - if (!LauncherAppState.isDisableAllApps()) { - addAndBindAddedApps(context, new ArrayList(), cb, added); - } else { + if (LauncherAppState.isDisableAllApps()) { final ArrayList addedInfos = new ArrayList(added); - addAndBindAddedApps(context, addedInfos, cb, added); + addAndBindAddedWorkspaceApps(context, addedInfos); + } else { + addAppsToAllApps(context, added); } } + if (modified != null) { final ArrayList modifiedFinal = modified; -- cgit v1.2.3