Skip to content

Commit

Permalink
fix(log): disable ndk and anr warning message when plugins are excluded
Browse files Browse the repository at this point in the history
  • Loading branch information
YYChen01988 committed Apr 18, 2023
2 parents 95fedbc + 24caf73 commit 26cab4b
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 42 deletions.
3 changes: 0 additions & 3 deletions Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,6 @@ GEM
mime-types-data (~> 3.2015)
mime-types-data (3.2023.0218.1)
multi_test (0.1.2)
nokogiri (1.14.2-arm64-darwin)
racc (~> 1.4)
nokogiri (1.14.2-x86_64-darwin)
racc (~> 1.4)
optimist (3.0.1)
Expand Down Expand Up @@ -121,7 +119,6 @@ GEM
rexml

PLATFORMS
arm64-darwin-22
x86_64-darwin-20

DEPENDENCIES
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ internal class PluginClient(
}

private val plugins: Set<Plugin>

private val ndkPlugin = instantiatePlugin(NDK_PLUGIN, immutableConfig.enabledErrorTypes.ndkCrashes)
private val anrPlugin = instantiatePlugin(ANR_PLUGIN, immutableConfig.enabledErrorTypes.anrs)
private val rnPlugin = instantiatePlugin(RN_PLUGIN, immutableConfig.enabledErrorTypes.unhandledRejections)
Expand All @@ -41,61 +40,59 @@ internal class PluginClient(
logger.d("Plugin '$clz' is not on the classpath - functionality will not be enabled.")
}
null

} catch (exc: Throwable) {
logger.e("Failed to load plugin '$clz'", exc)
null
}
}

fun getNdkPlugin(): Plugin? = ndkPlugin

fun getNdkPlugin(): Plugin? = ndkPlugin

fun loadPlugins(client: Client) {
plugins.forEach { plugin ->
try {
loadPluginInternal(plugin, client)
} catch (exc: Throwable) {
logger.e("Failed to load plugin $plugin, continuing with initialisation.", exc)
fun loadPlugins(client: Client) {
plugins.forEach { plugin ->
try {
loadPluginInternal(plugin, client)
} catch (exc: Throwable) {
logger.e("Failed to load plugin $plugin, continuing with initialisation.", exc)
}
}
}
}

fun setAutoNotify(client: Client, autoNotify: Boolean) {
setAutoDetectAnrs(client, autoNotify)
fun setAutoNotify(client: Client, autoNotify: Boolean) {
setAutoDetectAnrs(client, autoNotify)

if (autoNotify) {
ndkPlugin?.load(client)
} else {
ndkPlugin?.unload()
if (autoNotify) {
ndkPlugin?.load(client)
} else {
ndkPlugin?.unload()
}
}
}

fun setAutoDetectAnrs(client: Client, autoDetectAnrs: Boolean) {
if (autoDetectAnrs) {
anrPlugin?.load(client)
} else {
anrPlugin?.unload()
fun setAutoDetectAnrs(client: Client, autoDetectAnrs: Boolean) {
if (autoDetectAnrs) {
anrPlugin?.load(client)
} else {
anrPlugin?.unload()
}
}
}

fun findPlugin(clz: Class<*>): Plugin? = plugins.find { it.javaClass == clz }
fun findPlugin(clz: Class<*>): Plugin? = plugins.find { it.javaClass == clz }

private fun loadPluginInternal(plugin: Plugin, client: Client) {
val name = plugin.javaClass.name
val errorTypes = immutableConfig.enabledErrorTypes
private fun loadPluginInternal(plugin: Plugin, client: Client) {
val name = plugin.javaClass.name
val errorTypes = immutableConfig.enabledErrorTypes

// only initialize NDK/ANR plugins if automatic detection enabled
if (name == NDK_PLUGIN) {
if (errorTypes.ndkCrashes) {
plugin.load(client)
}
} else if (name == ANR_PLUGIN) {
if (errorTypes.anrs) {
// only initialize NDK/ANR plugins if automatic detection enabled
if (name == NDK_PLUGIN) {
if (errorTypes.ndkCrashes) {
plugin.load(client)
}
} else if (name == ANR_PLUGIN) {
if (errorTypes.anrs) {
plugin.load(client)
}
} else {
plugin.load(client)
}
} else {
plugin.load(client)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,6 @@ open class BaseCrashyActivity : AppCompatActivity() {
anrFromCXX()
showSnackbar()
}

}

override fun onResume() {
Expand Down

0 comments on commit 26cab4b

Please sign in to comment.