#region Copyright notice and license // Copyright 2015 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 Grpc.Core.Utils; namespace Grpc.Core { /// /// Encapsulates the logic for serializing and deserializing messages. /// public class Marshaller { readonly Func serializer; readonly Func deserializer; /// /// Initializes a new marshaller. /// /// Function that will be used to serialize messages. /// Function that will be used to deserialize messages. public Marshaller(Func serializer, Func deserializer) { this.serializer = GrpcPreconditions.CheckNotNull(serializer, "serializer"); this.deserializer = GrpcPreconditions.CheckNotNull(deserializer, "deserializer"); } /// /// Gets the serializer function. /// public Func Serializer { get { return this.serializer; } } /// /// Gets the deserializer function. /// public Func Deserializer { get { return this.deserializer; } } } /// /// Utilities for creating marshallers. /// public static class Marshallers { /// /// Creates a marshaller from specified serializer and deserializer. /// public static Marshaller Create(Func serializer, Func deserializer) { return new Marshaller(serializer, deserializer); } /// /// Returns a marshaller for string type. This is useful for testing. /// public static Marshaller StringMarshaller { get { return new Marshaller(System.Text.Encoding.UTF8.GetBytes, System.Text.Encoding.UTF8.GetString); } } } }