diff --git a/mirai-core-api/compatibility-validation/android/api/android.api b/mirai-core-api/compatibility-validation/android/api/android.api index 99ea5765a..9de5741a0 100644 --- a/mirai-core-api/compatibility-validation/android/api/android.api +++ b/mirai-core-api/compatibility-validation/android/api/android.api @@ -3489,7 +3489,7 @@ public final class net/mamoe/mirai/message/data/AtAll : net/mamoe/mirai/message/ public fun toString ()Ljava/lang/String; } -public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/mirai/message/data/MessageContent { +public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/mirai/message/data/ConstrainSingle, net/mamoe/mirai/message/data/MessageContent { public static final field Key Lnet/mamoe/mirai/message/data/Audio$Key; public fun contentToString ()Ljava/lang/String; public abstract fun getCodec ()Lnet/mamoe/mirai/message/data/AudioCodec; @@ -3497,6 +3497,7 @@ public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/m public abstract fun getFileMd5 ()[B public abstract fun getFileSize ()J public abstract fun getFilename ()Ljava/lang/String; + public fun getKey ()Lnet/mamoe/mirai/message/data/MessageKey; public abstract fun toString ()Ljava/lang/String; } diff --git a/mirai-core-api/compatibility-validation/jvm/api/jvm.api b/mirai-core-api/compatibility-validation/jvm/api/jvm.api index 9755071f6..f700f29e7 100644 --- a/mirai-core-api/compatibility-validation/jvm/api/jvm.api +++ b/mirai-core-api/compatibility-validation/jvm/api/jvm.api @@ -3489,7 +3489,7 @@ public final class net/mamoe/mirai/message/data/AtAll : net/mamoe/mirai/message/ public fun toString ()Ljava/lang/String; } -public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/mirai/message/data/MessageContent { +public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/mirai/message/data/ConstrainSingle, net/mamoe/mirai/message/data/MessageContent { public static final field Key Lnet/mamoe/mirai/message/data/Audio$Key; public fun contentToString ()Ljava/lang/String; public abstract fun getCodec ()Lnet/mamoe/mirai/message/data/AudioCodec; @@ -3497,6 +3497,7 @@ public abstract interface class net/mamoe/mirai/message/data/Audio : net/mamoe/m public abstract fun getFileMd5 ()[B public abstract fun getFileSize ()J public abstract fun getFilename ()Ljava/lang/String; + public fun getKey ()Lnet/mamoe/mirai/message/data/MessageKey; public abstract fun toString ()Ljava/lang/String; } diff --git a/mirai-core-api/src/commonMain/kotlin/message/data/Audio.kt b/mirai-core-api/src/commonMain/kotlin/message/data/Audio.kt index 83aba76d3..6a106dba3 100644 --- a/mirai-core-api/src/commonMain/kotlin/message/data/Audio.kt +++ b/mirai-core-api/src/commonMain/kotlin/message/data/Audio.kt @@ -63,7 +63,7 @@ import kotlin.time.Duration.Companion.seconds * * @since 2.7 */ -public sealed interface Audio : MessageContent { +public sealed interface Audio : MessageContent, ConstrainSingle { public companion object Key : AbstractPolymorphicMessageKey<MessageContent, Audio>(MessageContent, { it.safeCast() }) @@ -112,6 +112,8 @@ public sealed interface Audio : MessageContent { override fun <D, R> accept(visitor: MessageVisitor<D, R>, data: D): R { return visitor.visitAudio(this, data) } + + override val key: MessageKey<*> get() = Key }