From d4b254ea11798a8ba4b891d31c433496b7c53bb3 Mon Sep 17 00:00:00 2001 From: nea Date: Wed, 26 Jul 2023 23:59:24 +0200 Subject: Fix storage not saving properly --- .../inventory/storageoverlay/StorageData.kt | 3 +++ .../moe/nea/firmament/util/SortedMapSerializer.kt | 23 ++++++++++++++++++++++ 2 files changed, 26 insertions(+) create mode 100644 src/main/kotlin/moe/nea/firmament/util/SortedMapSerializer.kt (limited to 'src/main/kotlin/moe/nea') diff --git a/src/main/kotlin/moe/nea/firmament/features/inventory/storageoverlay/StorageData.kt b/src/main/kotlin/moe/nea/firmament/features/inventory/storageoverlay/StorageData.kt index 1c2ac08..00714ab 100644 --- a/src/main/kotlin/moe/nea/firmament/features/inventory/storageoverlay/StorageData.kt +++ b/src/main/kotlin/moe/nea/firmament/features/inventory/storageoverlay/StorageData.kt @@ -1,7 +1,10 @@ +@file:UseSerializers(SortedMapSerializer::class) package moe.nea.firmament.features.inventory.storageoverlay import java.util.SortedMap import kotlinx.serialization.Serializable +import kotlinx.serialization.UseSerializers +import moe.nea.firmament.util.SortedMapSerializer @Serializable data class StorageData( diff --git a/src/main/kotlin/moe/nea/firmament/util/SortedMapSerializer.kt b/src/main/kotlin/moe/nea/firmament/util/SortedMapSerializer.kt new file mode 100644 index 0000000..6f4ff2e --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/util/SortedMapSerializer.kt @@ -0,0 +1,23 @@ +package moe.nea.firmament.util + +import java.util.SortedMap +import kotlinx.serialization.KSerializer +import kotlinx.serialization.builtins.MapSerializer +import kotlinx.serialization.descriptors.SerialDescriptor +import kotlinx.serialization.encoding.Decoder +import kotlinx.serialization.encoding.Encoder + +class SortedMapSerializer, V>(val keyDelegate: KSerializer, val valueDelegate: KSerializer) : + KSerializer> { + val mapSerializer = MapSerializer(keyDelegate, valueDelegate) + override val descriptor: SerialDescriptor + get() = mapSerializer.descriptor + + override fun deserialize(decoder: Decoder): SortedMap { + return (mapSerializer.deserialize(decoder).toSortedMap(Comparator.naturalOrder())) + } + + override fun serialize(encoder: Encoder, value: SortedMap) { + mapSerializer.serialize(encoder, value) + } +} -- cgit