diff --git a/src/app/clusters/scenes-server/ExtensionFieldSets.h b/src/app/clusters/scenes-server/ExtensionFieldSets.h index e05525e0586f02..d926ce3bbcd9c2 100644 --- a/src/app/clusters/scenes-server/ExtensionFieldSets.h +++ b/src/app/clusters/scenes-server/ExtensionFieldSets.h @@ -34,10 +34,10 @@ class ExtensionFieldSets ExtensionFieldSets(){}; virtual ~ExtensionFieldSets() = default; - virtual CHIP_ERROR Serialize(TLV::TLVWriter & writer, TLV::Tag structTa) const = 0; - virtual CHIP_ERROR Deserialize(TLV::TLVReader & reader, TLV::Tag structTa) = 0; - virtual void Clear() = 0; - virtual bool IsEmpty() const = 0; + virtual CHIP_ERROR Serialize(TLV::TLVWriter & writer) const = 0; + virtual CHIP_ERROR Deserialize(TLV::TLVReader & reader) = 0; + virtual void Clear() = 0; + virtual bool IsEmpty() const = 0; /// @brief Gets a count of how many initialized fields sets are in the object /// @return The number of initialized field sets the object /// @note Field set refers to extension field sets, from the scene cluster (see 1.4.6.2 ExtensionFieldSet in Matter Application diff --git a/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.cpp b/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.cpp index 489e6788be77f9..4ad9618158177b 100644 --- a/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.cpp +++ b/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.cpp @@ -20,12 +20,8 @@ namespace chip { namespace scenes { -// ExtensionFieldSetsImpl::ExtensionFieldSetsImpl() : ExtensionFieldSets() {} - -CHIP_ERROR ExtensionFieldSetsImpl::Serialize(TLV::TLVWriter & writer, TLV::Tag structTag) const +CHIP_ERROR ExtensionFieldSetsImpl::Serialize(TLV::TLVWriter & writer) const { - TLV::TLVType structureContainer; - ReturnErrorOnFailure(writer.StartContainer(structTag, TLV::kTLVType_Structure, structureContainer)); TLV::TLVType arrayContainer; ReturnErrorOnFailure( writer.StartContainer(TLV::ContextTag(TagEFS::kFieldSetArrayContainer), TLV::kTLVType_Array, arrayContainer)); @@ -34,16 +30,11 @@ CHIP_ERROR ExtensionFieldSetsImpl::Serialize(TLV::TLVWriter & writer, TLV::Tag s ReturnErrorOnFailure(mFieldSets[i].Serialize(writer)); } - ReturnErrorOnFailure(writer.EndContainer(arrayContainer)); - return writer.EndContainer(structureContainer); + return writer.EndContainer(arrayContainer); } -CHIP_ERROR ExtensionFieldSetsImpl::Deserialize(TLV::TLVReader & reader, TLV::Tag structTag) +CHIP_ERROR ExtensionFieldSetsImpl::Deserialize(TLV::TLVReader & reader) { - TLV::TLVType structureContainer; - ReturnErrorOnFailure(reader.Next(TLV::kTLVType_Structure, structTag)); - ReturnErrorOnFailure(reader.EnterContainer(structureContainer)); - TLV::TLVType arrayContainer; ReturnErrorOnFailure(reader.Next(TLV::kTLVType_Array, TLV::ContextTag(TagEFS::kFieldSetArrayContainer))); ReturnErrorOnFailure(reader.EnterContainer(arrayContainer)); @@ -69,8 +60,7 @@ CHIP_ERROR ExtensionFieldSetsImpl::Deserialize(TLV::TLVReader & reader, TLV::Tag return err; } - ReturnErrorOnFailure(reader.ExitContainer(arrayContainer)); - return reader.ExitContainer(structureContainer); + return reader.ExitContainer(arrayContainer); } void ExtensionFieldSetsImpl::Clear() diff --git a/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.h b/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.h index 381c592941b079..50b92878daf1ed 100644 --- a/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.h +++ b/src/app/clusters/scenes-server/ExtensionFieldSetsImpl.h @@ -122,8 +122,8 @@ class ExtensionFieldSetsImpl : public ExtensionFieldSets ~ExtensionFieldSetsImpl() override{}; // overrides - CHIP_ERROR Serialize(TLV::TLVWriter & writer, TLV::Tag structTag) const override; - CHIP_ERROR Deserialize(TLV::TLVReader & reader, TLV::Tag structTag) override; + CHIP_ERROR Serialize(TLV::TLVWriter & writer) const override; + CHIP_ERROR Deserialize(TLV::TLVReader & reader) override; void Clear() override; bool IsEmpty() const override { return (mFieldSetsCount == 0); } uint8_t GetFieldSetCount() const override { return mFieldSetsCount; }; diff --git a/src/app/clusters/scenes-server/SceneTableImpl.cpp b/src/app/clusters/scenes-server/SceneTableImpl.cpp index 19dd0dc79d1b18..a0cc24a8e4516e 100644 --- a/src/app/clusters/scenes-server/SceneTableImpl.cpp +++ b/src/app/clusters/scenes-server/SceneTableImpl.cpp @@ -39,7 +39,6 @@ enum class TagScene : uint8_t kSceneID, kName, kTransitionTimeMs, - kExtensionFieldSetsContainer, }; using SceneTableEntry = DefaultSceneTableImpl::SceneTableEntry; @@ -99,7 +98,7 @@ struct EndpointSceneCount : public PersistentDataSerialize(writer, TLV::ContextTag(TagTestEFS::kEFS))); + NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == EFS->Serialize(writer)); writer.EndContainer(outer); sceneEFS_serialized_length = writer.GetLengthWritten(); NL_TEST_ASSERT(aSuite, sceneEFS_serialized_length <= kPersistentSceneBufferMax); @@ -243,7 +243,7 @@ void TestSerializeDerializeExtensionFieldSet(nlTestSuite * aSuite, void * aConte reader.Init(sceneEFSBuffer); NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == reader.Next()); NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == reader.EnterContainer(outerRead)); - NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == testSceneEFS.Deserialize(reader, TLV::ContextTag(TagTestEFS::kEFS))); + NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == testSceneEFS.Deserialize(reader)); NL_TEST_ASSERT(aSuite, CHIP_NO_ERROR == reader.ExitContainer(outerRead)); NL_TEST_ASSERT(aSuite, *EFS == testSceneEFS); diff --git a/src/lib/core/CHIPConfig.h b/src/lib/core/CHIPConfig.h index 7cdd629d393d2c..0fa3e6e257988f 100644 --- a/src/lib/core/CHIPConfig.h +++ b/src/lib/core/CHIPConfig.h @@ -1484,16 +1484,16 @@ extern const char CHIP_NON_PRODUCTION_MARKER[]; * } * * Including all the TLV fields, the following values can help estimate the needed size for a scenes given a number of clusters: - * Empty EFS Scene Max name size: 33bytes - * Scene Max name size + OnOff : 51 bytes - * Scene Max name size + LevelControl : 60 bytes - * Scene Max name size + ColorControl : 126 bytes - * Scene Max name size + OnOff + LevelControl + ColoControl : 171 bytes + * Empty EFS Scene Max name size: 37 bytes + * Scene Max name size + OnOff : 55 bytes + * Scene Max name size + LevelControl : 64 bytes + * Scene Max name size + ColorControl : 130 bytes + * Scene Max name size + OnOff + LevelControl + ColoControl : 175 bytes * * Cluster Sizes: - * OnOff Cluster Max Size: 18 bytes - * LevelControl Cluster Max Size: 27 bytes - * Color Control Cluster Max Size: 93 bytes + * OnOff Cluster Max Size: 21 bytes + * LevelControl Cluster Max Size: 30 bytes + * Color Control Cluster Max Size: 96 bytes * */ #ifndef CHIP_CONFIG_SCENES_MAX_SERIALIZED_SCENE_SIZE_BYTES #define CHIP_CONFIG_SCENES_MAX_SERIALIZED_SCENE_SIZE_BYTES 256