feat: wip universe object converter added
This commit is contained in:
@@ -4,33 +4,33 @@ using YamlDotNet.Serialization;
|
||||
|
||||
namespace Syntriax.Engine.Serialization;
|
||||
|
||||
public class EntityReferenceConverter : IEngineTypeYamlConverter
|
||||
{
|
||||
public bool Accepts(Type type) => type == typeof(EntityReference);
|
||||
// public class EntityReferenceConverter : IEngineTypeYamlConverter
|
||||
// {
|
||||
// public bool Accepts(Type type) => type == typeof(EntityReference);
|
||||
|
||||
public object? ReadYaml(IParser parser, Type type, ObjectDeserializer rootDeserializer)
|
||||
{
|
||||
parser.Consume<MappingStart>();
|
||||
// public object? ReadYaml(IParser parser, Type type, ObjectDeserializer rootDeserializer)
|
||||
// {
|
||||
// parser.Consume<MappingStart>();
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(EntityReference.Id)) != 0)
|
||||
throw new ArgumentException($"{nameof(EntityReference)} mapping must start with {nameof(EntityReference.Id)}");
|
||||
string id = parser.Consume<Scalar>().Value;
|
||||
// if (parser.Consume<Scalar>().Value.CompareTo(nameof(EntityReference.Id)) != 0)
|
||||
// throw new ArgumentException($"{nameof(EntityReference)} mapping must start with {nameof(EntityReference.Id)}");
|
||||
// string id = parser.Consume<Scalar>().Value;
|
||||
|
||||
TypeContainer typeContainer = (TypeContainer)rootDeserializer(typeof(TypeContainer))!;
|
||||
// TypeContainer typeContainer = (TypeContainer)rootDeserializer(typeof(TypeContainer))!;
|
||||
|
||||
parser.Consume<MappingEnd>();
|
||||
// parser.Consume<MappingEnd>();
|
||||
|
||||
return new EntityReference() { Id = id, TypeContainer = typeContainer };
|
||||
}
|
||||
// return new EntityReference() { Id = id, TypeContainer = typeContainer };
|
||||
// }
|
||||
|
||||
public void WriteYaml(IEmitter emitter, object? value, Type type, ObjectSerializer serializer)
|
||||
{
|
||||
EntityReference? entityReference = (EntityReference)value!;
|
||||
// public void WriteYaml(IEmitter emitter, object? value, Type type, ObjectSerializer serializer)
|
||||
// {
|
||||
// EntityReference? entityReference = (EntityReference)value!;
|
||||
|
||||
emitter.Emit(new MappingStart());
|
||||
emitter.Emit(new Scalar(nameof(EntityReference.Id)));
|
||||
emitter.Emit(new Scalar(entityReference.Id));
|
||||
serializer(entityReference.TypeContainer, typeof(TypeContainer));
|
||||
emitter.Emit(new MappingEnd());
|
||||
}
|
||||
}
|
||||
// emitter.Emit(new MappingStart());
|
||||
// emitter.Emit(new Scalar(nameof(EntityReference.Id)));
|
||||
// emitter.Emit(new Scalar(entityReference.Id));
|
||||
// serializer(entityReference.TypeContainer, typeof(TypeContainer));
|
||||
// emitter.Emit(new MappingEnd());
|
||||
// }
|
||||
// }
|
||||
|
||||
Reference in New Issue
Block a user