summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Phil Weaver <pweaver@google.com> 2016-08-17 21:02:30 +0000
committer android-build-merger <android-build-merger@google.com> 2016-08-17 21:02:30 +0000
commitf49d1bab467365dfc2cf0ebdb633a734e5aaf441 (patch)
tree6a5f1b2c369fc43fa788ba7704584a01660152db
parentd7787f8ca486395482ed376bb6bf73000512a56b (diff)
parentfff4a144deae13f78eedd5caffb5d8efa46abda6 (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.java25
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();