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