Line data Source code
1 : /** 2 : * 3 : * Copyright (c) 2021 Project CHIP Authors 4 : * 5 : * Licensed under the Apache License, Version 2.0 (the "License"); 6 : * you may not use this file except in compliance with the License. 7 : * You may obtain a copy of the License at 8 : * 9 : * http://www.apache.org/licenses/LICENSE-2.0 10 : * 11 : * Unless required by applicable law or agreed to in writing, software 12 : * distributed under the License is distributed on an "AS IS" BASIS, 13 : * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 : * See the License for the specific language governing permissions and 15 : * limitations under the License. 16 : */ 17 : 18 : #pragma once 19 : 20 : #include <app/AppConfig.h> 21 : #include <app/util/basic-types.h> 22 : #include <lib/core/CHIPCore.h> 23 : #include <lib/core/TLV.h> 24 : #include <lib/support/CodeUtils.h> 25 : #include <lib/support/logging/CHIPLogging.h> 26 : 27 : #include "ArrayBuilder.h" 28 : #include "ArrayParser.h" 29 : #include "InvokeResponseIB.h" 30 : 31 : namespace chip { 32 : namespace app { 33 : namespace InvokeResponseIBs { 34 : class Parser : public ArrayParser 35 : { 36 : public: 37 : #if CHIP_CONFIG_IM_PRETTY_PRINT 38 : CHIP_ERROR PrettyPrint() const; 39 : #endif // CHIP_CONFIG_IM_PRETTY_PRINT 40 : }; 41 : 42 : class Builder : public ArrayBuilder 43 : { 44 : public: 45 : /** 46 : * @brief Performs underlying StructBuilder::Init, but reserves memory need in 47 : * EndOfInvokeResponses() with underlying TLVWriter. 48 : */ 49 : CHIP_ERROR InitWithEndBufferReserved(TLV::TLVWriter * const apWriter, const uint8_t aContextTagToUse); 50 : 51 : /** 52 : * @brief Initialize a InvokeResponseIB::Builder for writing into the TLV stream 53 : * 54 : * @return A reference to InvokeResponseIB::Builder 55 : */ 56 : InvokeResponseIB::Builder & CreateInvokeResponse(); 57 : 58 : /** 59 : * @return A reference to InvokeResponseIB::Builder 60 : */ 61 194 : InvokeResponseIB::Builder & GetInvokeResponse() { return mInvokeResponse; }; 62 : 63 : /** 64 : * @brief Mark the end of this InvokeResponseIBs 65 : * 66 : * @return The builder's final status. 67 : */ 68 : CHIP_ERROR EndOfInvokeResponses(); 69 : 70 : /** 71 : * @brief Get number of bytes required in the buffer by EndOfInvokeResponses() 72 : * 73 : * @return Expected number of bytes required in the buffer by EndOfInvokeResponses() 74 : */ 75 : uint32_t GetSizeToEndInvokeResponses(); 76 : 77 : private: 78 : InvokeResponseIB::Builder mInvokeResponse; 79 : bool mIsEndBufferReserved = false; 80 : }; 81 : } // namespace InvokeResponseIBs 82 : } // namespace app 83 : } // namespace chip