diff --git a/crystal-map-api/src/main/java/com/schwarz/crystalapi/schema/CMType.kt b/crystal-map-api/src/main/java/com/schwarz/crystalapi/schema/CMType.kt index 51d16a5..f086421 100644 --- a/crystal-map-api/src/main/java/com/schwarz/crystalapi/schema/CMType.kt +++ b/crystal-map-api/src/main/java/com/schwarz/crystalapi/schema/CMType.kt @@ -3,16 +3,17 @@ package com.schwarz.crystalapi.schema import com.schwarz.crystalapi.ITypeConverter sealed interface CMType { + val name: String val path: String } -open class CMJsonField(val name: String, override val path: String) : CMType +open class CMJsonField(override val name: String, override val path: String) : CMType -open class CMJsonList(val name: String, override val path: String) : CMType +open class CMJsonList(override val name: String, override val path: String) : CMType -class CMObject(val element: T, override val path: String) : CMType +class CMObjectField(val element: T, override val name: String, override val path: String) : CMType -class CMObjectList(val element: T, val name: String, override val path: String) : CMType +class CMObjectList(val element: T, override val name: String, override val path: String) : CMType class CMConverterField( name: String, diff --git a/crystal-map-processor/src/main/java/com/schwarz/crystalprocessor/generation/model/SchemaGeneration.kt b/crystal-map-processor/src/main/java/com/schwarz/crystalprocessor/generation/model/SchemaGeneration.kt index 8402976..38f28ce 100644 --- a/crystal-map-processor/src/main/java/com/schwarz/crystalprocessor/generation/model/SchemaGeneration.kt +++ b/crystal-map-processor/src/main/java/com/schwarz/crystalprocessor/generation/model/SchemaGeneration.kt @@ -170,7 +170,7 @@ class SchemaGeneration { return when { isIterable && isObject -> buildObjectListFormat(propertyType, fieldName, propertyAccessPath) - isObject -> buildObjectFormat(propertyType, propertyAccessPath) + isObject -> buildObjectFormat(propertyType, fieldName, propertyAccessPath) else -> buildSimpleFormat(fieldName) } } @@ -188,9 +188,10 @@ class SchemaGeneration { private fun buildSimpleFormat(fieldName: String): String = """%T("$fieldName", $pathAttributeName)""" - private fun buildObjectFormat(propertyType: TypeName, propertyAccessPath: String): String = + private fun buildObjectFormat(propertyType: TypeName, fieldName: String, propertyAccessPath: String): String = """%T( $propertyType($propertyAccessPath), + "$fieldName", $pathAttributeName, )""" @@ -203,7 +204,7 @@ class SchemaGeneration { hasProperty -> CMConverterField::class.asTypeName() isIterable && isObject -> CMObjectList::class.asTypeName() isIterable -> CMJsonList::class.asTypeName() - isObject -> CMObject::class.asTypeName() + isObject -> CMObjectField::class.asTypeName() else -> CMJsonField::class.asTypeName() } diff --git a/crystal-map-processor/src/test/resources/ExpectedSchema.txt b/crystal-map-processor/src/test/resources/ExpectedSchema.txt index 484dd5f..a76ad1f 100644 --- a/crystal-map-processor/src/test/resources/ExpectedSchema.txt +++ b/crystal-map-processor/src/test/resources/ExpectedSchema.txt @@ -9,7 +9,7 @@ import com.schwarz.crystalapi.schema.CMConverterField import com.schwarz.crystalapi.schema.CMConverterList import com.schwarz.crystalapi.schema.CMJsonField import com.schwarz.crystalapi.schema.CMJsonList -import com.schwarz.crystalapi.schema.CMObject +import com.schwarz.crystalapi.schema.CMObjectField import com.schwarz.crystalapi.schema.CMObjectList import com.schwarz.crystalapi.schema.Schema import java.time.OffsetDateTime @@ -27,9 +27,10 @@ public open class SubSchema( public val list: CMJsonList = CMJsonList("list", path) - public val someObject: CMObject = CMObject( + public val someObject: CMObjectField = CMObjectField( com.kaufland.testModels.TestObjectSchema(if (path.isBlank()) "someObject" else "$path.someObject"), + "someObject", path, )