mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-25 07:30:14 +08:00
plugin API fixed
This commit is contained in:
parent
66b9e59634
commit
d411df85ca
@ -83,7 +83,11 @@ abstract class PluginBase
|
|||||||
@JvmOverloads
|
@JvmOverloads
|
||||||
internal fun disable(throwable: CancellationException? = null) {
|
internal fun disable(throwable: CancellationException? = null) {
|
||||||
this.coroutineContext[Job]!!.cancelChildren(throwable)
|
this.coroutineContext[Job]!!.cancelChildren(throwable)
|
||||||
|
try {
|
||||||
this.onDisable()
|
this.onDisable()
|
||||||
|
}catch (e:Exception){
|
||||||
|
logger.info(e)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal var pluginName: String = ""
|
internal var pluginName: String = ""
|
||||||
|
@ -42,7 +42,11 @@ object PluginManager {
|
|||||||
|
|
||||||
fun onCommand(command: Command, sender: CommandSender, args: List<String>) {
|
fun onCommand(command: Command, sender: CommandSender, args: List<String>) {
|
||||||
nameToPluginBaseMap.values.forEach {
|
nameToPluginBaseMap.values.forEach {
|
||||||
|
try {
|
||||||
it.onCommand(command, sender, args)
|
it.onCommand(command, sender, args)
|
||||||
|
}catch (e:Exception){
|
||||||
|
logger.info(e)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -194,7 +198,27 @@ object PluginManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
nameToPluginBaseMap.values.forEach {
|
nameToPluginBaseMap.values.forEach {
|
||||||
|
try {
|
||||||
|
it.onLoad()
|
||||||
|
}catch (ignored:Exception){
|
||||||
|
if(ignored is CancellationException) {
|
||||||
|
logger.info(ignored)
|
||||||
|
logger.info(it.pluginName + "Failed to load, disabling it")
|
||||||
|
it.disable(ignored)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
nameToPluginBaseMap.values.forEach {
|
||||||
|
try {
|
||||||
it.enable()
|
it.enable()
|
||||||
|
}catch (ignored:Exception){
|
||||||
|
logger.info(ignored)
|
||||||
|
logger.info(it.pluginName + "Failed to enable, disabling it")
|
||||||
|
if(ignored is CancellationException) {
|
||||||
|
it.disable(ignored)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("""加载了${nameToPluginBaseMap.size}个插件""")
|
logger.info("""加载了${nameToPluginBaseMap.size}个插件""")
|
||||||
@ -213,7 +237,7 @@ object PluginManager {
|
|||||||
* 根据插件名字找Jar的文件
|
* 根据插件名字找Jar的文件
|
||||||
* null => 没找到
|
* null => 没找到
|
||||||
*/
|
*/
|
||||||
fun getJarPath(pluginName: String): File? {
|
fun getJarFileByName(pluginName: String): File? {
|
||||||
File(pluginsPath).listFiles()?.forEach { file ->
|
File(pluginsPath).listFiles()?.forEach { file ->
|
||||||
if (file != null && file.extension == "jar") {
|
if (file != null && file.extension == "jar") {
|
||||||
val jar = JarFile(file)
|
val jar = JarFile(file)
|
||||||
@ -240,7 +264,7 @@ object PluginManager {
|
|||||||
* null => 没找到
|
* null => 没找到
|
||||||
*/
|
*/
|
||||||
fun getFileInJarByName(pluginName: String, toFind: String): InputStream? {
|
fun getFileInJarByName(pluginName: String, toFind: String): InputStream? {
|
||||||
val jarFile = getJarPath(pluginName) ?: return null
|
val jarFile = getJarFileByName(pluginName) ?: return null
|
||||||
val jar = JarFile(jarFile)
|
val jar = JarFile(jarFile)
|
||||||
val toFindFile =
|
val toFindFile =
|
||||||
jar.entries().asSequence().filter { it.name == toFind }.firstOrNull() ?: return null
|
jar.entries().asSequence().filter { it.name == toFind }.firstOrNull() ?: return null
|
||||||
|
Loading…
Reference in New Issue
Block a user