mirror of
https://github.com/curioustorvald/Terrarum.git
synced 2026-06-19 23:14:05 +09:00
jsoner is always newly generated when accessed
This commit is contained in:
@@ -46,16 +46,15 @@ object Common {
|
||||
private fun Byte.tostr() = this.toInt().and(255).toString(16).padStart(2,'0')
|
||||
private val digester = DigestUtils.getSha256Digest()
|
||||
|
||||
val jsoner = Json(JsonWriter.OutputType.json)
|
||||
|
||||
val jsoner: Json
|
||||
get() = Json(JsonWriter.OutputType.json).also {
|
||||
// install custom (de)serialiser
|
||||
init {
|
||||
jsoner.ignoreUnknownFields = true
|
||||
jsoner.setUsePrototypes(false)
|
||||
jsoner.setIgnoreDeprecated(false)
|
||||
it.ignoreUnknownFields = true
|
||||
it.setUsePrototypes(false)
|
||||
it.setIgnoreDeprecated(false)
|
||||
|
||||
// BigInteger
|
||||
jsoner.setSerializer(BigInteger::class.java, object : Json.Serializer<BigInteger> {
|
||||
it.setSerializer(BigInteger::class.java, object : Json.Serializer<BigInteger> {
|
||||
override fun write(json: Json, obj: BigInteger?, knownType: Class<*>?) {
|
||||
json.writeValue(obj?.toString())
|
||||
}
|
||||
@@ -65,7 +64,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// ZipCodedStr
|
||||
jsoner.setSerializer(ZipCodedStr::class.java, object : Json.Serializer<ZipCodedStr> {
|
||||
it.setSerializer(ZipCodedStr::class.java, object : Json.Serializer<ZipCodedStr> {
|
||||
override fun write(json: Json, obj: ZipCodedStr, knownType: Class<*>?) {
|
||||
json.writeValue(zipStrAndEnascii(obj.doc))
|
||||
}
|
||||
@@ -75,7 +74,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// BlockLayer
|
||||
jsoner.setSerializer(BlockLayerI16::class.java, object : Json.Serializer<BlockLayerI16> {
|
||||
it.setSerializer(BlockLayerI16::class.java, object : Json.Serializer<BlockLayerI16> {
|
||||
override fun write(json: Json, obj: BlockLayerI16, knownType: Class<*>?) {
|
||||
digester.reset()
|
||||
obj.bytesIterator().forEachRemaining { digester.update(it) }
|
||||
@@ -103,7 +102,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// WorldTime
|
||||
jsoner.setSerializer(WorldTime::class.java, object : Json.Serializer<WorldTime> {
|
||||
it.setSerializer(WorldTime::class.java, object : Json.Serializer<WorldTime> {
|
||||
override fun write(json: Json, obj: WorldTime, knownType: Class<*>?) {
|
||||
json.writeValue(obj.TIME_T)
|
||||
}
|
||||
@@ -113,7 +112,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// HashArray
|
||||
jsoner.setSerializer(HashArray::class.java, object : Json.Serializer<HashArray<*>> {
|
||||
it.setSerializer(HashArray::class.java, object : Json.Serializer<HashArray<*>> {
|
||||
override fun write(json: Json, obj: HashArray<*>, knownType: Class<*>?) {
|
||||
json.writeObjectStart()
|
||||
obj.forEach { (k, v) ->
|
||||
@@ -131,7 +130,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// HashedWirings
|
||||
jsoner.setSerializer(HashedWirings::class.java, object : Json.Serializer<HashedWirings> {
|
||||
it.setSerializer(HashedWirings::class.java, object : Json.Serializer<HashedWirings> {
|
||||
override fun write(json: Json, obj: HashedWirings, knownType: Class<*>?) {
|
||||
json.writeObjectStart()
|
||||
obj.forEach { (k, v) ->
|
||||
@@ -149,7 +148,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// HashedWiringGraph
|
||||
jsoner.setSerializer(HashedWiringGraph::class.java, object : Json.Serializer<HashedWiringGraph> {
|
||||
it.setSerializer(HashedWiringGraph::class.java, object : Json.Serializer<HashedWiringGraph> {
|
||||
override fun write(json: Json, obj: HashedWiringGraph, knownType: Class<*>?) {
|
||||
json.writeObjectStart()
|
||||
obj.forEach { (k, v) ->
|
||||
@@ -167,7 +166,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// WiringGraphMap; this serialiser is here just to reduce the JSON filesize
|
||||
jsoner.setSerializer(WiringGraphMap::class.java, object : Json.Serializer<WiringGraphMap> {
|
||||
it.setSerializer(WiringGraphMap::class.java, object : Json.Serializer<WiringGraphMap> {
|
||||
override fun write(json: Json, obj: WiringGraphMap, knownType: Class<*>?) {
|
||||
json.writeObjectStart()
|
||||
obj.forEach { (k, v) ->
|
||||
@@ -185,7 +184,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// UUID
|
||||
jsoner.setSerializer(UUID::class.java, object : Json.Serializer<UUID> {
|
||||
it.setSerializer(UUID::class.java, object : Json.Serializer<UUID> {
|
||||
override fun write(json: Json, obj: UUID, knownType: Class<*>?) {
|
||||
json.writeValue(obj.toString())
|
||||
}
|
||||
@@ -195,7 +194,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// HQRNG
|
||||
jsoner.setSerializer(HQRNG::class.java, object : Json.Serializer<HQRNG> {
|
||||
it.setSerializer(HQRNG::class.java, object : Json.Serializer<HQRNG> {
|
||||
override fun write(json: Json, obj: HQRNG, knownType: Class<*>?) {
|
||||
json.writeValue("${obj.state0.toString()},${obj.state1.toString()}")
|
||||
}
|
||||
@@ -208,7 +207,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// kotlin.ByteArray
|
||||
jsoner.setSerializer(ByteArray::class.java, object : Json.Serializer<ByteArray> {
|
||||
it.setSerializer(ByteArray::class.java, object : Json.Serializer<ByteArray> {
|
||||
override fun write(json: Json, obj: ByteArray, knownType: Class<*>?) {
|
||||
json.writeValue(bytesToZipdStr(obj.iterator()))
|
||||
}
|
||||
@@ -218,7 +217,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// WeatherStateBox
|
||||
jsoner.setSerializer(WeatherStateBox::class.java, object : Json.Serializer<WeatherStateBox> {
|
||||
it.setSerializer(WeatherStateBox::class.java, object : Json.Serializer<WeatherStateBox> {
|
||||
override fun write(json: Json, obj: WeatherStateBox, knownType: Class<*>?) {
|
||||
json.writeValue("${obj.x};${obj.pM2};${obj.pM1};${obj.p0};${obj.p1};${obj.p2};${obj.p3}")
|
||||
}
|
||||
@@ -230,7 +229,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// WeatherDirBox
|
||||
jsoner.setSerializer(WeatherDirBox::class.java, object : Json.Serializer<WeatherDirBox> {
|
||||
it.setSerializer(WeatherDirBox::class.java, object : Json.Serializer<WeatherDirBox> {
|
||||
override fun write(json: Json, obj: WeatherDirBox, knownType: Class<*>?) {
|
||||
json.writeValue("${obj.x};${obj.pM2};${obj.pM1};${obj.p0};${obj.p1};${obj.p2};${obj.p3}")
|
||||
}
|
||||
@@ -256,7 +255,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// BaseModularWeather
|
||||
jsoner.setSerializer(BaseModularWeather::class.java, object : Json.Serializer<BaseModularWeather> {
|
||||
it.setSerializer(BaseModularWeather::class.java, object : Json.Serializer<BaseModularWeather> {
|
||||
override fun write(json: Json, obj: BaseModularWeather, knownType: Class<*>?) {
|
||||
json.writeValue(obj.identifier)
|
||||
}
|
||||
@@ -266,7 +265,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// Fill
|
||||
jsoner.setSerializer(Fill::class.java, object : Json.Serializer<Fill> {
|
||||
it.setSerializer(Fill::class.java, object : Json.Serializer<Fill> {
|
||||
override fun write(json: Json, obj: Fill, knownType: Class<*>?) {
|
||||
json.writeValue("${obj.item};${obj.amount}")
|
||||
}
|
||||
@@ -277,7 +276,7 @@ object Common {
|
||||
}
|
||||
})
|
||||
// OrePlacement
|
||||
jsoner.setSerializer(OrePlacement::class.java, object : Json.Serializer<OrePlacement> {
|
||||
it.setSerializer(OrePlacement::class.java, object : Json.Serializer<OrePlacement> {
|
||||
override fun write(json: Json, obj: OrePlacement, knownType: Class<*>?) {
|
||||
json.writeValue("${obj.item};${obj.tilePlacement}")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user