Skip to content

Commit

Permalink
address comments
Browse files Browse the repository at this point in the history
  • Loading branch information
yunhanw-google committed Oct 31, 2024
1 parent 44484ae commit 2ad287b
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 26 deletions.
32 changes: 26 additions & 6 deletions src/app/BufferedReadCallback.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,12 @@ void BufferedReadCallback::OnReportBegin()

void BufferedReadCallback::OnReportEnd()
{
mLastError = DispatchBufferedData(mBufferedPath, StatusIB(), true);
ReturnOnFailure(mLastError);
mDataBufferingError = DispatchBufferedData(mBufferedPath, StatusIB(), true);
if (mDataBufferingError != CHIP_NO_ERROR)
{
mCallback.OnError(mDataBufferingError);
return;
}
mCallback.OnReportEnd();
}

Expand Down Expand Up @@ -225,19 +229,35 @@ CHIP_ERROR BufferedReadCallback::DispatchBufferedData(const ConcreteAttributePat
void BufferedReadCallback::OnAttributeData(const ConcreteDataAttributePath & aPath, TLV::TLVReader * apData,
const StatusIB & aStatus)
{
if (mDataBufferingError != CHIP_NO_ERROR)
{
ChipLogError(DataManagement,
"Skipping AttributeData: (%u, " ChipLogFormatMEI ", " ChipLogFormatMEI ") '%" CHIP_ERROR_FORMAT "'",
aPath.mEndpointId, ChipLogValueMEI(aPath.mClusterId),
ChipLogValueMEI(aPath.mAttributeId), mDataBufferingError.Format());
return;
}
//
// First, let's dispatch to our registered callback any buffered up list data from previous calls.
//
mLastError = DispatchBufferedData(aPath, aStatus);
ReturnOnFailure(mLastError);
mDataBufferingError = DispatchBufferedData(aPath, aStatus);
if (mDataBufferingError != CHIP_NO_ERROR)
{
mCallback.OnError(mDataBufferingError);
return;
}

//
// We buffer up list data (only if the status was successful)
//
if (aPath.IsListOperation() && aStatus.mStatus == Protocols::InteractionModel::Status::Success)
{
mLastError = BufferData(aPath, apData);
ReturnOnFailure(mLastError);
mDataBufferingError = BufferData(aPath, apData);
if (mDataBufferingError != CHIP_NO_ERROR)
{
mCallback.OnError(mDataBufferingError);
return;
}
}
else
{
Expand Down
15 changes: 1 addition & 14 deletions src/app/BufferedReadCallback.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,18 +43,6 @@ class BufferedReadCallback : public ReadClient::Callback
BufferedReadCallback(Callback & callback) : mCallback(callback) {}

private:
/*
* Get the last internal fatal error in BufferedReadCallback
* @retval #CHIP_NO_ERROR If the method succeeded.
* @retval #CHIP_ERROR_INVALID_TLV_ELEMENT
* If bufferred list data is not TLV Array
* @retval #CHIP_ERROR_NO_MEMORY
* If an attempt to allocate an buffer failed due to lack of
* memory.
* @retval other Other CHIP or platform-specific errors.
*/
CHIP_ERROR GetLastError() const override { return mLastError; }

/*
* Generates the reconstituted TLV array from the stored individual list elements
*/
Expand Down Expand Up @@ -86,7 +74,6 @@ class BufferedReadCallback : public ReadClient::Callback
void OnError(CHIP_ERROR aError) override
{
mBufferedList.clear();
mLastError = CHIP_NO_ERROR;
return mCallback.OnError(aError);
}

Expand Down Expand Up @@ -144,7 +131,7 @@ class BufferedReadCallback : public ReadClient::Callback
ConcreteDataAttributePath mBufferedPath;
std::vector<System::PacketBufferHandle> mBufferedList;
Callback & mCallback;
CHIP_ERROR mLastError = CHIP_NO_ERROR;
CHIP_ERROR mDataBufferingError = CHIP_NO_ERROR;
};

} // namespace app
Expand Down
3 changes: 2 additions & 1 deletion src/app/ReadClient.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -868,7 +868,8 @@ CHIP_ERROR ReadClient::ProcessAttributeReportIBs(TLV::TLVReader & aAttributeRepo
{
err = CHIP_NO_ERROR;
}
return mpCallback.GetLastError();

return err;
}

CHIP_ERROR ReadClient::ProcessEventReportIBs(TLV::TLVReader & aEventReportIBsReader)
Expand Down
5 changes: 0 additions & 5 deletions src/app/ReadClient.h
Original file line number Diff line number Diff line change
Expand Up @@ -284,11 +284,6 @@ class ReadClient : public Messaging::ExchangeDelegate
* things like min/max intervals based on the session parameters).
*/
virtual void OnCASESessionEstablished(const SessionHandle & aSession, ReadPrepareParams & aSubscriptionParams) {}

/*
* Get the last internal fatal error in callback
*/
virtual CHIP_ERROR GetLastError() const { return CHIP_NO_ERROR; }
};

enum class InteractionType : uint8_t
Expand Down

0 comments on commit 2ad287b

Please sign in to comment.