Skip to content

Commit

Permalink
tv-casting-app fixes: saving prevValue before callback
Browse files Browse the repository at this point in the history
  • Loading branch information
sharadb-amazon committed Apr 3, 2024
1 parent c1f823e commit 364efec
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 13 deletions.
8 changes: 4 additions & 4 deletions examples/tv-casting-app/APIs.md
Original file line number Diff line number Diff line change
Expand Up @@ -917,14 +917,14 @@ On iOS refer to the following platform specific files:
1. For a list of clusters, commands and attributes supported by the Matter TV
Casting library:
[/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCClusterObjects.h](/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCClusterObjects.h)
[darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCClusterObjects.h](darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCClusterObjects.h)
2. For the IDs and request / response types to use with the commands:
[/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandObjects.h](/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandObjects.h)
[darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandObjects.h](darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandObjects.h)
and
[/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandPayloads.h](/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandPayloads.h)
[darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandPayloads.h](darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCCommandPayloads.h)
3. For attribute [read operations](#read-operations) and
[subscriptions](#subscriptions):
[/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCAttributeObjects.h](/darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCAttributeObjects.h)
[darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCAttributeObjects.h](darwin/MatterTvCastingBridge/MatterTvCastingBridge/zap-generated/MCAttributeObjects.h)
### Issuing Commands
Expand Down
1 change: 1 addition & 0 deletions examples/tv-casting-app/linux/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,7 @@ CHIP_ERROR ProcessClusterCommand(int argc, char ** argv)

int main(int argc, char * argv[])
{
ChipLogProgress(AppServer, "chip_casting_simplified = 0");
VerifyOrDie(CHIP_NO_ERROR == chip::Platform::MemoryInit());
VerifyOrDie(CHIP_NO_ERROR == chip::DeviceLayer::PlatformMgr().InitChipStack());

Expand Down
1 change: 1 addition & 0 deletions examples/tv-casting-app/linux/simple-app.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,7 @@ class CommonCaseDeviceServerInitParamsProvider : public ServerInitParamsProvider

int main(int argc, char * argv[])
{
ChipLogProgress(AppServer, "chip_casting_simplified = 1");
// Create AppParameters that need to be passed to CastingApp.Initialize()
AppParameters appParameters;
RotatingDeviceIdUniqueIdProvider rotatingDeviceIdUniqueIdProvider;
Expand Down
23 changes: 14 additions & 9 deletions examples/tv-casting-app/tv-casting-common/core/Attribute.h
Original file line number Diff line number Diff line change
Expand Up @@ -97,16 +97,19 @@ class Attribute
static_cast<ReadAttributeContext<TypeInfo> *>(__context);
ChipLogProgress(AppServer, "<Attribute>::Read() success");
Attribute<TypeInfo> * __attr = static_cast<Attribute<TypeInfo> *>(__attributeContext->mAttribute);
__attr->value = response;
if (__attr->hasValue)
{
__attributeContext->mSuccessCb(__attributeContext->mClientContext,
chip::MakeOptional(__attr->value), response);
typename TypeInfo::DecodableType prevValue = __attr->value;
__attr->value = response;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::MakeOptional(prevValue),
__attr->value);
}
else
{
__attr->hasValue = true;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::NullOptional, response);
__attr->value = response;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::NullOptional,
__attr->value);
}
delete __attributeContext;
},
Expand Down Expand Up @@ -269,17 +272,19 @@ class Attribute
static_cast<SubscribeAttributeContext<TypeInfo> *>(__context);
ChipLogProgress(AppServer, "<Attribute>::Subscribe() success");
Attribute<TypeInfo> * __attr = static_cast<Attribute<TypeInfo> *>(__attributeContext->mAttribute);
__attr->value = response;
// TODO: Save old value and then overwrite
if (__attr->hasValue)
{
__attributeContext->mSuccessCb(__attributeContext->mClientContext,
chip::MakeOptional(__attr->value), response);
typename TypeInfo::DecodableType prevValue = __attr->value;
__attr->value = response;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::MakeOptional(prevValue),
__attr->value);
}
else
{
__attr->hasValue = true;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::NullOptional, response);
__attr->value = response;
__attributeContext->mSuccessCb(__attributeContext->mClientContext, chip::NullOptional,
__attr->value);
}
delete __attributeContext;
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,9 @@
#define CHIP_CONFIG_EXAMPLE_ACCESS_CONTROL_MAX_SUBJECTS_PER_ENTRY 20
#define CHIP_CONFIG_EXAMPLE_ACCESS_CONTROL_MAX_ENTRIES_PER_FABRIC 20

// For casting, we need to allow for more binding table entries
#define MATTER_BINDING_TABLE_SIZE 64

// Enable some test-only interaction model APIs.
#define CONFIG_BUILD_FOR_HOST_UNIT_TEST 1

Expand Down

0 comments on commit 364efec

Please sign in to comment.