From 28724078cc3bba0865fcaf8eb7d3345c49dcbae5 Mon Sep 17 00:00:00 2001 From: Boris Zbarsky Date: Mon, 21 Feb 2022 13:38:25 -0500 Subject: [PATCH] Remove unnecessary null-checks for exchange contexts. (#15370) The unit tests for this code no longer call it without an exchange context, so we can remove the workarounds. Fixes https://github.com/project-chip/connectedhomeip/issues/8031 --- src/app/ReadHandler.cpp | 22 ++++++---------------- 1 file changed, 6 insertions(+), 16 deletions(-) diff --git a/src/app/ReadHandler.cpp b/src/app/ReadHandler.cpp index 67751eeb400f79..21f557b4896287 100644 --- a/src/app/ReadHandler.cpp +++ b/src/app/ReadHandler.cpp @@ -152,10 +152,8 @@ CHIP_ERROR ReadHandler::OnStatusResponse(Messaging::ExchangeContext * apExchange { InteractionModelEngine::GetInstance()->GetReportingEngine().OnReportConfirm(); MoveToState(HandlerState::GeneratingReports); - if (mpExchangeCtx) - { - mpExchangeCtx->WillSendMessage(); - } + mpExchangeCtx->WillSendMessage(); + // Trigger ReportingEngine run for sending next chunk of data. SuccessOrExit(err = InteractionModelEngine::GetInstance()->GetReportingEngine().ScheduleRun()); } @@ -363,12 +361,7 @@ CHIP_ERROR ReadHandler::ProcessReadRequest(System::PacketBufferHandle && aPayloa ReturnErrorOnFailure(InteractionModelEngine::GetInstance()->GetReportingEngine().ScheduleRun()); - // mpExchangeCtx can be null here due to - // https://github.com/project-chip/connectedhomeip/issues/8031 - if (mpExchangeCtx) - { - mpExchangeCtx->WillSendMessage(); - } + mpExchangeCtx->WillSendMessage(); // There must be no code after the WillSendMessage() call that can cause // this method to return a failure. @@ -695,12 +688,9 @@ CHIP_ERROR ReadHandler::ProcessSubscribeRequest(System::PacketBufferHandle && aP MoveToState(HandlerState::GeneratingReports); InteractionModelEngine::GetInstance()->GetReportingEngine().ScheduleRun(); - // mpExchangeCtx can be null here due to - // https://github.com/project-chip/connectedhomeip/issues/8031 - if (mpExchangeCtx) - { - mpExchangeCtx->WillSendMessage(); - } + + mpExchangeCtx->WillSendMessage(); + return CHIP_NO_ERROR; }