Filter exceptions reporting via ACRA
This commit is contained in:
@@ -138,6 +138,8 @@ dependencies {
|
|||||||
|
|
||||||
implementation 'ch.acra:acra-http:5.11.3'
|
implementation 'ch.acra:acra-http:5.11.3'
|
||||||
implementation 'ch.acra:acra-dialog:5.11.3'
|
implementation 'ch.acra:acra-dialog:5.11.3'
|
||||||
|
compileOnly 'com.google.auto.service:auto-service-annotations:1.1.1'
|
||||||
|
ksp 'dev.zacsweers.autoservice:auto-service-ksp:1.1.0'
|
||||||
|
|
||||||
debugImplementation 'com.squareup.leakcanary:leakcanary-android:2.12'
|
debugImplementation 'com.squareup.leakcanary:leakcanary-android:2.12'
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,24 @@
|
|||||||
|
package org.koitharu.kotatsu.core
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import com.google.auto.service.AutoService
|
||||||
|
import org.acra.builder.ReportBuilder
|
||||||
|
import org.acra.config.CoreConfiguration
|
||||||
|
import org.acra.config.ReportingAdministrator
|
||||||
|
|
||||||
|
@AutoService(ReportingAdministrator::class)
|
||||||
|
class ErrorReportingAdmin : ReportingAdministrator {
|
||||||
|
|
||||||
|
override fun shouldStartCollecting(
|
||||||
|
context: Context,
|
||||||
|
config: CoreConfiguration,
|
||||||
|
reportBuilder: ReportBuilder
|
||||||
|
): Boolean {
|
||||||
|
return reportBuilder.exception?.isDeadOs() != true
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun Throwable.isDeadOs(): Boolean {
|
||||||
|
val className = javaClass.simpleName
|
||||||
|
return className == "DeadSystemException" || className == "DeadSystemRuntimeException" || cause?.isDeadOs() == true
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user