From 6e7de8747c78a04fcb5f6cf92bc789feb84c95fe Mon Sep 17 00:00:00 2001 From: Him188 Date: Tue, 1 Dec 2020 10:25:28 +0800 Subject: [PATCH] Allow optional 'name' property for plugin.yml --- .../src/plugin/jvm/JvmPluginDescription.kt | 23 +++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/backend/mirai-console/src/plugin/jvm/JvmPluginDescription.kt b/backend/mirai-console/src/plugin/jvm/JvmPluginDescription.kt index a65d810bb..77009e0c4 100644 --- a/backend/mirai-console/src/plugin/jvm/JvmPluginDescription.kt +++ b/backend/mirai-console/src/plugin/jvm/JvmPluginDescription.kt @@ -52,7 +52,7 @@ public interface JvmPluginDescription : PluginDescription { val bytes = stream.use { it.readBytes() } - return Yaml.default.decodeFromString(SimpleJvmPluginDescription.serializer(), String(bytes)) + return Yaml.default.decodeFromString(SimpleJvmPluginDescription.SerialData.serializer(), String(bytes)).toJvmPluginDescription() } } } @@ -218,7 +218,7 @@ public class JvmPluginDescriptionBuilder( * * @see JvmPluginDescription */ -@Serializable // Keep this file in public API files. Might turn to `public` in the future. +// @Serializable // Keep this file in public API files. Might turn to `public` in the future. internal data class SimpleJvmPluginDescription @JvmOverloads constructor( override val id: String, @@ -243,4 +243,23 @@ internal data class SimpleJvmPluginDescription init { PluginDescription.checkPluginDescription(this) } + + @Serializable // Keep this file in public API files. Might turn to `public` in the future. + internal data class SerialData + @JvmOverloads constructor( + val id: String, + val name: String? = null, // workaround to ktx-serialization bug + val version: SemVersion, + val author: String = "", + val info: String = "", + val dependencies: Set = setOf(), + ) { + fun toJvmPluginDescription(): JvmPluginDescription { + return SimpleJvmPluginDescription( + id, + name ?: id, + version, author, info, dependencies + ) + } + } } \ No newline at end of file