#region Copyright notice and license // Copyright 2018 The gRPC Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #endregion using System; using System.Buffers; namespace Grpc.Core { /// /// Provides storage for payload when serializing a message. /// public abstract class SerializationContext { /// /// Use the byte array as serialized form of current message and mark serialization process as complete. /// Complete(byte[]) can only be called once. By calling this method the caller gives up the ownership of the /// payload which must not be accessed afterwards. /// /// the serialized form of current message public virtual void Complete(byte[] payload) { throw new NotImplementedException(); } /// /// Gets buffer writer that can be used to write the serialized data. Once serialization is finished, /// Complete() needs to be called. /// public virtual IBufferWriter GetBufferWriter() { throw new NotImplementedException(); } /// /// Sets the payload length when writing serialized data into a buffer writer. If the serializer knows the full payload /// length in advance, providing that information before obtaining the buffer writer using GetBufferWriter() can improve /// serialization efficiency by avoiding copies. The provided payload length must be the same as the data written to the writer. /// Calling this method is optional. If the payload length is not set then the length is calculated using the data written to /// the buffer writer when Complete() is called. /// /// The total length of the payload in bytes. public virtual void SetPayloadLength(int payloadLength) { } /// /// Complete the payload written to the buffer writer. Complete() can only be called once. /// public virtual void Complete() { throw new NotImplementedException(); } } }