Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c4666416 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Handle object in thread-safe manner."

parents eb803fd5 0288bcb4
Loading
Loading
Loading
Loading
+8 −5
Original line number Diff line number Diff line
@@ -233,6 +233,7 @@ public class UsageStatsService extends SystemService implements
    final SparseArray<ActivityData> mVisibleActivities = new SparseArray();
    @GuardedBy("mLock")
    private final SparseArray<LaunchTimeAlarmQueue> mLaunchTimeAlarmQueues = new SparseArray<>();
    @GuardedBy("mUsageEventListeners") // Don't hold the main lock when calling out
    private final ArraySet<UsageStatsManagerInternal.UsageEventListener> mUsageEventListeners =
            new ArraySet<>();
    private final CopyOnWriteArraySet<UsageStatsManagerInternal.EstimatedLaunchTimeChangedListener>
@@ -1189,11 +1190,13 @@ public class UsageStatsService extends SystemService implements
            service.reportEvent(event);
        }

        synchronized (mUsageEventListeners) {
            final int size = mUsageEventListeners.size();
            for (int i = 0; i < size; ++i) {
                mUsageEventListeners.valueAt(i).onUsageEvent(userId, event);
            }
        }
    }

    private String getUsageSourcePackage(Event event) {
        switch(mUsageSource) {
@@ -1682,7 +1685,7 @@ public class UsageStatsService extends SystemService implements
     * Called via the local interface.
     */
    private void registerListener(@NonNull UsageStatsManagerInternal.UsageEventListener listener) {
        synchronized (mLock) {
        synchronized (mUsageEventListeners) {
            mUsageEventListeners.add(listener);
        }
    }
@@ -1692,7 +1695,7 @@ public class UsageStatsService extends SystemService implements
     */
    private void unregisterListener(
            @NonNull UsageStatsManagerInternal.UsageEventListener listener) {
        synchronized (mLock) {
        synchronized (mUsageEventListeners) {
            mUsageEventListeners.remove(listener);
        }
    }