diff --git a/app/src/main/java/io/legado/app/model/analyzeRule/AnalyzeRule.kt b/app/src/main/java/io/legado/app/model/analyzeRule/AnalyzeRule.kt index df7e31480..237ecb381 100644 --- a/app/src/main/java/io/legado/app/model/analyzeRule/AnalyzeRule.kt +++ b/app/src/main/java/io/legado/app/model/analyzeRule/AnalyzeRule.kt @@ -77,6 +77,7 @@ class AnalyzeRule( private val regexCache = hashMapOf() private val scriptCache = hashMapOf() private var topScopeRef: WeakReference? = null + private var evalJSCallCount = 0 private var coroutineContext: CoroutineContext = EmptyCoroutineContext @@ -781,7 +782,9 @@ class AnalyzeRule( val topScope = source?.getShareScope(coroutineContext) ?: topScopeRef?.get() val scope = if (topScope == null) { RhinoScriptEngine.getRuntimeScope(bindings).apply { - topScopeRef = WeakReference(prototype) + if (evalJSCallCount++ > 16) { + topScopeRef = WeakReference(prototype) + } } } else { bindings.apply {