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

Commit c72ce752 authored by Mårten Kongstad's avatar Mårten Kongstad Committed by Ryan Mitchell
Browse files

Revert "Revert "OMS: block until settings are persisted""

This reverts commit b8c651c9.

Change-Id: Ie02ddd3710395c3c53ca3604076c5f34c73b8387
parent d7074e1c
Loading
Loading
Loading
Loading
+20 −26
Original line number Diff line number Diff line
@@ -50,6 +50,7 @@ import android.content.res.ApkAssets;
import android.net.Uri;
import android.os.Binder;
import android.os.Environment;
import android.os.HandlerThread;
import android.os.IBinder;
import android.os.RemoteException;
import android.os.ResultReceiver;
@@ -66,7 +67,6 @@ import android.util.SparseArray;

import com.android.internal.content.om.OverlayConfig;
import com.android.server.FgThread;
import com.android.server.IoThread;
import com.android.server.LocalServices;
import com.android.server.SystemConfig;
import com.android.server.SystemService;
@@ -89,7 +89,6 @@ import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.function.Consumer;

/**
@@ -239,8 +238,6 @@ public final class OverlayManagerService extends SystemService {

    private final OverlayActorEnforcer mActorEnforcer;

    private final AtomicBoolean mPersistSettingsScheduled = new AtomicBoolean(false);

    private final Consumer<PackageAndUser> mOnOverlaysChanged = (pair) -> {
        onOverlaysChanged(pair.packageName, pair.userId);
    };
@@ -259,13 +256,16 @@ public final class OverlayManagerService extends SystemService {
                    OverlayConfig.getSystemInstance(), getDefaultOverlayPackages());
            mActorEnforcer = new OverlayActorEnforcer(mPackageManager);

            HandlerThread packageReceiverThread = new HandlerThread(TAG);
            packageReceiverThread.start();

            final IntentFilter packageFilter = new IntentFilter();
            packageFilter.addAction(ACTION_PACKAGE_ADDED);
            packageFilter.addAction(ACTION_PACKAGE_CHANGED);
            packageFilter.addAction(ACTION_PACKAGE_REMOVED);
            packageFilter.addDataScheme("package");
            getContext().registerReceiverAsUser(new PackageReceiver(), UserHandle.ALL,
                    packageFilter, null, null);
                    packageFilter, null, packageReceiverThread.getThreadHandler());

            final IntentFilter userFilter = new IntentFilter();
            userFilter.addAction(ACTION_USER_ADDED);
@@ -318,7 +318,7 @@ public final class OverlayManagerService extends SystemService {
                final List<String> targets = mImpl.updateOverlaysForUser(newUserId);
                updateAssets(newUserId, targets);
            }
            schedulePersistSettings();
            persistSettings();
        } finally {
            traceEnd(TRACE_TAG_RRO);
        }
@@ -973,7 +973,7 @@ public final class OverlayManagerService extends SystemService {
    };

    private void onOverlaysChanged(@NonNull final String targetPackageName, final int userId) {
        schedulePersistSettings();
        persistSettings();
        FgThread.getHandler().post(() -> {
            updateAssets(userId, targetPackageName);

@@ -1065,12 +1065,7 @@ public final class OverlayManagerService extends SystemService {
        }
    }

    private void schedulePersistSettings() {
        if (mPersistSettingsScheduled.getAndSet(true)) {
            return;
        }
        IoThread.getHandler().post(() -> {
            mPersistSettingsScheduled.set(false);
    private void persistSettings() {
        if (DEBUG) {
            Slog.d(TAG, "Writing overlay settings");
        }
@@ -1085,7 +1080,6 @@ public final class OverlayManagerService extends SystemService {
                Slog.e(TAG, "failed to persist overlay state", e);
            }
        }
        });
    }

    private void restoreSettings() {