pull/1835/head
kunfei 3 years ago
parent 429945f731
commit 00a4846829
  1. 14
      app/src/main/java/io/legado/app/utils/RegexExtensions.kt

@ -2,15 +2,11 @@ package io.legado.app.utils
import io.legado.app.exception.RegexTimeoutException
import io.legado.app.help.CrashHandler
import kotlinx.coroutines.Dispatchers.IO
import kotlinx.coroutines.MainScope
import kotlinx.coroutines.launch
import kotlinx.coroutines.suspendCancellableCoroutine
import splitties.init.appCtx
import kotlin.concurrent.thread
import kotlin.coroutines.resume
private val scope = MainScope()
/**
* 带有超时检测的正则替换
* 超时重启apk,线程不能强制结束,只能重启apk
@ -18,7 +14,7 @@ private val scope = MainScope()
suspend fun CharSequence.replace(regex: Regex, replacement: String, timeout: Long): String {
val charSequence = this
return suspendCancellableCoroutine { block ->
val job = scope.launch(IO) {
val thread = thread {
try {
val result = regex.replace(charSequence, replacement)
block.resume(result)
@ -27,14 +23,16 @@ suspend fun CharSequence.replace(regex: Regex, replacement: String, timeout: Lon
}
}
mainHandler.postDelayed({
if (job.isActive) {
val timeoutMsg = "替换超时,将在3秒后重启应用\n替换规则$regex\n替换内容:${this}"
if (thread.isAlive) {
val timeoutMsg = "替换超时,3秒后还未结束将重启应用\n替换规则$regex\n替换内容:${this}"
val exception = RegexTimeoutException(timeoutMsg)
block.cancel(exception)
appCtx.longToastOnUi(timeoutMsg)
CrashHandler.saveCrashInfo2File(exception)
mainHandler.postDelayed({
if (thread.isAlive) {
appCtx.restart()
}
}, 3000)
}
}, timeout)

Loading…
Cancel
Save