From ba045bc627c8a6d63f5a61e8430369b74e1f1a9a Mon Sep 17 00:00:00 2001 From: Endel Dreyer Date: Sat, 27 Feb 2021 18:42:54 -0300 Subject: [PATCH] fix: workaround when server encodes ADD + DELETE in the same MapSchema key. --- .../Colyseus/Serializer/Schema/Types/MapSchema.cs | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/Assets/Plugins/Colyseus/Serializer/Schema/Types/MapSchema.cs b/Assets/Plugins/Colyseus/Serializer/Schema/Types/MapSchema.cs index 0ab72fd6..2ec90d97 100644 --- a/Assets/Plugins/Colyseus/Serializer/Schema/Types/MapSchema.cs +++ b/Assets/Plugins/Colyseus/Serializer/Schema/Types/MapSchema.cs @@ -58,7 +58,14 @@ public object GetByIndex(int index) public void DeleteByIndex(int index) { string dynamicIndex = (string) GetIndex(index); - if (Items.Contains(dynamicIndex)) + if ( + // + // FIXME: + // The schema encoder should not encode a DELETE operation when using ADD + DELETE in the same key. (in the same patch) + // + dynamicIndex != null && + Items.Contains(dynamicIndex) + ) { Items.Remove(dynamicIndex); Indexes.Remove(index);