mirai/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/javaFriendly.kt

32 lines
1.3 KiB
Kotlin
Raw Normal View History

2020-03-01 16:55:58 +08:00
/*
* 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
/**
* 表明这个 API 是为了让 Java 使用者调用更方便.
*
2020-04-10 11:35:05 +08:00
* 一般有一定的性能损失, 且不能在 JVM/Android 以外平台使用. 不要在 Kotlin 调用它.
2020-03-01 16:55:58 +08:00
*/
@RequiresOptIn(level = RequiresOptIn.Level.ERROR)
2020-03-01 20:13:52 +08:00
@Target(AnnotationTarget.PROPERTY, AnnotationTarget.FUNCTION, AnnotationTarget.TYPE, AnnotationTarget.CLASS)
internal annotation class JavaFriendlyAPI
2020-03-01 16:55:58 +08:00
/**
* [Bot] 中为了让 Java 使用者调用更方便的 API 列表.
*
* **注意**: 不应该把这个类作为一个类型, 只应使用其中的方法
*/
2020-03-01 16:55:58 +08:00
@Suppress("FunctionName", "INAPPLICABLE_JVM_NAME", "unused")
internal expect interface BotJavaFriendlyAPI
2020-03-01 16:55:58 +08:00
// 保留多平台结构, 以避免在 Android 和 JVM 都定义这个类
// 待 https://youtrack.jetbrains.com/issue/KT-27801 实现后修改为 hierarchical MPP 架构
2020-03-01 17:10:55 +08:00
// 待 https://youtrack.jetbrains.com/issue/KT-36740 修复后添加 Future 相关 API 到 hierarchical MPP 架构中