mirror of https://github.com/grpc/grpc.git
parent
8a86f5329e
commit
26d3e774df
3 changed files with 181 additions and 12 deletions
@ -0,0 +1,49 @@ |
|||||||
|
#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 |
||||||
|
|
||||||
|
namespace Grpc.Core |
||||||
|
{ |
||||||
|
/// <summary> |
||||||
|
/// Provides access to the payload being deserialized when deserializing messages. |
||||||
|
/// </summary> |
||||||
|
public abstract class DeserializationContext |
||||||
|
{ |
||||||
|
/// <summary> |
||||||
|
/// Returns <c>true</c> if there is a payload to deserialize (= payload is not null), <c>false</c> otherwise. |
||||||
|
/// </summary> |
||||||
|
public virtual bool HasPayload => PayloadLength.HasValue; |
||||||
|
|
||||||
|
/// <summary> |
||||||
|
/// Get the total length of the payload in bytes or <c>null</c> if the payload is null. |
||||||
|
/// </summary> |
||||||
|
public abstract int? PayloadLength { get; } |
||||||
|
|
||||||
|
/// <summary> |
||||||
|
/// Gets the entire payload as a newly allocated byte array. |
||||||
|
/// Once the byte array is returned, the byte array becomes owned by the caller and won't be ever accessed or reused by gRPC again. |
||||||
|
/// NOTE: Obtaining the buffer as a newly allocated byte array is the simplest way of accessing the payload, |
||||||
|
/// but it can have important consequences in high-performance scenarios. |
||||||
|
/// In particular, using this method usually requires copying of the entire buffer one extra time. |
||||||
|
/// Also, allocating a new buffer each time can put excessive pressure on GC, especially if |
||||||
|
/// the payload is more than 86700 bytes large (which means the newly allocated buffer will be placed in LOH, |
||||||
|
/// and LOH object can only be garbage collected via a full ("stop the world") GC run). |
||||||
|
/// </summary> |
||||||
|
/// <returns>byte array containing the entire payload or null if there is no payload.</returns> |
||||||
|
public abstract byte[] PayloadAsNewBuffer(); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,34 @@ |
|||||||
|
#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 |
||||||
|
|
||||||
|
namespace Grpc.Core |
||||||
|
{ |
||||||
|
/// <summary> |
||||||
|
/// Provides storage for payload when serializing a message. |
||||||
|
/// </summary> |
||||||
|
public abstract class SerializationContext |
||||||
|
{ |
||||||
|
/// <summary> |
||||||
|
/// Use the byte array as serialized form of current message and mark serialization process as complete. |
||||||
|
/// Complete() can only be called once. By calling this method the caller gives up the ownership of the |
||||||
|
/// payload which must not be accessed afterwards. |
||||||
|
/// </summary> |
||||||
|
/// <param name="payload">the serialized form of current message</param> |
||||||
|
public abstract void Complete(byte[] payload); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue