mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-11 02:50:15 +08:00
Introduce JPluginConfig for Java callers, update docs
This commit is contained in:
parent
c821f9e9e9
commit
91e30377fc
@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2020 Mamoe Technologies and contributors.
|
||||||
|
*
|
||||||
|
* 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
|
||||||
|
* Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
|
||||||
|
*
|
||||||
|
* https://github.com/mamoe/mirai/blob/master/LICENSE
|
||||||
|
*/
|
||||||
|
|
||||||
|
package net.mamoe.mirai.console.data
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 一个插件的配置数据, 用于和用户交互.
|
||||||
|
*
|
||||||
|
* 用户可通过 mirai-console 前端 (如在 Android 中可视化实现) 修改这些配置, 修改会自动写入这个对象中.
|
||||||
|
*
|
||||||
|
* **提示**:
|
||||||
|
* 插件内部的数据应用 [PluginData] 存储, 而不能使用 [PluginConfig].
|
||||||
|
*
|
||||||
|
* ### 实现
|
||||||
|
*
|
||||||
|
* 在 [JPluginData] 的示例基础上, 修改类定义
|
||||||
|
* ```java
|
||||||
|
* // 原
|
||||||
|
* public class AccountPluginData extends JPluginData {
|
||||||
|
* // 修改为
|
||||||
|
* public class AccountPluginConfig extends JPluginConfig {
|
||||||
|
* ```
|
||||||
|
* 即可将一个 [PluginData] 变更为 [PluginConfig].
|
||||||
|
*
|
||||||
|
* @see JPluginData
|
||||||
|
* @see PluginConfig
|
||||||
|
*/
|
||||||
|
public abstract class JPluginConfig(delegate: PluginData) : JPluginData(delegate), PluginConfig
|
@ -19,6 +19,24 @@ import kotlin.annotation.AnnotationTarget.*
|
|||||||
*
|
*
|
||||||
* **提示**:
|
* **提示**:
|
||||||
* 插件内部的数据应用 [PluginData] 存储, 而不能使用 [PluginConfig].
|
* 插件内部的数据应用 [PluginData] 存储, 而不能使用 [PluginConfig].
|
||||||
|
*
|
||||||
|
* ## 实现
|
||||||
|
* 对使用者来说, [PluginConfig] 与 [PluginData] 实现几乎相同. 目前仅需在 [PluginData] 使用的基础上添加接口实现即可.
|
||||||
|
*
|
||||||
|
* ### Kotlin
|
||||||
|
* 在 [PluginData] 的示例基础上, 修改对象定义
|
||||||
|
* ```
|
||||||
|
* // 原
|
||||||
|
* object MyPluginData : PluginData by PluginMain.loadPluginData()
|
||||||
|
* // 修改为
|
||||||
|
* object MyPluginConfig : PluginConfig by PluginMain.loadPluginConfig()
|
||||||
|
* ```
|
||||||
|
* 即可将一个 [PluginData] 变更为 [PluginConfig].
|
||||||
|
*
|
||||||
|
* ### Java
|
||||||
|
* 见 [JPluginConfig]
|
||||||
|
*
|
||||||
|
* @see PluginData
|
||||||
*/
|
*/
|
||||||
@ExperimentalPluginConfig
|
@ExperimentalPluginConfig
|
||||||
public interface PluginConfig : PluginData
|
public interface PluginConfig : PluginData
|
||||||
|
@ -47,10 +47,11 @@ import kotlin.reflect.KType
|
|||||||
* ```
|
* ```
|
||||||
* object PluginMain : KotlinPlugin()
|
* object PluginMain : KotlinPlugin()
|
||||||
*
|
*
|
||||||
* object AccountPluginData : PluginData by PluginMain.loadPluginData() {
|
* object MyPluginData : PluginData by PluginMain.loadPluginData() {
|
||||||
* val list: MutableList<String> by value(mutableListOf("a", "b")) // mutableListOf("a", "b") 是初始值, 可以省略
|
* val list: MutableList<String> by value(mutableListOf("a", "b")) // mutableListOf("a", "b") 是初始值, 可以省略
|
||||||
* val custom: Map<Long, CustomData> by value() // 使用 kotlinx-serialization 序列化的类型. (目前还不支持)
|
* val custom: Map<Long, CustomData> by value() // 使用 kotlinx-serialization 序列化的类型. (目前还不支持)
|
||||||
* var custom2: CustomData by value() // 允许 var
|
* var long: Long by value(0) // 允许 var
|
||||||
|
* var int by value(0) // 可以使用类型推断, 但更推荐使用 `var long: Long by value(0)` 这种定义方式.
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* @Serializable
|
* @Serializable
|
||||||
|
@ -16,9 +16,9 @@ import net.mamoe.mirai.console.data.PluginData
|
|||||||
import net.mamoe.mirai.console.data.SerializableValue.Companion.serializableValueWith
|
import net.mamoe.mirai.console.data.SerializableValue.Companion.serializableValueWith
|
||||||
import net.mamoe.mirai.console.data.SerializerAwareValue
|
import net.mamoe.mirai.console.data.SerializerAwareValue
|
||||||
import net.mamoe.mirai.console.data.valueFromKType
|
import net.mamoe.mirai.console.data.valueFromKType
|
||||||
|
import net.mamoe.mirai.console.internal.command.qualifiedNameOrTip
|
||||||
import kotlin.reflect.KClass
|
import kotlin.reflect.KClass
|
||||||
import kotlin.reflect.KType
|
import kotlin.reflect.KType
|
||||||
import kotlin.reflect.full.createInstance as createInstanceKotlin
|
|
||||||
|
|
||||||
private val primitiveCollectionsImplemented by lazy {
|
private val primitiveCollectionsImplemented by lazy {
|
||||||
false
|
false
|
||||||
@ -101,24 +101,36 @@ internal fun PluginData.valueFromKTypeImpl(type: KType): SerializerAwareValue<*>
|
|||||||
|
|
||||||
internal fun KClass<*>.createInstanceSmart(): Any? {
|
internal fun KClass<*>.createInstanceSmart(): Any? {
|
||||||
return when (this) {
|
return when (this) {
|
||||||
|
Byte::class -> 0.toByte()
|
||||||
|
Short::class -> 0.toShort()
|
||||||
|
Int::class -> 0
|
||||||
|
Long::class -> 0L
|
||||||
|
Float::class -> 0.toFloat()
|
||||||
|
Double::class -> 0.0
|
||||||
|
|
||||||
|
Boolean::class -> false
|
||||||
|
|
||||||
|
String::class -> ""
|
||||||
|
|
||||||
MutableMap::class,
|
MutableMap::class,
|
||||||
Map::class,
|
Map::class,
|
||||||
LinkedHashMap::class,
|
LinkedHashMap::class,
|
||||||
HashMap::class
|
HashMap::class
|
||||||
-> mutableMapOf<Any?, Any?>()
|
-> LinkedHashMap<Any?, Any?>()
|
||||||
|
|
||||||
MutableList::class,
|
MutableList::class,
|
||||||
List::class,
|
List::class,
|
||||||
ArrayList::class
|
ArrayList::class
|
||||||
-> mutableListOf<Any?>()
|
-> ArrayList<Any?>()
|
||||||
|
|
||||||
MutableSet::class,
|
MutableSet::class,
|
||||||
Set::class,
|
Set::class,
|
||||||
LinkedHashSet::class,
|
LinkedHashSet::class,
|
||||||
HashSet::class
|
HashSet::class
|
||||||
-> mutableSetOf<Any?>()
|
-> LinkedHashSet<Any?>()
|
||||||
|
|
||||||
else -> createInstanceKotlin()
|
else -> createInstanceOrNull()
|
||||||
|
?: error("Cannot create instance or find a initial value for ${this.qualifiedNameOrTip}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user