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

48 lines
1.7 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
2020-03-01 17:10:55 +08:00
import net.mamoe.mirai.data.AddFriendResult
2020-03-01 16:55:58 +08:00
import net.mamoe.mirai.message.data.Image
import net.mamoe.mirai.message.data.MessageSource
2020-03-01 17:10:55 +08:00
import net.mamoe.mirai.utils.MiraiInternalAPI
2020-03-01 16:55:58 +08:00
import kotlin.jvm.JvmName
2020-03-01 17:10:55 +08:00
import kotlin.jvm.JvmOverloads
2020-03-01 16:55:58 +08:00
/**
* 表明这个 API 是为了让 Java 使用者调用更方便.
*/
2020-03-01 17:10:55 +08:00
@MiraiInternalAPI
2020-03-01 16:55:58 +08:00
@Experimental(level = Experimental.Level.ERROR)
@Target(AnnotationTarget.PROPERTY, AnnotationTarget.FUNCTION, AnnotationTarget.TYPE)
annotation class JavaHappyAPI
/**
* [Bot] 中为了让 Java 使用者调用更方便的 API 列表.
2020-03-01 17:10:55 +08:00
*/ // TODO: 2020/3/1 待 https://youtrack.jetbrains.com/issue/KT-36740 修复后添加 Future 相关 API.
@MiraiInternalAPI
2020-03-01 16:55:58 +08:00
@Suppress("FunctionName", "INAPPLICABLE_JVM_NAME", "unused")
2020-03-01 17:10:55 +08:00
expect abstract class BotJavaHappyAPI() { // 不要使用 interface, 会无法添加默认实现
@JvmName("join")
open fun __joinBlockingForJava__()
2020-03-01 16:55:58 +08:00
@JvmName("login")
open fun __loginBlockingForJava__()
@JvmName("recall")
open fun __recallBlockingForJava__(source: MessageSource)
@JvmName("queryImageUrl")
2020-03-01 17:10:55 +08:00
open fun __queryImageUrlBlockingForJava__(image: Image): String
@JvmName("addFriend")
@JvmOverloads
open fun __addFriendBlockingForJava__(id: Long, message: String? = null, remark: String? = null): AddFriendResult
2020-03-01 16:55:58 +08:00
}