v0.2.0-dev-22 #47

Merged
altavir merged 158 commits from dev into master 2021-07-17 11:04:22 +03:00
4 changed files with 12 additions and 6 deletions
Showing only changes of commit 62a76f2c86 - Show all commits

View File

@ -13,10 +13,12 @@ import kotlinx.serialization.Transient
@SerialName("vision.group")
public open class VisionGroupBase : VisionBase(), MutableVisionGroup {
//protected abstract val _children: MutableMap<NameToken, T>
/**
* Internal mutable container for group children
* TODO made protected due to https://github.com/Kotlin/kotlinx.serialization/issues/1200
*/
@SerialName("children")
protected val childrenInternal = LinkedHashMap<NameToken, Vision>()
protected open val childrenInternal: MutableMap<NameToken, Vision> = LinkedHashMap()
/**
* A map of top level named children

View File

@ -93,13 +93,17 @@ public fun MutableVisionGroup.group(name: String, action: SolidGroup.() -> Unit
*/
@Serializable(PrototypesSerializer::class)
internal class Prototypes(
override var children: MutableMap<NameToken, Vision> = LinkedHashMap(),
children: Map<NameToken, Vision> = emptyMap(),
) : VisionGroupBase(), PrototypeHolder {
override fun styleSheet(block: StyleSheet.() -> Unit) {
error("Can't define stylesheet for prototypes block")
}
init {
this.childrenInternal.putAll(children)
}
override var properties: Config?
get() = null
set(_) {

View File

@ -91,7 +91,7 @@ internal object PrototypesSerializer : KSerializer<MutableVisionGroup> {
override fun deserialize(decoder: Decoder): MutableVisionGroup {
val map = mapSerializer.deserialize(decoder)
return Prototypes(map as? MutableMap<NameToken, Vision> ?: LinkedHashMap(map))
return Prototypes(map)
}
override fun serialize(encoder: Encoder, value: MutableVisionGroup) {

View File

@ -60,7 +60,7 @@ class PropertyTest {
@Test
fun testProxyStyleProperty() {
var box: Proxy? = null
val group = SolidGroup().apply {
val group = SolidGroup{
styleSheet {
set("testStyle") {
SolidMaterial.MATERIAL_COLOR_KEY put "#555555"