#if !NO_RUNTIME using System; #if FEAT_IKVM using Type = IKVM.Reflection.Type; using IKVM.Reflection; #else using System.Reflection; #endif namespace ProtoBuf.Serializers { sealed class DateTimeSerializer : IProtoSerializer { #if FEAT_IKVM readonly Type expectedType; #else static readonly Type expectedType = typeof(DateTime); #endif public Type ExpectedType { get { return expectedType; } } bool IProtoSerializer.RequiresOldValue { get { return false; } } bool IProtoSerializer.ReturnsValue { get { return true; } } private readonly bool includeKind; public DateTimeSerializer(ProtoBuf.Meta.TypeModel model) { #if FEAT_IKVM expectedType = model.MapType(typeof(DateTime)); #endif includeKind = model != null && model.SerializeDateTimeKind(); } #if !FEAT_IKVM public object Read(object value, ProtoReader source) { Helpers.DebugAssert(value == null); // since replaces return BclHelpers.ReadDateTime(source); } public void Write(object value, ProtoWriter dest) { if(includeKind) BclHelpers.WriteDateTimeWithKind((DateTime)value, dest); else BclHelpers.WriteDateTime((DateTime)value, dest); } #endif #if FEAT_COMPILER void IProtoSerializer.EmitWrite(Compiler.CompilerContext ctx, Compiler.Local valueFrom) { ctx.EmitWrite(ctx.MapType(typeof(BclHelpers)), includeKind ? "WriteDateTimeWithKind" : "WriteDateTime", valueFrom); } void IProtoSerializer.EmitRead(Compiler.CompilerContext ctx, Compiler.Local valueFrom) { ctx.EmitBasicRead(ctx.MapType(typeof(BclHelpers)), "ReadDateTime", ExpectedType); } #endif } } #endif