From 0ba0adf825bd5f7e5d09472ce9c77d634b9714cd Mon Sep 17 00:00:00 2001 From: darken Date: Sun, 24 Sep 2023 21:28:23 +0200 Subject: [PATCH] "pidof" based activity check is kinda slow. Elevated pkgops access can use `runningAppProcesses` which gets us the same info, but faster. --- .../common/pkgs/pkgops/ipc/PkgOpsHost.kt | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/app-common-io/src/main/java/eu/darken/sdmse/common/pkgs/pkgops/ipc/PkgOpsHost.kt b/app-common-io/src/main/java/eu/darken/sdmse/common/pkgs/pkgops/ipc/PkgOpsHost.kt index 31584697d..e3e318880 100644 --- a/app-common-io/src/main/java/eu/darken/sdmse/common/pkgs/pkgops/ipc/PkgOpsHost.kt +++ b/app-common-io/src/main/java/eu/darken/sdmse/common/pkgs/pkgops/ipc/PkgOpsHost.kt @@ -9,6 +9,7 @@ import eu.darken.rxshell.cmd.Cmd import eu.darken.sdmse.common.debug.Bugs import eu.darken.sdmse.common.debug.logging.Logging.Priority.ERROR import eu.darken.sdmse.common.debug.logging.Logging.Priority.VERBOSE +import eu.darken.sdmse.common.debug.logging.asLog import eu.darken.sdmse.common.debug.logging.log import eu.darken.sdmse.common.debug.logging.logTag import eu.darken.sdmse.common.ipc.IpcHostModule @@ -33,6 +34,9 @@ class PkgOpsHost @Inject constructor( private val pm: PackageManager get() = context.packageManager + private val am: ActivityManager + get() = context.getSystemService(Context.ACTIVITY_SERVICE) as ActivityManager + override fun getUserNameForUID(uid: Int): String? = try { libcoreTool.getNameForUid(uid) } catch (e: Exception) { @@ -48,10 +52,19 @@ class PkgOpsHost @Inject constructor( } override fun isRunning(packageName: String): Boolean = try { - val result = runBlocking { - sharedShell.useRes { - Cmd.builder("pidof $packageName").execute(it) - }.exitCode == Cmd.ExitCode.OK + val result = try { + val runningAppProcesses = am.runningAppProcesses + ?.flatMap { it.pkgList.toList() } + ?.distinct() + ?: emptyList() + runningAppProcesses.any { it == packageName } + } catch (e: Exception) { + log(TAG, ERROR) { "isRunning($packageName): runningAppProcesses failed due to ${e.asLog()} " } + runBlocking { + sharedShell.useRes { + Cmd.builder("pidof $packageName").execute(it) + }.exitCode == Cmd.ExitCode.OK + } } log(TAG, VERBOSE) { "isRunning(packageName=$packageName)=$result" } result