diff options
| author | 2016-04-07 14:56:25 -0700 | |
|---|---|---|
| committer | 2016-04-07 16:41:57 -0700 | |
| commit | 7f98aa4aa93497692f200c553d2d6fff402e3de2 (patch) | |
| tree | b67cf69def537d856b53896c21f602c89fb8c5ba /services/appwidget/java | |
| parent | 8b704d4474caf9fa0c7a734582fb6cce55248de4 (diff) | |
Added getProfileIds method returning array of userIds
Previously many usages of UserManager.getProfiles and getEnabledProfiles
were only using ids of returned users. Given that the list of users needs
to be parceled and unparceled for Binder calls, returning array of ids
minimizes memory usage and serialization time.
A new method getProfileIds was introduced which returns an array of userIds.
Existing method calls were updated where appropriate.
Bug: 27705805
Change-Id: Ic5d5decd77567ba0f749e48837a2c6fa10e812c0
Diffstat (limited to 'services/appwidget/java')
| -rw-r--r-- | services/appwidget/java/com/android/server/appwidget/AppWidgetServiceImpl.java | 32 |
1 files changed, 4 insertions, 28 deletions
diff --git a/services/appwidget/java/com/android/server/appwidget/AppWidgetServiceImpl.java b/services/appwidget/java/com/android/server/appwidget/AppWidgetServiceImpl.java index f93fb1b0f975..6ca3af8219da 100644 --- a/services/appwidget/java/com/android/server/appwidget/AppWidgetServiceImpl.java +++ b/services/appwidget/java/com/android/server/appwidget/AppWidgetServiceImpl.java @@ -460,12 +460,9 @@ class AppWidgetServiceImpl extends IAppWidgetService.Stub implements WidgetBacku } synchronized (mLock) { reloadWidgetsMaskedState(userId); - List<UserInfo> profiles = mUserManager.getEnabledProfiles(userId); - if (profiles != null) { - for (int i = 0; i < profiles.size(); i++) { - UserInfo user = profiles.get(i); - reloadWidgetsMaskedState(user.id); - } + int[] profileIds = mUserManager.getEnabledProfileIds(userId); + for (int profileId : profileIds) { + reloadWidgetsMaskedState(profileId); } } } @@ -3458,33 +3455,12 @@ class AppWidgetServiceImpl extends IAppWidgetService.Stub implements WidgetBacku public int[] getEnabledGroupProfileIds(int userId) { final int parentId = getGroupParent(userId); - final List<UserInfo> profiles; final long identity = Binder.clearCallingIdentity(); try { - profiles = mUserManager.getProfiles(parentId); + return mUserManager.getEnabledProfileIds(parentId); } finally { Binder.restoreCallingIdentity(identity); } - - int enabledProfileCount = 0; - final int profileCount = profiles.size(); - for (int i = 0; i < profileCount; i++) { - if (profiles.get(i).isEnabled()) { - enabledProfileCount++; - } - } - - int enabledProfileIndex = 0; - final int[] profileIds = new int[enabledProfileCount]; - for (int i = 0; i < profileCount; i++) { - UserInfo profile = profiles.get(i); - if (profile.isEnabled()) { - profileIds[enabledProfileIndex] = profile.getUserHandle().getIdentifier(); - enabledProfileIndex++; - } - } - - return profileIds; } public void enforceServiceExistsAndRequiresBindRemoteViewsPermission( |