diff options
| author | 2011-10-31 18:20:48 -0700 | |
|---|---|---|
| committer | 2011-10-31 18:20:48 -0700 | |
| commit | ff93e417a217703a635d8601b835853e07233afd (patch) | |
| tree | 7fed8f519904bca0b917681325505b0589621393 | |
| parent | b1db20bde5e00c8cdd1a97b07ddcc41f321d3db8 (diff) | |
| parent | 2520ed8cc3436df023a4f0ce3f436977b8ab3a99 (diff) | |
Merge "Resolve memory leak in TextServicesManagerService" into ics-mr1
| -rw-r--r-- | services/java/com/android/server/TextServicesManagerService.java | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/services/java/com/android/server/TextServicesManagerService.java b/services/java/com/android/server/TextServicesManagerService.java index 1976eba043d3..b042da601141 100644 --- a/services/java/com/android/server/TextServicesManagerService.java +++ b/services/java/com/android/server/TextServicesManagerService.java @@ -635,7 +635,9 @@ public class TextServicesManagerService extends ITextServicesManager.Stub { if (DBG) { Slog.w(TAG, "Remove " + removeList.get(i)); } - mListeners.remove(removeList.get(i)); + final InternalDeathRecipient idr = removeList.get(i); + idr.mScListener.asBinder().unlinkToDeath(idr, 0); + mListeners.remove(idr); } cleanLocked(); } @@ -664,6 +666,11 @@ public class TextServicesManagerService extends ITextServicesManager.Stub { public void removeAll() { Slog.e(TAG, "Remove the spell checker bind unexpectedly."); synchronized(mSpellCheckerMap) { + final int size = mListeners.size(); + for (int i = 0; i < size; ++i) { + final InternalDeathRecipient idr = mListeners.get(i); + idr.mScListener.asBinder().unlinkToDeath(idr, 0); + } mListeners.clear(); cleanLocked(); } |