#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);
}
}
}
}