mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-25 23:50:15 +08:00
Improve plugin enabling and disabling
This commit is contained in:
parent
d2b7421df7
commit
9cc05f682b
@ -110,7 +110,7 @@ internal object JarPluginLoaderImpl :
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun enable(plugin: JvmPlugin) {
|
override fun enable(plugin: JvmPlugin) {
|
||||||
if (plugin.isEnabled) throw IllegalStateException("Plugin is already enabled")
|
if (plugin.isEnabled) return
|
||||||
ensureActive()
|
ensureActive()
|
||||||
if (plugin is JvmPluginInternal) {
|
if (plugin is JvmPluginInternal) {
|
||||||
plugin.internalOnEnable()
|
plugin.internalOnEnable()
|
||||||
@ -118,7 +118,7 @@ internal object JarPluginLoaderImpl :
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun disable(plugin: JvmPlugin) {
|
override fun disable(plugin: JvmPlugin) {
|
||||||
if (!plugin.isEnabled) throw IllegalStateException("Plugin is already disabled")
|
if (!plugin.isEnabled) return
|
||||||
|
|
||||||
if (plugin is JvmPluginInternal) {
|
if (plugin is JvmPluginInternal) {
|
||||||
plugin.internalOnDisable()
|
plugin.internalOnDisable()
|
||||||
|
@ -38,8 +38,7 @@ internal abstract class JvmPluginInternal(
|
|||||||
) : JvmPlugin,
|
) : JvmPlugin,
|
||||||
CoroutineScope {
|
CoroutineScope {
|
||||||
|
|
||||||
override val isEnabled: Boolean
|
override var isEnabled: Boolean = false
|
||||||
get() = job.isActive
|
|
||||||
|
|
||||||
private val resourceContainerDelegate by lazy { this::class.java.classLoader.asResourceContainer() }
|
private val resourceContainerDelegate by lazy { this::class.java.classLoader.asResourceContainer() }
|
||||||
override fun getResourceAsStream(path: String): InputStream? = resourceContainerDelegate.getResourceAsStream(path)
|
override fun getResourceAsStream(path: String): InputStream? = resourceContainerDelegate.getResourceAsStream(path)
|
||||||
@ -77,6 +76,7 @@ internal abstract class JvmPluginInternal(
|
|||||||
cancel(CancellationException("Exception while enabling plugin", it))
|
cancel(CancellationException("Exception while enabling plugin", it))
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
isEnabled = false
|
||||||
}
|
}
|
||||||
|
|
||||||
@Throws(Throwable::class)
|
@Throws(Throwable::class)
|
||||||
@ -90,6 +90,7 @@ internal abstract class JvmPluginInternal(
|
|||||||
onEnable()
|
onEnable()
|
||||||
}.fold(
|
}.fold(
|
||||||
onSuccess = {
|
onSuccess = {
|
||||||
|
isEnabled = true
|
||||||
return true
|
return true
|
||||||
},
|
},
|
||||||
onFailure = {
|
onFailure = {
|
||||||
@ -121,7 +122,7 @@ internal abstract class JvmPluginInternal(
|
|||||||
job.invokeOnCompletion { e ->
|
job.invokeOnCompletion { e ->
|
||||||
if (e != null) {
|
if (e != null) {
|
||||||
logger.error(e)
|
logger.error(e)
|
||||||
safeLoader.disable(this)
|
if (this.isEnabled) safeLoader.disable(this)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
|
|
||||||
package net.mamoe.mirai.console.plugin
|
package net.mamoe.mirai.console.plugin
|
||||||
|
|
||||||
|
import net.mamoe.mirai.console.plugin.PluginManager.INSTANCE.disable
|
||||||
|
import net.mamoe.mirai.console.plugin.PluginManager.INSTANCE.enable
|
||||||
import net.mamoe.mirai.console.plugin.PluginManager.INSTANCE.register
|
import net.mamoe.mirai.console.plugin.PluginManager.INSTANCE.register
|
||||||
import net.mamoe.mirai.console.plugin.dsecription.PluginDescription
|
import net.mamoe.mirai.console.plugin.dsecription.PluginDescription
|
||||||
import net.mamoe.mirai.console.plugin.jvm.JarPluginLoader
|
import net.mamoe.mirai.console.plugin.jvm.JarPluginLoader
|
||||||
@ -75,8 +77,9 @@ public interface PluginLoader<P : Plugin, D : PluginDescription> {
|
|||||||
* **实现细节**: 此函数可抛出 [PluginLoadException] 作为正常失败原因, 其他任意异常都属于意外错误.
|
* **实现细节**: 此函数可抛出 [PluginLoadException] 作为正常失败原因, 其他任意异常都属于意外错误.
|
||||||
* 当异常发生时, 插件将会直接被放弃加载, 并影响依赖它的其他插件.
|
* 当异常发生时, 插件将会直接被放弃加载, 并影响依赖它的其他插件.
|
||||||
*
|
*
|
||||||
* @throws IllegalStateException 当插件已经启用时抛出
|
|
||||||
* @throws PluginLoadException 在加载插件遇到意料之中的错误时抛出 (如找不到主类等).
|
* @throws PluginLoadException 在加载插件遇到意料之中的错误时抛出 (如找不到主类等).
|
||||||
|
*
|
||||||
|
* @see PluginManager.enable
|
||||||
*/
|
*/
|
||||||
@Throws(IllegalStateException::class, PluginLoadException::class)
|
@Throws(IllegalStateException::class, PluginLoadException::class)
|
||||||
public fun enable(plugin: P)
|
public fun enable(plugin: P)
|
||||||
@ -87,8 +90,9 @@ public interface PluginLoader<P : Plugin, D : PluginDescription> {
|
|||||||
* **实现细节**: 此函数可抛出 [PluginLoadException] 作为正常失败原因, 其他任意异常都属于意外错误.
|
* **实现细节**: 此函数可抛出 [PluginLoadException] 作为正常失败原因, 其他任意异常都属于意外错误.
|
||||||
* 当异常发生时, 插件将会直接被放弃加载, 并影响依赖它的其他插件.
|
* 当异常发生时, 插件将会直接被放弃加载, 并影响依赖它的其他插件.
|
||||||
*
|
*
|
||||||
* @throws IllegalStateException 当插件已经禁用时抛出
|
|
||||||
* @throws PluginLoadException 在加载插件遇到意料之中的错误时抛出 (如找不到主类等).
|
* @throws PluginLoadException 在加载插件遇到意料之中的错误时抛出 (如找不到主类等).
|
||||||
|
*
|
||||||
|
* @see PluginManager.disable
|
||||||
*/
|
*/
|
||||||
@Throws(IllegalStateException::class, PluginLoadException::class)
|
@Throws(IllegalStateException::class, PluginLoadException::class)
|
||||||
public fun disable(plugin: P)
|
public fun disable(plugin: P)
|
||||||
|
Loading…
Reference in New Issue
Block a user