forked from mamoe/mirai
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathQuoteReply.kt
63 lines (53 loc) · 2.34 KB
/
QuoteReply.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/*
* Copyright 2019-2021 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
*/
@file:JvmMultifileClass
@file:JvmName("MessageUtils")
@file:Suppress("NOTHING_TO_INLINE", "unused")
package net.mamoe.mirai.message.data
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable
import net.mamoe.mirai.message.data.MessageSource.Key.quote
import net.mamoe.mirai.message.data.MessageSource.Key.recall
import net.mamoe.mirai.utils.safeCast
/**
* 引用回复. [QuoteReply] 被作为 [MessageMetadata], 因为它不包含实际的消息内容.
*
* 支持引用任何一条消息发送给任何人.
*
* 引用回复的原消息内容完全由 [source] 中 [MessageSource.originalMessage] 控制, 客户端不会自行寻找原消息.
* 可通过 [MessageSource.copyAmend] 修改引用的消息内容.
*
* 客户端通过 [MessageSource.ids] 等数据定位源消息, 在修改时使用 [MessageSourceBuilder.metadata] 可以修改定位结果.
*
* ## 创建引用回复
* - 直接构造 [QuoteReply]: `new QuoteReply(source)`
* - 在 Kotlin 使用扩展 [MessageSource.quote]
*
* @see MessageSource 获取有关消息源的更多信息
*/
@Serializable
@SerialName(QuoteReply.SERIAL_NAME)
public data class QuoteReply(
public val source: MessageSource
) : Message, MessageMetadata, ConstrainSingle {
public constructor(sourceMessage: MessageChain) : this(sourceMessage.getOrFail(MessageSource))
public override val key: MessageKey<QuoteReply> get() = Key
public override fun toString(): String =
"[mirai:quote:${source.ids.contentToString()},${source.internalIds.contentToString()}]"
public override fun equals(other: Any?): Boolean = other is QuoteReply && other.source == this.source
public override fun hashCode(): Int = source.hashCode()
public companion object Key : AbstractMessageKey<QuoteReply>({ it.safeCast() }) {
public const val SERIAL_NAME: String = "QuoteReply"
}
}
/**
* 撤回引用的源消息
*/
@JvmSynthetic
public suspend inline fun QuoteReply.recallSource(): Unit = this.source.recall()