perf: made SerializedClass private and public fields optional
This commit is contained in:
parent
f77afa3632
commit
4c41870732
@ -17,22 +17,22 @@ public class SerializedClassSerializer : IEngineTypeYamlSerializer
|
||||
public object? ReadYaml(IParser parser, Type type, ObjectDeserializer rootDeserializer)
|
||||
{
|
||||
SerializedClass serializedClass = new();
|
||||
Dictionary<string, TypeContainer> publicDictionary = [];
|
||||
Dictionary<string, TypeContainer> privateDictionary = [];
|
||||
|
||||
parser.Consume<MappingStart>();
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(SerializedClass.Type)) != 0)
|
||||
throw new();
|
||||
serializedClass.Type = parser.Consume<Scalar>().Value;
|
||||
while (!parser.TryConsume<MappingEnd>(out _))
|
||||
{
|
||||
string key = parser.Consume<Scalar>().Value;
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(SerializedClass.Public)) != 0)
|
||||
throw new();
|
||||
Dictionary<string, TypeContainer> publicDictionary = (Dictionary<string, TypeContainer>)rootDeserializer(typeof(Dictionary<string, TypeContainer>))!;
|
||||
|
||||
if (parser.Consume<Scalar>().Value.CompareTo(nameof(SerializedClass.Private)) != 0)
|
||||
throw new();
|
||||
Dictionary<string, TypeContainer> privateDictionary = (Dictionary<string, TypeContainer>)rootDeserializer(typeof(Dictionary<string, TypeContainer>))!;
|
||||
|
||||
parser.Consume<MappingEnd>();
|
||||
switch (key)
|
||||
{
|
||||
case nameof(SerializedClass.Type): serializedClass.Type = parser.Consume<Scalar>().Value; break;
|
||||
case nameof(SerializedClass.Public): publicDictionary = (Dictionary<string, TypeContainer>)rootDeserializer(typeof(Dictionary<string, TypeContainer>))!; break;
|
||||
case nameof(SerializedClass.Private): privateDictionary = (Dictionary<string, TypeContainer>)rootDeserializer(typeof(Dictionary<string, TypeContainer>))!; break;
|
||||
}
|
||||
}
|
||||
|
||||
foreach ((string key, TypeContainer typeContainer) in publicDictionary)
|
||||
serializedClass.Public.Add(key, Serializer.Deserialize(typeContainer.Value!.ToString()!, TypeFactory.GetType(typeContainer.Type)));
|
||||
@ -61,11 +61,17 @@ public class SerializedClassSerializer : IEngineTypeYamlSerializer
|
||||
emitter.Emit(new Scalar(nameof(SerializedClass.Type)));
|
||||
emitter.Emit(new Scalar(serializedClass.Type));
|
||||
|
||||
emitter.Emit(new Scalar(nameof(SerializedClass.Public)));
|
||||
serializer(publics);
|
||||
if (publics.Count > 0)
|
||||
{
|
||||
emitter.Emit(new Scalar(nameof(SerializedClass.Public)));
|
||||
serializer(publics);
|
||||
}
|
||||
|
||||
emitter.Emit(new Scalar(nameof(SerializedClass.Private)));
|
||||
serializer(privates);
|
||||
if (privates.Count > 0)
|
||||
{
|
||||
emitter.Emit(new Scalar(nameof(SerializedClass.Private)));
|
||||
serializer(privates);
|
||||
}
|
||||
|
||||
emitter.Emit(new MappingEnd());
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user