diff options
| author | 2016-08-17 21:02:30 +0000 | |
|---|---|---|
| committer | 2016-08-17 21:02:30 +0000 | |
| commit | f49d1bab467365dfc2cf0ebdb633a734e5aaf441 (patch) | |
| tree | 6a5f1b2c369fc43fa788ba7704584a01660152db | |
| parent | d7787f8ca486395482ed376bb6bf73000512a56b (diff) | |
| parent | fff4a144deae13f78eedd5caffb5d8efa46abda6 (diff) | |
Restart accessibility services after they update. am: 1e6695bbd4
am: fff4a144de
Change-Id: Ife63344494f27a68511c702536d373350e2b4b46
| -rw-r--r-- | services/accessibility/java/com/android/server/accessibility/AccessibilityManagerService.java | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/services/accessibility/java/com/android/server/accessibility/AccessibilityManagerService.java b/services/accessibility/java/com/android/server/accessibility/AccessibilityManagerService.java index 65af958b0181..695ea606a90b 100644 --- a/services/accessibility/java/com/android/server/accessibility/AccessibilityManagerService.java +++ b/services/accessibility/java/com/android/server/accessibility/AccessibilityManagerService.java @@ -279,6 +279,31 @@ public class AccessibilityManagerService extends IAccessibilityManager.Stub { } @Override + public void onPackageUpdateFinished(String packageName, int uid) { + // Unbind all services from this package, and then update the user state to + // re-bind new versions of them. + synchronized (mLock) { + final int userId = getChangingUserId(); + if (userId != mCurrentUserId) { + return; + } + UserState userState = getUserStateLocked(userId); + boolean unboundAService = false; + for (int i = userState.mBoundServices.size() - 1; i >= 0; i--) { + Service boundService = userState.mBoundServices.get(i); + String servicePkg = boundService.mComponentName.getPackageName(); + if (servicePkg.equals(packageName)) { + boundService.unbindLocked(); + unboundAService = true; + } + } + if (unboundAService) { + onUserStateChangedLocked(userState); + } + } + } + + @Override public void onPackageRemoved(String packageName, int uid) { synchronized (mLock) { final int userId = getChangingUserId(); |