mirror of
https://github.com/simtactics/mysimulation.git
synced 2025-03-20 16:51:21 +00:00
- NioTSO client isn't needed because we're using RayLib - Added FreeSO's API server to handle most backend operations
106 lines
3.8 KiB
C#
Executable file
106 lines
3.8 KiB
C#
Executable file
using FSO.Common.Serialization.TypeSerializers;
|
|
using Mina.Core.Buffer;
|
|
using System;
|
|
using System.Collections.Concurrent;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
|
|
namespace FSO.Common.Serialization
|
|
{
|
|
public class ModelSerializer : IModelSerializer
|
|
{
|
|
private List<ITypeSerializer> TypeSerializers = new List<ITypeSerializer>();
|
|
private ConcurrentDictionary<Type, ITypeSerializer> SerialCache = new ConcurrentDictionary<Type, ITypeSerializer>();
|
|
private ConcurrentDictionary<uint, ITypeSerializer> DeserialCache = new ConcurrentDictionary<uint, ITypeSerializer>();
|
|
|
|
public ModelSerializer(){
|
|
//Built-in
|
|
AddTypeSerializer(new cTSOValueBoolean());
|
|
AddTypeSerializer(new cTSOValueBooleanVector());
|
|
AddTypeSerializer(new cTSOValueBooleanMap());
|
|
AddTypeSerializer(new cTSOValueString());
|
|
AddTypeSerializer(new cTSOValueStringVector());
|
|
AddTypeSerializer(new cTSOValueByte());
|
|
AddTypeSerializer(new cTSOValueByteVector());
|
|
AddTypeSerializer(new cTSOValueSByte());
|
|
AddTypeSerializer(new cTSOValueSByteVector());
|
|
|
|
AddTypeSerializer(new cTSOValueUInt32());
|
|
AddTypeSerializer(new cTSOValueUInt32Vector());
|
|
|
|
AddTypeSerializer(new cTSOValueUInt16());
|
|
AddTypeSerializer(new cTSOValueDecorated());
|
|
AddTypeSerializer(new cTSOValueUInt64());
|
|
|
|
AddTypeSerializer(new cTSOValueGenericData());
|
|
}
|
|
|
|
|
|
public uint? GetClsid(object value)
|
|
{
|
|
if (value == null) { return null; }
|
|
var serializer = GetSerializer(value.GetType());
|
|
if (serializer == null) { return null; }
|
|
return serializer.GetClsid(value);
|
|
}
|
|
|
|
public void Serialize(IoBuffer output, object obj, ISerializationContext context)
|
|
{
|
|
if (obj == null) { return; }
|
|
var serializer = GetSerializer(obj.GetType());
|
|
if (serializer == null) { return; }
|
|
|
|
serializer.Serialize(output, obj, context);
|
|
}
|
|
|
|
|
|
public void Serialize(IoBuffer output, object value, ISerializationContext context, bool clsIdPrefix)
|
|
{
|
|
if (value == null) { return; }
|
|
var serializer = GetSerializer(value.GetType());
|
|
if (serializer == null) { return; }
|
|
|
|
if (clsIdPrefix){
|
|
output.PutUInt32(serializer.GetClsid(value).Value);
|
|
}
|
|
serializer.Serialize(output, value, context);
|
|
}
|
|
|
|
public IoBuffer SerializeBuffer(object value, ISerializationContext context, bool clsIdPrefix)
|
|
{
|
|
var buffer = IoBuffer.Allocate(256);
|
|
buffer.AutoExpand = true;
|
|
buffer.Order = ByteOrder.BigEndian;
|
|
Serialize(buffer, value, context, clsIdPrefix);
|
|
buffer.Flip();
|
|
return buffer;
|
|
}
|
|
|
|
public object Deserialize(uint clsid, IoBuffer input, ISerializationContext context)
|
|
{
|
|
var serializer = GetSerializer(clsid);
|
|
if (serializer == null) { return null; }
|
|
|
|
return serializer.Deserialize(clsid, input, context);
|
|
}
|
|
|
|
public void AddTypeSerializer(ITypeSerializer serializer)
|
|
{
|
|
TypeSerializers.Add(serializer);
|
|
}
|
|
|
|
private ITypeSerializer GetSerializer(uint clsid){
|
|
return DeserialCache.GetOrAdd(clsid, (t) =>
|
|
{
|
|
return TypeSerializers.FirstOrDefault(x => x.CanDeserialize(clsid));
|
|
});
|
|
}
|
|
|
|
private ITypeSerializer GetSerializer(Type type){
|
|
return SerialCache.GetOrAdd(type, (t) =>
|
|
{
|
|
return TypeSerializers.FirstOrDefault(x => x.CanSerialize(type));
|
|
});
|
|
}
|
|
}
|
|
}
|