mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-25 07:30:14 +08:00
tool man fixes bugs which he doesnt know at all
This commit is contained in:
parent
989547d0fc
commit
876da07144
@ -374,12 +374,12 @@ internal class QQAndroidBotNetworkHandler(bot: QQAndroidBot) : BotNetworkHandler
|
|||||||
// with generic type, less mistakes
|
// with generic type, less mistakes
|
||||||
private suspend fun <P : Packet?> generifiedParsePacket(input: Input) {
|
private suspend fun <P : Packet?> generifiedParsePacket(input: Input) {
|
||||||
KnownPacketFactories.parseIncomingPacket(bot, input) { packetFactory: PacketFactory<P>, packet: P, commandName: String, sequenceId: Int ->
|
KnownPacketFactories.parseIncomingPacket(bot, input) { packetFactory: PacketFactory<P>, packet: P, commandName: String, sequenceId: Int ->
|
||||||
handlePacket(packetFactory, packet, commandName, sequenceId)
|
|
||||||
if (packet is MultiPacket<*>) {
|
if (packet is MultiPacket<*>) {
|
||||||
packet.forEach {
|
packet.forEach {
|
||||||
handlePacket(null, it, commandName, sequenceId)
|
handlePacket(null, it, commandName, sequenceId)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
handlePacket(packetFactory, packet, commandName, sequenceId)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -388,29 +388,6 @@ internal class QQAndroidBotNetworkHandler(bot: QQAndroidBot) : BotNetworkHandler
|
|||||||
*/
|
*/
|
||||||
suspend fun <P : Packet?> handlePacket(packetFactory: PacketFactory<P>?, packet: P, commandName: String, sequenceId: Int) {
|
suspend fun <P : Packet?> handlePacket(packetFactory: PacketFactory<P>?, packet: P, commandName: String, sequenceId: Int) {
|
||||||
// highest priority: pass to listeners (attached by sendAndExpect).
|
// highest priority: pass to listeners (attached by sendAndExpect).
|
||||||
packetListeners.forEach { listener ->
|
|
||||||
if (listener.filter(commandName, sequenceId) && packetListeners.remove(listener)) {
|
|
||||||
listener.complete(packet)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// check top-level cancelling
|
|
||||||
if (packet != null && PacketReceivedEvent(packet).broadcast().isCancelled) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// broadcast
|
|
||||||
if (packet is Event) {
|
|
||||||
if (packet is BroadcastControllable) {
|
|
||||||
if (packet.shouldBroadcast) packet.broadcast()
|
|
||||||
} else {
|
|
||||||
packet.broadcast()
|
|
||||||
}
|
|
||||||
|
|
||||||
if (packet is CancellableEvent && packet.isCancelled) return
|
|
||||||
}
|
|
||||||
|
|
||||||
if (packet != null && (bot.logger.isEnabled || logger.isEnabled)) {
|
if (packet != null && (bot.logger.isEnabled || logger.isEnabled)) {
|
||||||
val logMessage = "Received: ${packet.toString().replace("\n", """\n""").replace("\r", "")}"
|
val logMessage = "Received: ${packet.toString().replace("\n", """\n""").replace("\r", "")}"
|
||||||
|
|
||||||
@ -419,12 +396,32 @@ internal class QQAndroidBotNetworkHandler(bot: QQAndroidBot) : BotNetworkHandler
|
|||||||
} else logger.verbose(logMessage)
|
} else logger.verbose(logMessage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
packetListeners.forEach { listener ->
|
||||||
|
if (listener.filter(commandName, sequenceId) && packetListeners.remove(listener)) {
|
||||||
|
listener.complete(packet)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
packetFactory?.run {
|
packetFactory?.run {
|
||||||
when (this) {
|
when (this) {
|
||||||
is OutgoingPacketFactory<P> -> bot.handle(packet)
|
is OutgoingPacketFactory<P> -> bot.handle(packet)
|
||||||
is IncomingPacketFactory<P> -> bot.handle(packet, sequenceId)?.sendWithoutExpect()
|
is IncomingPacketFactory<P> -> bot.handle(packet, sequenceId)?.sendWithoutExpect()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (packet != null && PacketReceivedEvent(packet).broadcast().isCancelled) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (packet is Event) {
|
||||||
|
if (packet is BroadcastControllable) {
|
||||||
|
if (packet.shouldBroadcast) packet.broadcast()
|
||||||
|
} else {
|
||||||
|
packet.broadcast()
|
||||||
|
}
|
||||||
|
|
||||||
|
if (packet is CancellableEvent && packet.isCancelled) return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user