feat: state enable converted added
This commit is contained in:
parent
bb934b59f3
commit
f92f36442c
53
Engine.Serialization/Converters/StateEnableConverter.cs
Normal file
53
Engine.Serialization/Converters/StateEnableConverter.cs
Normal file
@ -0,0 +1,53 @@
|
||||
using Syntriax.Engine.Core;
|
||||
|
||||
using YamlDotNet.Core;
|
||||
using YamlDotNet.Core.Events;
|
||||
using YamlDotNet.Serialization;
|
||||
|
||||
namespace Syntriax.Engine.Serialization;
|
||||
|
||||
public class StateEnableConverter : IEngineTypeYamlConverter
|
||||
{
|
||||
private const string SERIALIZED_SCALAR_NAME = "Properties";
|
||||
|
||||
public bool Accepts(Type type) => typeof(IStateEnable).IsAssignableFrom(type);
|
||||
|
||||
public object? ReadYaml(IParser parser, Type type, ObjectDeserializer rootDeserializer)
|
||||
{
|
||||
bool enabled;
|
||||
|
||||
IStateEnable stateEnable;
|
||||
|
||||
parser.Consume<MappingStart>();
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(IStateEnable.Enabled)) != 0)
|
||||
throw new();
|
||||
enabled = bool.Parse(parser.Consume<Scalar>().Value);
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(SERIALIZED_SCALAR_NAME) != 0)
|
||||
throw new();
|
||||
SerializedClass instanceSerializedClass = (SerializedClass)rootDeserializer(typeof(SerializedClass))!;
|
||||
stateEnable = (IStateEnable)instanceSerializedClass.CreateInstance();
|
||||
|
||||
parser.Consume<MappingEnd>();
|
||||
|
||||
stateEnable.Enabled = enabled;
|
||||
|
||||
return stateEnable;
|
||||
}
|
||||
|
||||
public void WriteYaml(IEmitter emitter, object? value, Type type, ObjectSerializer serializer)
|
||||
{
|
||||
IStateEnable stateEnable = (IStateEnable)value!;
|
||||
|
||||
emitter.Emit(new MappingStart());
|
||||
|
||||
emitter.Emit(new Scalar(nameof(IStateEnable.Enabled)));
|
||||
emitter.Emit(new Scalar(stateEnable.Enabled.ToString()));
|
||||
|
||||
emitter.Emit(new Scalar(SERIALIZED_SCALAR_NAME));
|
||||
serializer(new SerializedClass(stateEnable));
|
||||
|
||||
emitter.Emit(new MappingEnd());
|
||||
}
|
||||
}
|
@ -1,4 +1,5 @@
|
||||
using Syntriax.Engine.Core;
|
||||
|
||||
using YamlDotNet.Core;
|
||||
using YamlDotNet.Core.Events;
|
||||
using YamlDotNet.Serialization;
|
||||
@ -38,8 +39,7 @@ public class UniverseObjectConverter : IEngineTypeYamlConverter
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(IUniverseObject.StateEnable)) != 0)
|
||||
throw new();
|
||||
SerializedClass stateEnableSerializedClass = (SerializedClass)rootDeserializer(typeof(SerializedClass))!;
|
||||
stateEnable = (IStateEnable)stateEnableSerializedClass.CreateInstance();
|
||||
stateEnable = (IStateEnable)rootDeserializer(typeof(IStateEnable))!;
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(IUniverseObject.BehaviourController)) != 0)
|
||||
throw new();
|
||||
@ -83,7 +83,7 @@ public class UniverseObjectConverter : IEngineTypeYamlConverter
|
||||
serializer(new SerializedClass(universeObject));
|
||||
|
||||
emitter.Emit(new Scalar(nameof(IUniverseObject.StateEnable)));
|
||||
serializer(new SerializedClass(universeObject.StateEnable));
|
||||
serializer(universeObject.StateEnable);
|
||||
|
||||
emitter.Emit(new Scalar(nameof(IUniverseObject.BehaviourController)));
|
||||
serializer(new SerializedClass(universeObject.BehaviourController));
|
||||
|
Loading…
x
Reference in New Issue
Block a user