From d6ac6d86bb7b3973826db227a3c694b3420f68c1 Mon Sep 17 00:00:00 2001 From: DBotThePony Date: Wed, 8 Feb 2023 19:01:14 +0700 Subject: [PATCH] =?UTF-8?q?=D1=81=D1=8B=D1=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../ru/dbotthepony/kstarbound/Starbound.kt | 4 +- .../kstarbound/defs/item/ArmorPieceType.kt | 26 ------- .../defs/item/IArmorItemDefinition.kt | 5 -- .../defs/item/IFossilItemDefinition.kt | 66 ------------------ .../kstarbound/defs/item/IInventoryIcon.kt | 9 +++ .../kstarbound/defs/item/IItemDefinition.kt | 68 ++----------------- .../kstarbound/defs/item/InventoryIcon.kt | 46 +++++++++++++ .../kstarbound/defs/item/ItemPrototype.kt | 2 +- .../kstarbound/defs/item/ItemRarity.kt | 20 ------ 9 files changed, 62 insertions(+), 184 deletions(-) delete mode 100644 src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ArmorPieceType.kt delete mode 100644 src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IFossilItemDefinition.kt create mode 100644 src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IInventoryIcon.kt create mode 100644 src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/InventoryIcon.kt delete mode 100644 src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemRarity.kt diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/Starbound.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/Starbound.kt index ef33aed3..984b0561 100644 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/Starbound.kt +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/Starbound.kt @@ -27,9 +27,9 @@ import ru.dbotthepony.kstarbound.defs.item.HarvestingToolPrototype import ru.dbotthepony.kstarbound.defs.item.HeadArmorItemPrototype import ru.dbotthepony.kstarbound.defs.item.IArmorItemDefinition import ru.dbotthepony.kstarbound.defs.item.IItemDefinition +import ru.dbotthepony.kstarbound.defs.item.InventoryIcon import ru.dbotthepony.kstarbound.defs.item.ItemPrototype import ru.dbotthepony.kstarbound.defs.item.LegsArmorItemPrototype -import ru.dbotthepony.kstarbound.defs.item.LeveledStatusEffect import ru.dbotthepony.kstarbound.defs.item.LiquidItemPrototype import ru.dbotthepony.kstarbound.defs.item.MaterialItemPrototype import ru.dbotthepony.kstarbound.defs.tile.LiquidDefinition @@ -168,7 +168,7 @@ class Starbound : ISBFileLocator { spriteRegistry = SpriteReference.Adapter(pathStack, this@Starbound::atlasRegistry) registerTypeAdapter(spriteRegistry) - registerTypeAdapterFactory(IItemDefinition.InventoryIcon.Factory(pathStack, spriteRegistry)) + registerTypeAdapterFactory(InventoryIcon.Factory(pathStack, spriteRegistry)) registerTypeAdapterFactory(IArmorItemDefinition.Frames.Factory(pathStack, this@Starbound::atlasRegistry)) registerTypeAdapterFactory(DirectAssetReferenceFactory(pathStack)) diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ArmorPieceType.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ArmorPieceType.kt deleted file mode 100644 index e942eb10..00000000 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ArmorPieceType.kt +++ /dev/null @@ -1,26 +0,0 @@ -package ru.dbotthepony.kstarbound.defs.item - -/** - * Тип брони. Более формально, в какой слот надевается данный предмет - */ -enum class ArmorPieceType { - /** - * Шлем - */ - HEAD, - - /** - * Нагрудник - */ - CHEST, - - /** - * Поножи - */ - LEGS, - - /** - * Плащ/рюкзак/прочее - */ - BACK -} diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IArmorItemDefinition.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IArmorItemDefinition.kt index 19e8e8ad..35e0c0d0 100644 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IArmorItemDefinition.kt +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IArmorItemDefinition.kt @@ -14,11 +14,6 @@ import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation import ru.dbotthepony.kstarbound.util.PathStack interface IArmorItemDefinition : ILeveledItemDefinition, IScriptableItemDefinition { - /** - * @see ArmorPieceType - */ - val armorType: ArmorPieceType - /** * Варианты покраски (???) */ diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IFossilItemDefinition.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IFossilItemDefinition.kt deleted file mode 100644 index 5bebef70..00000000 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IFossilItemDefinition.kt +++ /dev/null @@ -1,66 +0,0 @@ -package ru.dbotthepony.kstarbound.defs.item - -import ru.dbotthepony.kstarbound.defs.IThingWithDescription -import ru.dbotthepony.kstarbound.io.json.builder.FactoryAdapter -import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory -import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation -import ru.dbotthepony.kvector.vector.ndouble.Vector2d - -interface IFossilItemDefinition : IItemDefinition { - /** - * Используется в костях-ископаемых - */ - val race: String - val displayImage: String - val displayoffset: Vector2d - - /** - * Используется в костях-ископаемых - */ - val fossilSetName: String - - /** - * Используется в костях-ископаемых - */ - val setIndex: Int - - /** - * Используется в костях-ископаемых - */ - val setCount: Int - - /** - * Используется в костях-ископаемых - */ - val setCollectables: Map - - /** - * Используется в костях-ископаемых - */ - val completeFossilIcon: String? - - /** - * Используется в костях-ископаемых - */ - val completeFossilObject: String? - - /** - * Используется в костях-ископаемых - */ - val completeSetDescriptions: IFossilSetDescription? - - @JsonImplementation(FossilSetDescription::class) - interface IFossilSetDescription : IThingWithDescription { - /** - * Цена в пикселях - */ - val price: Long - } - - @JsonFactory - data class FossilSetDescription( - override val price: Long = 0L, - override val shortdescription: String = "...", - override val description: String = "..." - ) : IFossilSetDescription -} diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IInventoryIcon.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IInventoryIcon.kt new file mode 100644 index 00000000..678a88dd --- /dev/null +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IInventoryIcon.kt @@ -0,0 +1,9 @@ +package ru.dbotthepony.kstarbound.defs.item + +import ru.dbotthepony.kstarbound.defs.image.SpriteReference +import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation + +@JsonImplementation(InventoryIcon::class) +interface IInventoryIcon { + val image: SpriteReference +} diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IItemDefinition.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IItemDefinition.kt index c15a2d5a..38a54ecd 100644 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IItemDefinition.kt +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/IItemDefinition.kt @@ -1,18 +1,7 @@ package ru.dbotthepony.kstarbound.defs.item -import com.google.gson.Gson -import com.google.gson.TypeAdapter -import com.google.gson.TypeAdapterFactory -import com.google.gson.reflect.TypeToken -import com.google.gson.stream.JsonReader -import com.google.gson.stream.JsonToken -import com.google.gson.stream.JsonWriter import ru.dbotthepony.kstarbound.defs.IThingWithDescription import ru.dbotthepony.kstarbound.defs.RegistryReference -import ru.dbotthepony.kstarbound.defs.image.SpriteReference -import ru.dbotthepony.kstarbound.io.json.builder.FactoryAdapter -import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation -import ru.dbotthepony.kstarbound.util.PathStack interface IItemDefinition : IThingWithDescription { /** @@ -29,60 +18,16 @@ interface IItemDefinition : IThingWithDescription { */ val price: Long - /** - * Редкость как [ItemRarity] - */ - val rarity: ItemRarity - /** * Категория предмета, определяет, в какую вкладку инвентаря оно попадает */ - val category: String? + val category: String /** * Иконка в инвентаре, относительный и абсолютный пути */ val inventoryIcon: List? - @JsonImplementation(InventoryIcon::class) - interface IInventoryIcon { - val image: SpriteReference - } - - data class InventoryIcon( - override val image: SpriteReference - ) : IInventoryIcon { - class Factory(val remapper: PathStack, val spriteRegistry: SpriteReference.Adapter) : TypeAdapterFactory { - override fun create(gson: Gson, type: TypeToken): TypeAdapter? { - if (type.rawType == InventoryIcon::class.java) { - return object : TypeAdapter() { - private val adapter = FactoryAdapter.Builder(InventoryIcon::class, InventoryIcon::image).build(gson) - - override fun write(out: JsonWriter, value: InventoryIcon?) { - if (value == null) - out.nullValue() - else - adapter.write(out, value) - } - - override fun read(`in`: JsonReader): InventoryIcon? { - if (`in`.peek() == JsonToken.NULL) - return null - - if (`in`.peek() == JsonToken.STRING) { - return InventoryIcon(spriteRegistry.parse(remapper.remap(`in`.nextString()))) - } - - return adapter.read(`in`) - } - } as TypeAdapter - } - - return null - } - } - } - /** * Теги предмета */ @@ -130,25 +75,20 @@ interface IItemDefinition : IThingWithDescription { */ val radioMessagesOnPickup: List - /** - * Топливо корабля - */ - val fuelAmount: Long? - /** * Звуки при поднятии "малого" количества предметов. Не имеет никакого смысла без [smallStackLimit] */ - val pickupSoundsSmall: List + val pickupSoundsSmall: List? /** * Звуки при поднятии "среднего" количества предметов. Не имеет никакого смысла без [mediumStackLimit] */ - val pickupSoundsMedium: List + val pickupSoundsMedium: List? /** * Звуки при поднятии "большого" количества предметов. Не имеет никакого смысла без [smallStackLimit] и без [mediumStackLimit] */ - val pickupSoundsLarge: List + val pickupSoundsLarge: List? /** * Количество предметов ниже или равному данному значению проиграет звук [pickupSoundsSmall] diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/InventoryIcon.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/InventoryIcon.kt new file mode 100644 index 00000000..558809c7 --- /dev/null +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/InventoryIcon.kt @@ -0,0 +1,46 @@ +package ru.dbotthepony.kstarbound.defs.item + +import com.google.gson.Gson +import com.google.gson.TypeAdapter +import com.google.gson.TypeAdapterFactory +import com.google.gson.reflect.TypeToken +import com.google.gson.stream.JsonReader +import com.google.gson.stream.JsonToken +import com.google.gson.stream.JsonWriter +import ru.dbotthepony.kstarbound.defs.image.SpriteReference +import ru.dbotthepony.kstarbound.io.json.builder.FactoryAdapter +import ru.dbotthepony.kstarbound.util.PathStack + +data class InventoryIcon( + override val image: SpriteReference +) : IInventoryIcon { + class Factory(val remapper: PathStack, val spriteRegistry: SpriteReference.Adapter) : TypeAdapterFactory { + override fun create(gson: Gson, type: TypeToken): TypeAdapter? { + if (type.rawType == InventoryIcon::class.java) { + return object : TypeAdapter() { + private val adapter = FactoryAdapter.Builder(InventoryIcon::class, InventoryIcon::image).build(gson) + + override fun write(out: JsonWriter, value: InventoryIcon?) { + if (value == null) + out.nullValue() + else + adapter.write(out, value) + } + + override fun read(`in`: JsonReader): InventoryIcon? { + if (`in`.peek() == JsonToken.NULL) + return null + + if (`in`.peek() == JsonToken.STRING) { + return InventoryIcon(spriteRegistry.parse(remapper.remap(`in`.nextString()))) + } + + return adapter.read(`in`) + } + } as TypeAdapter + } + + return null + } + } +} diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemPrototype.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemPrototype.kt index 58b46102..07091114 100644 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemPrototype.kt +++ b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemPrototype.kt @@ -34,7 +34,7 @@ open class ItemPrototype : FreezableDefintionBuilder(), IItemDefinition { final override var price: Long by NotNull(0L) final override var rarity: ItemRarity by NotNull(ItemRarity.COMMON) final override var category: String? by Nullable() - final override var inventoryIcon: ImmutableList? by Nullable() + final override var inventoryIcon: ImmutableList? by Nullable() final override var itemTags: ImmutableList by NotNull(ImmutableList.of()) final override var learnBlueprintsOnPickup: ImmutableList> by NotNull(ImmutableList.of()) final override var maxStack: Long by NotNull(9999L) diff --git a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemRarity.kt b/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemRarity.kt deleted file mode 100644 index 1e889c3a..00000000 --- a/src/main/kotlin/ru/dbotthepony/kstarbound/defs/item/ItemRarity.kt +++ /dev/null @@ -1,20 +0,0 @@ -package ru.dbotthepony.kstarbound.defs.item - -import com.google.gson.stream.JsonWriter -import ru.dbotthepony.kstarbound.io.json.builder.IStringSerializable - -enum class ItemRarity(val canonical: String) : IStringSerializable { - COMMON("Common"), - UNCOMMON("Uncommon"), - RARE("Rare"), - LEGENDARY("Legendary"), - ESSENTIAL("Essential"); - - override fun match(name: String): Boolean { - return name == this.canonical || name.lowercase() == this.name.lowercase() - } - - override fun write(out: JsonWriter) { - out.value(canonical) - } -}