mirror of
https://github.com/mamoe/mirai.git
synced 2025-02-09 09:06:59 +08:00
Add shortcuts, fix type issue
This commit is contained in:
parent
45784c01a8
commit
e9591981e6
@ -270,7 +270,7 @@ interface MessageMetadata : SingleMessage {
|
|||||||
*/
|
*/
|
||||||
@SinceMirai("0.34.0")
|
@SinceMirai("0.34.0")
|
||||||
@MiraiExperimentalAPI
|
@MiraiExperimentalAPI
|
||||||
interface ConstrainSingle<M : Message> : MessageMetadata {
|
interface ConstrainSingle<out M : Message> : MessageMetadata {
|
||||||
val key: Message.Key<M>
|
val key: Message.Key<M>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,12 +39,12 @@ import kotlin.jvm.JvmSynthetic
|
|||||||
*/
|
*/
|
||||||
@OptIn(MiraiExperimentalAPI::class)
|
@OptIn(MiraiExperimentalAPI::class)
|
||||||
@SinceMirai("0.33.0")
|
@SinceMirai("0.33.0")
|
||||||
sealed class MessageSource : Message, MessageMetadata, ConstrainSingle<OnlineMessageSource> {
|
sealed class MessageSource : Message, MessageMetadata, ConstrainSingle<MessageSource> {
|
||||||
companion object Key : Message.Key<MessageSource> {
|
companion object Key : Message.Key<MessageSource> {
|
||||||
override val typeName: String get() = "MessageSource"
|
override val typeName: String get() = "MessageSource"
|
||||||
}
|
}
|
||||||
|
|
||||||
final override val key: Message.Key<OnlineMessageSource> get() = OnlineMessageSource
|
final override val key: Message.Key<MessageSource> get() = Key
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 所属 [Bot]
|
* 所属 [Bot]
|
||||||
@ -153,13 +153,6 @@ sealed class OnlineMessageSource : MessageSource() {
|
|||||||
abstract override val target: QQ
|
abstract override val target: QQ
|
||||||
final override val subject: QQ get() = target
|
final override val subject: QQ get() = target
|
||||||
// final override fun toString(): String = "OnlineMessageSource.ToFriend(target=${target.id})"
|
// final override fun toString(): String = "OnlineMessageSource.ToFriend(target=${target.id})"
|
||||||
|
|
||||||
@PlannedRemoval("1.0.0")
|
|
||||||
@Deprecated("for binary compatibility until 1.0.0", level = DeprecationLevel.HIDDEN)
|
|
||||||
@get:JvmName("sender")
|
|
||||||
@get:JvmSynthetic
|
|
||||||
final override val sender2: Bot
|
|
||||||
get() = sender
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract class ToTemp : Outgoing() {
|
abstract class ToTemp : Outgoing() {
|
||||||
@ -188,8 +181,7 @@ sealed class OnlineMessageSource : MessageSource() {
|
|||||||
*/
|
*/
|
||||||
sealed class Incoming : OnlineMessageSource() {
|
sealed class Incoming : OnlineMessageSource() {
|
||||||
companion object Key : Message.Key<Incoming> {
|
companion object Key : Message.Key<Incoming> {
|
||||||
override val typeName: String
|
override val typeName: String get() = "OnlineMessageSource.Incoming"
|
||||||
get() = "OnlineMessageSource.Incoming"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract override val sender: QQ // out QQ
|
abstract override val sender: QQ // out QQ
|
||||||
@ -199,8 +191,7 @@ sealed class OnlineMessageSource : MessageSource() {
|
|||||||
|
|
||||||
abstract class FromFriend : Incoming() {
|
abstract class FromFriend : Incoming() {
|
||||||
companion object Key : Message.Key<FromFriend> {
|
companion object Key : Message.Key<FromFriend> {
|
||||||
override val typeName: String
|
override val typeName: String get() = "OnlineMessageSource.Incoming.FromFriend"
|
||||||
get() = "OnlineMessageSource.Incoming.FromFriend"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract override val sender: QQ
|
abstract override val sender: QQ
|
||||||
@ -211,8 +202,7 @@ sealed class OnlineMessageSource : MessageSource() {
|
|||||||
|
|
||||||
abstract class FromTemp : Incoming() {
|
abstract class FromTemp : Incoming() {
|
||||||
companion object Key : Message.Key<FromTemp> {
|
companion object Key : Message.Key<FromTemp> {
|
||||||
override val typeName: String
|
override val typeName: String get() = "OnlineMessageSource.Incoming.FromTemp"
|
||||||
get() = "OnlineMessageSource.Incoming.FromTemp"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract override val sender: Member
|
abstract override val sender: Member
|
||||||
@ -223,8 +213,7 @@ sealed class OnlineMessageSource : MessageSource() {
|
|||||||
|
|
||||||
abstract class FromGroup : Incoming() {
|
abstract class FromGroup : Incoming() {
|
||||||
companion object Key : Message.Key<FromGroup> {
|
companion object Key : Message.Key<FromGroup> {
|
||||||
override val typeName: String
|
override val typeName: String get() = "OnlineMessageSource.Incoming.FromGroup"
|
||||||
get() = "OnlineMessageSource.Incoming.FromGroup"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract override val sender: Member
|
abstract override val sender: Member
|
||||||
|
@ -9,11 +9,12 @@
|
|||||||
|
|
||||||
@file:JvmMultifileClass
|
@file:JvmMultifileClass
|
||||||
@file:JvmName("MessageUtils")
|
@file:JvmName("MessageUtils")
|
||||||
@file:Suppress("NOTHING_TO_INLINE")
|
@file:Suppress("NOTHING_TO_INLINE", "unused")
|
||||||
|
|
||||||
package net.mamoe.mirai.message.data
|
package net.mamoe.mirai.message.data
|
||||||
|
|
||||||
import kotlinx.coroutines.Job
|
import kotlinx.coroutines.Job
|
||||||
|
import net.mamoe.mirai.Bot
|
||||||
import net.mamoe.mirai.message.MessageReceipt
|
import net.mamoe.mirai.message.MessageReceipt
|
||||||
import net.mamoe.mirai.utils.MiraiExperimentalAPI
|
import net.mamoe.mirai.utils.MiraiExperimentalAPI
|
||||||
import net.mamoe.mirai.utils.SinceMirai
|
import net.mamoe.mirai.utils.SinceMirai
|
||||||
@ -47,6 +48,31 @@ class QuoteReply(val source: MessageSource) : Message, MessageMetadata, Constrai
|
|||||||
override fun contentToString(): String = ""
|
override fun contentToString(): String = ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.id: Int
|
||||||
|
get() = source.id
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.fromId: Long
|
||||||
|
get() = source.fromId
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.targetId: Long
|
||||||
|
get() = source.targetId
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.originalMessage: MessageChain
|
||||||
|
get() = source.originalMessage
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.time: Int
|
||||||
|
get() = source.time
|
||||||
|
|
||||||
|
@get:JvmSynthetic
|
||||||
|
inline val QuoteReply.bot: Bot
|
||||||
|
get() = source.bot
|
||||||
|
|
||||||
|
|
||||||
@JvmSynthetic
|
@JvmSynthetic
|
||||||
suspend inline fun QuoteReply.recall() = this.source.recall()
|
suspend inline fun QuoteReply.recall() = this.source.recall()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user