From 97dcea8b03c00951eb431eaf8ec98bea3506704d Mon Sep 17 00:00:00 2001 From: CodeChronos <1197535+CodeChronos928@users.noreply.github.com> Date: Tue, 31 May 2022 18:21:55 -0700 Subject: [PATCH] Support const ClusterStateCache accessor calls. Allow read-only accessor calls to be made on const ClusterStateCache objects. --- src/app/ClusterStateCache.cpp | 21 ++++++++++--------- src/app/ClusterStateCache.h | 38 ++++++++++++++++++----------------- 2 files changed, 31 insertions(+), 28 deletions(-) diff --git a/src/app/ClusterStateCache.cpp b/src/app/ClusterStateCache.cpp index e7aaca424055fe..d6cd9645667b6d 100644 --- a/src/app/ClusterStateCache.cpp +++ b/src/app/ClusterStateCache.cpp @@ -209,7 +209,7 @@ void ClusterStateCache::OnReportEnd() mCallback.OnReportEnd(); } -CHIP_ERROR ClusterStateCache::Get(const ConcreteAttributePath & path, TLV::TLVReader & reader) +CHIP_ERROR ClusterStateCache::Get(const ConcreteAttributePath & path, TLV::TLVReader & reader) const { CHIP_ERROR err; auto attributeState = GetAttributeState(path.mEndpointId, path.mClusterId, path.mAttributeId, err); @@ -224,7 +224,7 @@ CHIP_ERROR ClusterStateCache::Get(const ConcreteAttributePath & path, TLV::TLVRe return reader.Next(); } -CHIP_ERROR ClusterStateCache::Get(EventNumber eventNumber, TLV::TLVReader & reader) +CHIP_ERROR ClusterStateCache::Get(EventNumber eventNumber, TLV::TLVReader & reader) const { CHIP_ERROR err; @@ -240,7 +240,7 @@ CHIP_ERROR ClusterStateCache::Get(EventNumber eventNumber, TLV::TLVReader & read return CHIP_NO_ERROR; } -ClusterStateCache::EndpointState * ClusterStateCache::GetEndpointState(EndpointId endpointId, CHIP_ERROR & err) +const ClusterStateCache::EndpointState * ClusterStateCache::GetEndpointState(EndpointId endpointId, CHIP_ERROR & err) const { auto endpointIter = mCache.find(endpointId); if (endpointIter == mCache.end()) @@ -253,7 +253,8 @@ ClusterStateCache::EndpointState * ClusterStateCache::GetEndpointState(EndpointI return &endpointIter->second; } -ClusterStateCache::ClusterState * ClusterStateCache::GetClusterState(EndpointId endpointId, ClusterId clusterId, CHIP_ERROR & err) +const ClusterStateCache::ClusterState * ClusterStateCache::GetClusterState(EndpointId endpointId, ClusterId clusterId, + CHIP_ERROR & err) const { auto endpointState = GetEndpointState(endpointId, err); if (err != CHIP_NO_ERROR) @@ -273,7 +274,7 @@ ClusterStateCache::ClusterState * ClusterStateCache::GetClusterState(EndpointId } const ClusterStateCache::AttributeState * ClusterStateCache::GetAttributeState(EndpointId endpointId, ClusterId clusterId, - AttributeId attributeId, CHIP_ERROR & err) + AttributeId attributeId, CHIP_ERROR & err) const { auto clusterState = GetClusterState(endpointId, clusterId, err); if (err != CHIP_NO_ERROR) @@ -292,7 +293,7 @@ const ClusterStateCache::AttributeState * ClusterStateCache::GetAttributeState(E return &attributeState->second; } -const ClusterStateCache::EventData * ClusterStateCache::GetEventData(EventNumber eventNumber, CHIP_ERROR & err) +const ClusterStateCache::EventData * ClusterStateCache::GetEventData(EventNumber eventNumber, CHIP_ERROR & err) const { EventData compareKey; @@ -338,7 +339,7 @@ void ClusterStateCache::OnAttributeData(const ConcreteDataAttributePath & aPath, mCallback.OnAttributeData(aPath, apData ? &dataSnapshot : nullptr, aStatus); } -CHIP_ERROR ClusterStateCache::GetVersion(const ConcreteClusterPath & aPath, Optional & aVersion) +CHIP_ERROR ClusterStateCache::GetVersion(const ConcreteClusterPath & aPath, Optional & aVersion) const { VerifyOrReturnError(aPath.IsValidConcreteClusterPath(), CHIP_ERROR_INVALID_ARGUMENT); CHIP_ERROR err; @@ -362,7 +363,7 @@ void ClusterStateCache::OnEventData(const EventHeader & aEventHeader, TLV::TLVRe mCallback.OnEventData(aEventHeader, apData ? &dataSnapshot : nullptr, apStatus); } -CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteAttributePath & path, StatusIB & status) +CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteAttributePath & path, StatusIB & status) const { CHIP_ERROR err; @@ -378,7 +379,7 @@ CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteAttributePath & path, Stat return CHIP_NO_ERROR; } -CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteEventPath & path, StatusIB & status) +CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteEventPath & path, StatusIB & status) const { auto statusIter = mEventStatusCache.find(path); if (statusIter == mEventStatusCache.end()) @@ -390,7 +391,7 @@ CHIP_ERROR ClusterStateCache::GetStatus(const ConcreteEventPath & path, StatusIB return CHIP_NO_ERROR; } -void ClusterStateCache::GetSortedFilters(std::vector> & aVector) +void ClusterStateCache::GetSortedFilters(std::vector> & aVector) const { for (auto const & endpointIter : mCache) { diff --git a/src/app/ClusterStateCache.h b/src/app/ClusterStateCache.h index be6308aee1dadd..89e76ae75d8dee 100644 --- a/src/app/ClusterStateCache.h +++ b/src/app/ClusterStateCache.h @@ -129,7 +129,7 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR Get(const ConcreteAttributePath & path, typename AttributeObjectTypeT::DecodableType & value) + CHIP_ERROR Get(const ConcreteAttributePath & path, typename AttributeObjectTypeT::DecodableType & value) const { TLV::TLVReader reader; @@ -152,7 +152,7 @@ class ClusterStateCache : protected ReadClient::Callback * - If data exists in the cache instead of status, CHIP_ERROR_INVALID_ARGUMENT shall be returned. * */ - CHIP_ERROR GetStatus(const ConcreteAttributePath & path, StatusIB & status); + CHIP_ERROR GetStatus(const ConcreteAttributePath & path, StatusIB & status) const; /* * Encapsulates a StatusIB and a ConcreteAttributePath pair. @@ -184,7 +184,8 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR Get(EndpointId endpointId, ClusterId clusterId, ClusterObjectTypeT & value, std::list & statusList) + CHIP_ERROR Get(EndpointId endpointId, ClusterId clusterId, ClusterObjectTypeT & value, + std::list & statusList) const { statusList.clear(); @@ -228,7 +229,7 @@ class ClusterStateCache : protected ReadClient::Callback * shall be returned from this call instead. The actual StatusIB can be retrieved using the GetStatus() API above. * */ - CHIP_ERROR Get(const ConcreteAttributePath & path, TLV::TLVReader & reader); + CHIP_ERROR Get(const ConcreteAttributePath & path, TLV::TLVReader & reader) const; /* * Retrieve the data version for the given cluster. If there is no data for the specified path in the cache, @@ -236,7 +237,7 @@ class ClusterStateCache : protected ReadClient::Callback * current data version for the cluster (which may have no value if we don't have a known data version * for it, for example because none of our paths were wildcards that covered the whole cluster). */ - CHIP_ERROR GetVersion(const ConcreteClusterPath & path, Optional & aVersion); + CHIP_ERROR GetVersion(const ConcreteClusterPath & path, Optional & aVersion) const; /* * Get highest received event number. @@ -271,7 +272,7 @@ class ClusterStateCache : protected ReadClient::Callback */ template - CHIP_ERROR Get(EventNumber eventNumber, EventObjectTypeT & value) + CHIP_ERROR Get(EventNumber eventNumber, EventObjectTypeT & value) const { TLV::TLVReader reader; CHIP_ERROR err; @@ -297,7 +298,7 @@ class ClusterStateCache : protected ReadClient::Callback * shall be returned. * */ - CHIP_ERROR Get(EventNumber eventNumber, TLV::TLVReader & reader); + CHIP_ERROR Get(EventNumber eventNumber, TLV::TLVReader & reader) const; /* * Retrieve the StatusIB for a specific event from the event status cache (if one exists). @@ -308,7 +309,7 @@ class ClusterStateCache : protected ReadClient::Callback * NOTE: Receipt of a StatusIB does not affect any pre-existing or future event data entries in the cache (and vice-versa). * */ - CHIP_ERROR GetStatus(const ConcreteEventPath & path, StatusIB & status); + CHIP_ERROR GetStatus(const ConcreteEventPath & path, StatusIB & status) const; /* * Execute an iterator function that is called for every attribute @@ -327,7 +328,7 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR ForEachAttribute(EndpointId endpointId, ClusterId clusterId, IteratorFunc func) + CHIP_ERROR ForEachAttribute(EndpointId endpointId, ClusterId clusterId, IteratorFunc func) const { CHIP_ERROR err; @@ -357,7 +358,7 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR ForEachAttribute(ClusterId clusterId, IteratorFunc func) + CHIP_ERROR ForEachAttribute(ClusterId clusterId, IteratorFunc func) const { for (auto & endpointIter : mCache) { @@ -390,7 +391,7 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR ForEachCluster(EndpointId endpointId, IteratorFunc func) + CHIP_ERROR ForEachCluster(EndpointId endpointId, IteratorFunc func) const { auto endpointIter = mCache.find(endpointId); if (endpointIter->first == endpointId) @@ -426,7 +427,7 @@ class ClusterStateCache : protected ReadClient::Callback */ template CHIP_ERROR ForEachEventData(IteratorFunc func, EventPathParams pathFilter = EventPathParams(), - EventNumber minEventNumberFilter = 0) + EventNumber minEventNumberFilter = 0) const { for (const auto & item : mEventDataCache) { @@ -453,7 +454,7 @@ class ClusterStateCache : protected ReadClient::Callback * */ template - CHIP_ERROR ForEachEventStatus(IteratorFunc func) + CHIP_ERROR ForEachEventStatus(IteratorFunc func) const { for (const auto & item : mEventStatusCache) { @@ -532,11 +533,12 @@ class ClusterStateCache : protected ReadClient::Callback * CHIP_ERROR_KEY_NOT_FOUND shall be returned. * */ - EndpointState * GetEndpointState(EndpointId endpointId, CHIP_ERROR & err); - ClusterState * GetClusterState(EndpointId endpointId, ClusterId clusterId, CHIP_ERROR & err); - const AttributeState * GetAttributeState(EndpointId endpointId, ClusterId clusterId, AttributeId attributeId, CHIP_ERROR & err); + const EndpointState * GetEndpointState(EndpointId endpointId, CHIP_ERROR & err) const; + const ClusterState * GetClusterState(EndpointId endpointId, ClusterId clusterId, CHIP_ERROR & err) const; + const AttributeState * GetAttributeState(EndpointId endpointId, ClusterId clusterId, AttributeId attributeId, + CHIP_ERROR & err) const; - const EventData * GetEventData(EventNumber number, CHIP_ERROR & err); + const EventData * GetEventData(EventNumber number, CHIP_ERROR & err) const; /* * Updates the state of an attribute in the cache given a reader. If the reader is null, the state is updated @@ -589,7 +591,7 @@ class ClusterStateCache : protected ReadClient::Callback // Get our list of data version filters, sorted from larges to smallest by the total size of the TLV // payload for the filter's cluster. Applying filters in this order should maximize space savings // on the wire if not all filters can be applied. - void GetSortedFilters(std::vector> & aVector); + void GetSortedFilters(std::vector> & aVector) const; CHIP_ERROR GetElementTLVSize(TLV::TLVReader * apData, size_t & aSize);