Add detailed error message

This commit is contained in:
Him188 2020-03-17 21:46:15 +08:00
parent 0407b99ae2
commit 79bb9e7dc9
2 changed files with 40 additions and 23 deletions

View File

@ -181,8 +181,9 @@ internal class JceDecoder(
StructureKind.MAP -> { StructureKind.MAP -> {
//println("!! MAP") //println("!! MAP")
return jce.skipToHeadAndUseIfPossibleOrFail(popTag().id) { val tag = popTag()
it.checkType(Jce.MAP) return jce.skipToHeadAndUseIfPossibleOrFail(tag.id) {
it.checkType(Jce.MAP, "beginStructure", tag, descriptor)
MapReader MapReader
} }
} }
@ -191,6 +192,8 @@ internal class JceDecoder(
//println("decoderTag: $currentTagOrNull") //println("decoderTag: $currentTagOrNull")
//println("jceHead: " + jce.currentHeadOrNull) //println("jceHead: " + jce.currentHeadOrNull)
return jce.skipToHeadAndUseIfPossibleOrFail(currentTag.id) { return jce.skipToHeadAndUseIfPossibleOrFail(currentTag.id) {
// don't check type. it's polymorphic
//println("listHead: $it") //println("listHead: $it")
when (it.type) { when (it.type) {
Jce.SIMPLE_LIST -> { Jce.SIMPLE_LIST -> {
@ -209,8 +212,9 @@ internal class JceDecoder(
//println("!! CLASS") //println("!! CLASS")
//println("decoderTag: $currentTag") //println("decoderTag: $currentTag")
//println("jceHead: " + jce.currentHeadOrNull) //println("jceHead: " + jce.currentHeadOrNull)
return jce.skipToHeadAndUseIfPossibleOrFail(popTag().id) { jceHead -> val tag = popTag()
jceHead.checkType(Jce.STRUCT_BEGIN) return jce.skipToHeadAndUseIfPossibleOrFail(tag.id) { jceHead ->
jceHead.checkType(Jce.STRUCT_BEGIN, "beginStructure", tag, descriptor)
repeat(descriptor.elementsCount) { repeat(descriptor.elementsCount) {
pushTag(descriptor.getTag(descriptor.elementsCount - it - 1)) // better performance pushTag(descriptor.getTag(descriptor.elementsCount - it - 1)) // better performance

View File

@ -10,6 +10,7 @@
package net.mamoe.mirai.qqandroid.io.serialization.jce package net.mamoe.mirai.qqandroid.io.serialization.jce
import kotlinx.io.core.Output import kotlinx.io.core.Output
import kotlinx.serialization.SerialDescriptor
import kotlinx.serialization.SerialInfo import kotlinx.serialization.SerialInfo
@ -57,8 +58,15 @@ internal data class JceTagCommon(
override val id: Int override val id: Int
) : JceTag() ) : JceTag()
fun JceHead.checkType(type: Byte) { internal fun JceHead.checkType(type: Byte, message: String, tag: JceTag, descriptor: SerialDescriptor) {
check(this.type == type) { "type mismatch. Expected $type, actual ${this.type}" } check(this.type == type) {
"type mismatch. " +
"Expected ${JceHead.findJceTypeName(type)}, " +
"actual ${JceHead.findJceTypeName(this.type)} for $message. " +
"Tag info: " +
"id=${tag.id}, " +
"name=${descriptor.getElementName(tag.id)} " +
"in ${descriptor.serialName}" }
} }
@PublishedApi @PublishedApi
@ -83,23 +91,28 @@ inline class JceHead(private val value: Long) {
val type: Byte get() = value.toUInt().toByte() val type: Byte get() = value.toUInt().toByte()
override fun toString(): String { override fun toString(): String {
val typeString = when (type) { return "JceHead(tag=$tag, type=$type(${findJceTypeName(type)}))"
Jce.BYTE -> "Byte" }
Jce.DOUBLE -> "Double"
Jce.FLOAT -> "Float" companion object {
Jce.INT -> "Int" fun findJceTypeName(type: Byte): String {
Jce.LIST -> "List" return when (type) {
Jce.LONG -> "Long" Jce.BYTE -> "Byte"
Jce.MAP -> "Map" Jce.DOUBLE -> "Double"
Jce.SHORT -> "Short" Jce.FLOAT -> "Float"
Jce.SIMPLE_LIST -> "SimpleList" Jce.INT -> "Int"
Jce.STRING1 -> "String1" Jce.LIST -> "List"
Jce.STRING4 -> "String4" Jce.LONG -> "Long"
Jce.STRUCT_BEGIN -> "StructBegin" Jce.MAP -> "Map"
Jce.STRUCT_END -> "StructEnd" Jce.SHORT -> "Short"
Jce.ZERO_TYPE -> "Zero" Jce.SIMPLE_LIST -> "SimpleList"
else -> error("illegal jce type: $type") Jce.STRING1 -> "String1"
Jce.STRING4 -> "String4"
Jce.STRUCT_BEGIN -> "StructBegin"
Jce.STRUCT_END -> "StructEnd"
Jce.ZERO_TYPE -> "Zero"
else -> error("illegal jce type: $type")
}
} }
return "JceHead(tag=$tag, type=$type($typeString))"
} }
} }