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

Commit f803a67b authored by Patrick Baumann's avatar Patrick Baumann Committed by android-build-merger
Browse files

Merge "Handles pre-process failure without crashing system" into qt-dev

am: b8735359

Change-Id: Ie3216c5918d423c23f0414fe8f9c1c62b1e7d0bb
parents b56c5bc3 b8735359
Loading
Loading
Loading
Loading
+6 −4
Original line number Diff line number Diff line
@@ -15032,24 +15032,26 @@ public class PackageManagerService extends IPackageManager.Stub
        void tryProcessInstallRequest(InstallArgs args, int currentStatus) {
            mCurrentState.put(args, currentStatus);
            boolean success = true;
            if (mCurrentState.size() != mChildParams.size()) {
                return;
            }
            int completeStatus = PackageManager.INSTALL_SUCCEEDED;
            for (Integer status : mCurrentState.values()) {
                if (status == PackageManager.INSTALL_UNKNOWN) {
                    return;
                } else if (status != PackageManager.INSTALL_SUCCEEDED) {
                    success = false;
                    completeStatus = status;
                    break;
                }
            }
            final List<InstallRequest> installRequests = new ArrayList<>(mCurrentState.size());
            for (Map.Entry<InstallArgs, Integer> entry : mCurrentState.entrySet()) {
                installRequests.add(new InstallRequest(entry.getKey(),
                        createPackageInstalledInfo(entry.getValue())));
                        createPackageInstalledInfo(completeStatus)));
            }
            processInstallRequestsAsync(success, installRequests);
            processInstallRequestsAsync(
                    completeStatus == PackageManager.INSTALL_SUCCEEDED,
                    installRequests);
        }
    }