From 83df188ce0822f4058406e5f2878d1cf34bf413e Mon Sep 17 00:00:00 2001 From: Michael Jurka Date: Wed, 31 Aug 2011 20:59:26 -0700 Subject: [PATCH] Execute update operations immediately if on right thread - Potential fix to bug 5205131 Change-Id: Iae302f81e4c8f5c07dc4363b3bb9ef298a33faf4 --- src/com/android/launcher2/LauncherModel.java | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/com/android/launcher2/LauncherModel.java b/src/com/android/launcher2/LauncherModel.java index ea51d01694..239970e84d 100644 --- a/src/com/android/launcher2/LauncherModel.java +++ b/src/com/android/launcher2/LauncherModel.java @@ -465,7 +465,7 @@ public class LauncherModel extends BroadcastReceiver { item.onAddToDatabase(values); item.updateValuesWithCoordinates(values, item.cellX, item.cellY); - sWorker.post(new Runnable() { + Runnable r = new Runnable() { public void run() { cr.update(LauncherSettings.Favorites.getContentUri(item.id, false), values, null, null); @@ -481,7 +481,12 @@ public class LauncherModel extends BroadcastReceiver { throw new RuntimeException(msg); } } - }); + }; + if (sWorkerThread.getThreadId() == Process.myTid()) { + r.run(); + } else { + sWorker.post(r); + } } /**