diff --git a/Engine.Serialization/Converters/TypeContainer.cs b/Engine.Serialization/Converters/TypeContainer.cs new file mode 100644 index 0000000..9511c88 --- /dev/null +++ b/Engine.Serialization/Converters/TypeContainer.cs @@ -0,0 +1,10 @@ +namespace Syntriax.Engine.Serialization; + +public class TypeContainer +{ + public string Type { get; set; } = string.Empty; + + public TypeContainer() { } + public TypeContainer(Type type) { Type = type.FullName ?? string.Empty; } + public TypeContainer(object? value) { Type = value?.GetType().FullName ?? string.Empty; } +} diff --git a/Engine.Serialization/Converters/TypeContainerConverter.cs b/Engine.Serialization/Converters/TypeContainerConverter.cs new file mode 100644 index 0000000..caf10e0 --- /dev/null +++ b/Engine.Serialization/Converters/TypeContainerConverter.cs @@ -0,0 +1,27 @@ +using YamlDotNet.Core; +using YamlDotNet.Core.Events; +using YamlDotNet.Serialization; + +namespace Syntriax.Engine.Serialization; + +public class TypeContainerConverter : IEngineTypeYamlConverter +{ + public bool Accepts(Type type) => type == typeof(TypeContainer); + + public object? ReadYaml(IParser parser, Type type, ObjectDeserializer rootDeserializer) + { + if (parser.Consume().Value.CompareTo(nameof(TypeContainer.Type)) != 0) + throw new ArgumentException($"{nameof(TypeContainer)} mapping must start with {nameof(TypeContainer.Type)}"); + string typeFullName = parser.Consume().Value; + + return new TypeContainer() { Type = typeFullName }; + } + + public void WriteYaml(IEmitter emitter, object? value, Type type, ObjectSerializer serializer) + { + TypeContainer? typeContainer = (TypeContainer)value!; + + emitter.Emit(new Scalar(nameof(TypeContainer.Type))); + emitter.Emit(new Scalar(typeContainer.Type)); + } +}